tourze / wechat-mini-program-url-link-bundle
微信小程序 URL Link
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:symfony-bundle
pkg:composer/tourze/wechat-mini-program-url-link-bundle
Requires
- php: ^8.1
- doctrine/collections: ^2.3
- doctrine/dbal: ^4.0
- doctrine/doctrine-bundle: ^2.13
- doctrine/orm: ^3.0
- doctrine/persistence: ^3.1 || ^4
- monolog/monolog: ^3.1
- nesbot/carbon: ^2.72 || ^3
- psr/link: ^1.1|^2.0
- psr/log: ^3|^2|^1
- symfony/config: ^6.4
- symfony/console: ^6.4
- symfony/dependency-injection: ^6.4
- symfony/doctrine-bridge: ^6.4
- symfony/event-dispatcher-contracts: ^2.5 | ^3
- symfony/framework-bundle: ^6.4
- symfony/http-foundation: ^6.4
- symfony/http-kernel: ^6.4
- symfony/routing: ^6.4
- symfony/security-bundle: ^6.4
- symfony/security-core: ^6.4
- symfony/serializer: ^6.4
- symfony/web-link: ^6.4
- symfony/yaml: ^6.4 || ^7.1
- tourze/arrayable: 0.0.*
- tourze/doctrine-async-bundle: 0.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/json-rpc-core: 0.0.*
- tourze/symfony-cron-job-bundle: 0.1.*
- tourze/symfony-schedule-entity-clean-bundle: 0.1.*
- tourze/wechat-mini-program-bundle: 0.1.*
- tourze/weui-bundle: 0.0.*
Requires (Dev)
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^10.0
This package is auto-updated.
Last update: 2025-11-01 19:31:30 UTC
README
WeChat Mini Program URL Link management bundle, providing URL Link (short link) and promotion code generation, management, and statistics features.
Table of Contents
- Features
- Installation
- Quick Start
- Main Features
- Configuration
- Advanced Usage
- Testing
- Dependencies
- License
Features
- Generate WeChat Mini Program URL Links (short links)
- Promotion code generation and management
- Visit statistics and analysis
- Automatic URL Link visit status query
- Daily promotion effectiveness statistics
Installation
composer require tourze/wechat-mini-program-url-link-bundle
Quick Start
1. Register the Bundle
In your config/bundles.php:
return [ // ... other bundles WechatMiniProgramUrlLinkBundle\WechatMiniProgramUrlLinkBundle::class => ['all' => true], ];
2. Update Database Schema
php bin/console doctrine:schema:update --force
3. Basic Usage
// Generate a promotion code $promotionCode = new PromotionCode(); $promotionCode->setName('New Year Promotion'); $promotionCode->setCode('NY2024'); $promotionCode->setLinkUrl('pages/promotion/detail'); $promotionCode->setAccount($miniProgramAccount); $entityManager->persist($promotionCode); $entityManager->flush(); // Access the short link // Visit: https://yourdomain.com/t.htm?NY2024
Configuration
This bundle uses standard Symfony Bundle configuration, with main configuration items injected through the service container.
Required Service Dependencies
WechatMiniProgramBundle\Service\Client- WeChat Mini Program client serviceEntityManagerInterface- Doctrine entity managerLoggerInterface- Logger service
Environment Variables
# Redirect page path (optional, default: pages/redirect/index)
WECHAT_MINI_PROGRAM_PROMOTION_REDIRECT_PATH=pages/redirect/index
Main Features
1. URL Link Management
URL Link is a short link feature provided by WeChat Mini Program that allows opening mini programs from outside WeChat.
Entity Description
UrlLink- URL Link entity, stores generated short link informationVisitLog- Visit log, records user visit historyDailyStatus- Daily statistics data
Core Services
UrlLinkService- URL Link core service, provides short link query and status update functionality
2. Promotion Code Feature
The promotion code system is used to track promotion effectiveness across different channels.
Entity Description
PromotionCode- Promotion code entityCodeRule- Promotion code rule configurationCodeRuleTag- Promotion code tags
3. API Endpoints
Generate Short Link
- Route:
POST /api/wechat-mini-program/url-link/generate - Request Parameters:
GenerateUrlLinkRequest - Function: Generate new mini program short link
Query Short Link
- Route:
POST /api/wechat-mini-program/url-link/query - Request Parameters:
QueryUrlLinkRequest - Function: Query short link visit status
4. Console Commands
wechat-mini-program:count-promotion-daily-status
Periodically count promotion code visit numbers.
Purpose:
- Count daily visits for each promotion code
- Update daily statistics data
- Supports scheduled task execution (every 10 minutes)
Usage:
bin/console wechat-mini-program:count-promotion-daily-status
Features:
- Automatically count all promotion code visits for the current day
- Update or create
DailyStatusrecords - Only update data when visit count increases
wechat-mini-program:query-url-link-result
Batch query URL Link click results.
Purpose:
- Batch check unconfirmed short link statuses
- Get visitor information through WeChat API
- Automatically mark expired links
Usage:
# Default: process 500 records, 60 minutes timeout bin/console wechat-mini-program:query-url-link-result # Custom record count and timeout bin/console wechat-mini-program:query-url-link-result 1000 120
Parameters:
limit(optional): Number of records to process at once, default 500minute(optional): Timeout in minutes, default 60
Features:
- Query all URL Links with
checked = false - Call WeChat API to get visitor's OpenID
- Automatically mark links as checked if not visited within specified time
- Supports scheduled task execution (every 10 minutes)
5. Event System
PromotionCodeRequestEvent
Promotion code request event, triggered when processing promotion code related requests.
Database Tables
Includes the following main tables:
wechat_mini_program_url_link- URL Link tablewechat_mini_program_promotion_code- Promotion code tablewechat_mini_program_code_rule- Promotion code rule tablewechat_mini_program_code_rule_tag- Promotion code tag tablewechat_mini_program_visit_log- Visit log tablewechat_mini_program_daily_status- Daily statistics table
Advanced Usage
Generate URL Link
use WechatMiniProgramUrlLinkBundle\Request\GenerateUrlLinkRequest; $request = new GenerateUrlLinkRequest(); $request->setPath('/pages/index/index'); $request->setQuery('source=test'); $request->setIsExpire(true); $request->setExpireType(1); $request->setExpireInterval(7); // Call through API endpoint // POST /api/wechat-mini-program/url-link/generate
Query URL Link Status
use WechatMiniProgramUrlLinkBundle\Service\UrlLinkService; // Inject service $urlLinkService = $container->get(UrlLinkService::class); // Query specific URL Link status $urlLink = $urlLinkRepository->find($id); $urlLinkService->apiCheck($urlLink);
Generate QR Code for Promotion Code
use WechatMiniProgramUrlLinkBundle\Service\PromotionCodeQrcodeService; // Inject service $qrcodeService = $container->get(PromotionCodeQrcodeService::class); // Generate QR code for promotion code $imageUrl = $qrcodeService->generateQrcode($promotionCode);
Testing
Run unit tests:
./vendor/bin/phpunit packages/wechat-mini-program-url-link-bundle/tests
Dependencies
tourze/wechat-mini-program-bundle- WeChat Mini Program base functionality bundletourze/doctrine-*- Doctrine extension bundle seriestourze/symfony-cron-job-bundle- Scheduled task support- Symfony 6.4+ components
License
MIT