tourze / resource-manage-bundle
资源管理
Installs: 3
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: ^8.1
- doctrine/dbal: ^3.7.0 || ^4.0
- doctrine/doctrine-bundle: ^2.13
- doctrine/persistence: ^3.1 || ^4
- psr/log: ^3|^2|^1
- symfony/config: ^6.4
- symfony/dependency-injection: ^6.4
- symfony/framework-bundle: ^6.4
- symfony/http-kernel: ^6.4
- symfony/security-core: ^6.4
- tourze/easy-admin-attribute: 0.0.*
- tourze/enum-extra: ~0.0.5
Requires (Dev)
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^10.0
This package is auto-updated.
Last update: 2025-04-19 12:19:04 UTC
README
系统概述
资源管理系统是一个通用的资源发放和管理框架,支持多种类型资源的统一管理和分发。系统采用接口定义和依赖注入的方式,实现了高度的可扩展性和灵活性。
核心组件
1. ResourceIdentity 接口
定义了资源的基本标识接口,包含:
- getResourceId(): 获取资源唯一标识
- getResourceLabel(): 获取资源显示名称
2. ResourceProvider 接口
资源提供者的统一接口,负责具体资源类型的管理和发放:
- getCode(): 资源类型的唯一标识
- getLabel(): 资源类型的显示名称
- getIdentities(): 获取该类型下所有可用的资源列表
- findIdentity(): 查找特定资源
- sendResource(): 发放资源给用户
3. ResourceManager 服务
资源管理器,负责:
- 统一管理所有资源提供者
- 提供资源选择数据
- 统一的资源发放入口
已实现的资源类型
1. 优惠券资源 (CouponResourceProvider)
- 类型标识:coupon
- 功能:管理和发放优惠券
- 特点:与优惠券系统集成,支持优惠券的查找和发放
2. 实物奖品资源 (SpuOfferResourceProvider)
- 类型标识:material
- 功能:管理和发放实物商品
- 特点:与商品系统集成,支持商品库存管理和订单创建
3. 文本资源 (TextResourceProvider)
- 类型标识:text
- 功能:用于发放文本类型的安慰奖
- 特点:无实际发放行为,用于安慰奖场景
4. 虚拟资源 (VirtualResourceProvider)
- 类型标识:virtual
- 功能:用于发放虚拟奖品
- 特点:无实际发放行为,用于虚拟奖品场景
如何实现新的资源类型
- 创建资源实体类并实现 ResourceIdentity 接口
class MyResource implements ResourceIdentity { public function getResourceId(): string { return $this->id; } public function getResourceLabel(): string { return $this->name; } }
- 创建资源提供者类并实现 ResourceProvider 接口
class MyResourceProvider implements ResourceProvider { public function getCode(): string { return 'my_resource'; } public function getLabel(): string { return '我的资源'; } public function getIdentities(): iterable|null { // 返回所有可用资源 } public function findIdentity(string $identity): ResourceIdentity|null { // 查找特定资源 } public function sendResource(BizUser $user, ResourceIdentity $identity, string $amount, ?int $expireDay = null, ?\DateTimeInterface $expireTime = null): void { // 实现资源发放逻辑 } }
- 资源提供者会自动注册到系统中(通过 AutoconfigureTag 注解)
使用示例
// 注入资源管理器 private ResourceManager $resourceManager; // 发放资源 $this->resourceManager->send( $user, // 用户 'coupon', // 资源类型 'COUPON001', // 资源ID '1', // 数量 30, // 过期天数(可选) null // 过期时间(可选) ); // 获取所有可用资源类型 $resources = $this->resourceManager->genSelectData();
注意事项
- 资源类型的 Code 必须全局唯一
- 实现新的资源类型时,需要同时实现资源标识和提供者
- 资源发放时需要处理异常情况
- 建议为新增的资源类型添加单元测试