tourze/wechat-work-group-welcome-template-bundle 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

tourze/wechat-work-group-welcome-template-bundle

最新稳定版本:0.0.2

Composer 安装命令:

composer require tourze/wechat-work-group-welcome-template-bundle

包简介

客户联系-入群欢迎语素材

README 文档

README

PHP Version License Symfony Build Status Code Coverage

English | 中文

A Symfony bundle for managing WeChat Work group welcome templates. This bundle provides entities, repositories, and API requests for creating, editing, and managing welcome messages that are sent to new group members.

Table of Contents

Features

  • Entity Management: Doctrine ORM entities for group welcome templates
  • API Integration: Request classes for WeChat Work external contact API
  • Rich Content Support: Support for text, images, links, mini-programs, files, and videos
  • Automatic Sync: Event listeners for automatic synchronization with WeChat Work
  • Comprehensive Testing: Full test coverage with PHPUnit

Installation

Install the bundle via Composer:

composer require tourze/wechat-work-group-welcome-template-bundle

Quick Start

1. Create a Group Welcome Template

use WechatWorkGroupWelcomeTemplateBundle\Entity\GroupWelcomeTemplate;
use WechatWorkGroupWelcomeTemplateBundle\Request\AddGroupWelcomeTemplateRequest;

// Create a new template entity
$template = new GroupWelcomeTemplate();
$template->setAgent($agent); // Your WeChat Work agent
$template->setNotify(true);
$template->setTextContent('Welcome to our group!');
$template->setSync(true); // Enable automatic sync

// Save to database (will automatically sync to WeChat Work)
$entityManager->persist($template);
$entityManager->flush();

2. Create API Request Manually

use WechatWorkGroupWelcomeTemplateBundle\Request\AddGroupWelcomeTemplateRequest;

$request = new AddGroupWelcomeTemplateRequest();
$request->setAgent($agent);
$request->setNotify(true);
$request->setTextContent('Welcome to our team!');
$request->setLinkTitle('Learn More');
$request->setLinkUrl('https://example.com');
$request->setLinkDesc('Click to learn more about our company');

// Use with WorkService
$response = $workService->request($request);

3. Rich Content Templates

$template = new GroupWelcomeTemplate();
$template->setAgent($agent);
$template->setNotify(true);

// Text content
$template->setTextContent('Welcome! Here are some resources:');

// Image
$template->setImageMedia($imageMedia); // TempMedia entity
// or
$template->setImagePicUrl('https://example.com/welcome.jpg');

// Link
$template->setLinkTitle('Company Website');
$template->setLinkUrl('https://company.com');
$template->setLinkDesc('Visit our website');
$template->setLinkPicUrl('https://company.com/logo.jpg');

// Mini-program
$template->setMiniprogramTitle('Team Tool');
$template->setMiniprogramAppId('wxabcd1234');
$template->setMiniprogramPage('pages/welcome');
$template->setMiniprogramMedia($miniprogramMedia);

// File
$template->setFileMedia($fileMedia);

// Video
$template->setVideoMedia($videoMedia);

Configuration

The bundle automatically configures services. No additional configuration is required.

Service Configuration

Services are automatically registered:

  • WechatWorkGroupWelcomeTemplateBundle\Repository\GroupWelcomeTemplateRepository
  • WechatWorkGroupWelcomeTemplateBundle\EventSubscriber\GroupWelcomeTemplateListener

API Requests

The bundle provides several request classes for WeChat Work API:

AddGroupWelcomeTemplateRequest

$request = AddGroupWelcomeTemplateRequest::createFromEntity($template);
$response = $workService->request($request);

EditGroupWelcomeTemplateRequest

$request = EditGroupWelcomeTemplateRequest::createFromEntity($template);
$request->setTemplateId($templateId);
$response = $workService->request($request);

DeleteGroupWelcomeTemplateRequest

$request = new DeleteGroupWelcomeTemplateRequest();
$request->setTemplateId($templateId);
$request->setAgent($agent);
$response = $workService->request($request);

GetGroupWelcomeTemplateRequest

$request = new GetGroupWelcomeTemplateRequest();
$request->setTemplateId($templateId);
$request->setAgent($agent);
$response = $workService->request($request);

Entity Properties

The GroupWelcomeTemplate entity includes:

  • Basic Properties: agent, templateId, notify
  • Text Content: textContent
  • Image: imageMedia, imagePicUrl
  • Link: linkTitle, linkUrl, linkDesc, linkPicUrl
  • Mini-program: miniprogramTitle, miniprogramAppId, miniprogramPage, miniprogramMedia
  • File: fileMedia
  • Video: videoMedia
  • Tracking: Created/updated timestamps, user blame, IP tracking

Event Listeners

The bundle includes automatic event listeners:

  • prePersist: Creates template in WeChat Work when saving new entities
  • preUpdate: Updates template in WeChat Work when modifying entities
  • postRemove: Deletes template from WeChat Work when removing entities

Advanced Usage

Custom Event Listeners

You can create custom event listeners for additional functionality:

use Doctrine\Bundle\DoctrineBundle\Attribute\AsEntityListener;
use Doctrine\ORM\Events;
use WechatWorkGroupWelcomeTemplateBundle\Entity\GroupWelcomeTemplate;

 #[AsEntityListener(event: Events::postPersist, method: 'postPersist')]
class CustomGroupWelcomeTemplateListener
{
    public function postPersist(GroupWelcomeTemplate $template): void
    {
        // Custom logic after template creation
    }
}

Repository Extensions

Extend the repository for custom queries:

use WechatWorkGroupWelcomeTemplateBundle\Repository\GroupWelcomeTemplateRepository;

class CustomGroupWelcomeTemplateRepository extends GroupWelcomeTemplateRepository
{
    public function findActiveTemplates(): array
    {
        return $this->createQueryBuilder('t')
            ->where('t.sync = :sync')
            ->setParameter('sync', true)
            ->getQuery()
            ->getResult();
    }
}

Batch Operations

For bulk operations, you can disable automatic sync:

// Process multiple templates without individual sync
foreach ($templates as $template) {
    $template->setSync(false); // Disable auto-sync
    $entityManager->persist($template);
}
$entityManager->flush();

// Manually sync all at once
$syncRequest = new BatchSyncGroupWelcomeTemplatesRequest();
// ... configure and execute

Testing

Run the test suite:

./vendor/bin/phpunit packages/wechat-work-group-welcome-template-bundle/tests

Test Coverage

The bundle includes comprehensive test coverage:

  • Entity Tests: Test GroupWelcomeTemplate entity properties and methods
  • Repository Tests: Test repository construction and basic functionality
  • Request Tests: Test API request classes and data transformation
  • Event Listener Tests: Test automatic synchronization with WeChat Work
  • Dependency Injection Tests: Test bundle configuration and service registration

Requirements

  • PHP 8.1+
  • Symfony 6.4+
  • Doctrine ORM 3.0+
  • tourze/wechat-work-bundle
  • tourze/wechat-work-media-bundle

License

This bundle is released under the MIT License. See the bundled LICENSE file for details.

References

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-06-04