tourze / wechat-work-group-welcome-template-bundle
客户联系-入群欢迎语素材
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
Type:symfony-bundle
pkg:composer/tourze/wechat-work-group-welcome-template-bundle
Requires
- php: ^8.1
- doctrine/dbal: ^4.0
- doctrine/doctrine-bundle: ^2.13
- doctrine/orm: ^3.0
- doctrine/persistence: ^3.1 || ^4
- psr/log: ^3|^2|^1
- symfony/config: ^6.4
- symfony/console: ^6.4
- symfony/dependency-injection: ^6.4
- symfony/doctrine-bridge: ^6.4
- symfony/framework-bundle: ^6.4
- symfony/http-kernel: ^6.4
- symfony/routing: ^6.4
- symfony/serializer: ^6.4
- symfony/yaml: ^6.4 || ^7.1
- tourze/doctrine-indexed-bundle: 0.0.*
- tourze/doctrine-ip-bundle: 0.0.*
- tourze/doctrine-snowflake-bundle: 0.1.*
- tourze/doctrine-timestamp-bundle: 0.0.*
- tourze/doctrine-track-bundle: 0.1.*
- tourze/doctrine-user-bundle: 0.0.*
- tourze/easy-admin-attribute: 0.1.*
- tourze/http-client-bundle: 0.1.*
- tourze/wechat-work-bundle: 0.1.*
- tourze/wechat-work-contracts: 0.0.*
- tourze/wechat-work-media-bundle: 0.1.*
Requires (Dev)
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^10.0
This package is auto-updated.
Last update: 2025-10-31 20:11:44 UTC
README
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
- Installation
- Quick Start
- Configuration
- API Requests
- Entity Properties
- Event Listeners
- Advanced Usage
- Testing
- Requirements
- License
- References
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\GroupWelcomeTemplateRepositoryWechatWorkGroupWelcomeTemplateBundle\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.