tourze/doctrine-user-agent-bundle
最新稳定版本:1.0.0
Composer 安装命令:
composer require tourze/doctrine-user-agent-bundle
包简介
A Symfony bundle that automatically captures and records User-Agent information in Doctrine entities for analytics and audit purposes
README 文档
README
A Symfony bundle that automatically captures and records User-Agent information in Doctrine entities for analytics and audit purposes.
Features
- 🚀 Zero Configuration - Works out of the box with simple attributes
- 📱 Auto-Detection - Automatically captures User-Agent from HTTP requests
- 🏷️ Attribute-Based - Simple PHP 8+ attributes to mark entity properties
- ⚡ Event-Driven - Seamless integration with Doctrine ORM lifecycle events
- 🔄 Create & Update - Separate tracking for entity creation and modification
- 🧩 Ready-to-Use Traits - Pre-built traits for common use cases
- 🔒 Non-Intrusive - Only sets values when properties are null
Installation
composer require tourze/doctrine-user-agent-bundle
Quick Start
- Add the bundle to your application's kernel:
// config/bundles.php return [ // ... Tourze\DoctrineUserAgentBundle\DoctrineUserAgentBundle::class => ['all' => true], ];
- Use attributes in your entity:
use Doctrine\DBAL\Types\Types; use Doctrine\ORM\Mapping as ORM; use Tourze\DoctrineUserAgentBundle\Attribute\CreateUserAgentColumn; use Tourze\DoctrineUserAgentBundle\Attribute\UpdateUserAgentColumn; #[ORM\Entity] class Article { #[ORM\Id] #[ORM\GeneratedValue] #[ORM\Column] private ?int $id = null; #[CreateUserAgentColumn] #[ORM\Column(type: Types::TEXT, nullable: true)] private ?string $createdUserAgent = null; #[UpdateUserAgentColumn] #[ORM\Column(type: Types::TEXT, nullable: true)] private ?string $updatedUserAgent = null; // Getters and setters... }
- Or use the convenience trait:
use Tourze\DoctrineUserAgentBundle\Traits\CreatedByUAAware; #[ORM\Entity] class Article { use CreatedByUAAware; #[ORM\Id] #[ORM\GeneratedValue] #[ORM\Column] private ?int $id = null; // Your other properties... }
Usage
Available Attributes
#[CreateUserAgentColumn]
Records the User-Agent header when the entity is first persisted to the database.
#[CreateUserAgentColumn] #[ORM\Column(type: Types::TEXT, nullable: true)] private ?string $createdUserAgent = null;
#[UpdateUserAgentColumn]
Records the User-Agent header when the entity is updated.
#[UpdateUserAgentColumn] #[ORM\Column(type: Types::TEXT, nullable: true)] private ?string $updatedUserAgent = null;
Available Traits
CreatedByUAAware
A ready-to-use trait that adds a createdFromUa property with proper Doctrine mapping:
use Tourze\DoctrineUserAgentBundle\Traits\CreatedByUAAware; class MyEntity { use CreatedByUAAware; // Access the User-Agent public function getCreatedFromUa(): ?string { return $this->createdFromUa; } }
How It Works
- Request Capture: The bundle listens to Symfony's
KernelEvents::REQUESTand captures theUser-Agentheader - Entity Events: When Doctrine triggers
prePersistorpreUpdateevents, the bundle checks for marked properties - Value Assignment: Only assigns User-Agent values to properties that are currently
null - Non-Intrusive: Existing values are never overwritten
Use Cases
- Analytics: Track which browsers/devices are creating content
- Audit Logging: Maintain detailed records of entity modifications
- Security: Monitor suspicious User-Agent patterns
- User Experience: Understand your users' technology preferences
Requirements
- PHP 8.1 or higher
- Symfony 6.4 or higher
- Doctrine ORM 3.0 or higher
- Doctrine DBAL 4.0 or higher
- Doctrine Bundle 2.13 or higher
Contributing
Please see CONTRIBUTING.md for details.
License
The MIT License (MIT). Please see License File for more information.
统计信息
- 总下载量: 16.05k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 4
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-04-07