tourze/doctrine-user-agent-bundle 问题修复 & 功能扩展

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

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

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

English | 中文

Latest Version Total Downloads PHP Version Require License Code Coverage

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

  1. Add the bundle to your application's kernel:
// config/bundles.php
return [
    // ...
    Tourze\DoctrineUserAgentBundle\DoctrineUserAgentBundle::class => ['all' => true],
];
  1. 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...
}
  1. 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

  1. Request Capture: The bundle listens to Symfony's KernelEvents::REQUEST and captures the User-Agent header
  2. Entity Events: When Doctrine triggers prePersist or preUpdate events, the bundle checks for marked properties
  3. Value Assignment: Only assigns User-Agent values to properties that are currently null
  4. 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

GitHub 信息

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

其他信息

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