首页
/ EntityAuditBundle 技术文档

EntityAuditBundle 技术文档

2024-12-25 03:18:54作者:俞予舒Fleming

1. 安装指南

EntityAuditBundle 是一个为 Doctrine 2 提供实体和其关联完整版本功能的扩展。以下是安装步骤:

安装扩展

假设您已经安装了 Composer,运行以下命令:

$ composer require sonata-project/entity-audit-bundle

启用扩展

在您的应用内核中启用扩展:

// config/bundles.php

return [
    //...
    SimpleThings\EntityAudit\SimpleThingsEntityAuditBundle::class => ['all' => true],
    //...
];

配置

加载 "simple_things_entity_audit" 扩展并指定审计实体:

# config/packages/entity_audit.yaml

simple_things_entity_audit:
    audited_entities:
        - MyBundle\Entity\MyEntity
        - MyBundle\Entity\MyEntity2

如果您需要排除某些实体属性以避免触发修订,使用以下配置:

# config/packages/entity_audit.yaml

simple_things_entity_audit:
    global_ignore_columns:
        - created_at
        - updated_at

若要使用除 "default" 之外的连接或实体管理器,使用以下设置:

# config/packages/entity_audit.yaml

simple_things_entity_audit:
    connection: custom
    entity_manager: custom

如果需要显式禁用从审计实体推断的外键,使用以下参数:

simple_things_entity_audit:
    disable_foreign_keys: true

创建新表

运行以下命令查看更新模式队列中的新表:

./bin/console doctrine:schema:update --dump-sql

2. 项目的使用说明

EntityAuditBundle 可以自动为实体和其关联创建版本。它通过在数据库中为每个审计实体创建一个后缀为 "_audit" 的镜像表来实现。除了审计实体的所有列之外,还有两个字段:

  • rev:包含从 "revisions" 表生成的全局修订号。
  • revtype:包含 'INS'、'UPD' 或 'DEL' 作为指示哪种数据库操作导致了修订日志条目的信息。

全局修订表包含一个 ID、时间戳、用户名和更改评论字段。

使用这种方法可以实现对应用程序及其在特定时间点的关联更改的版本控制。

此扩展会钩入 SchemaTool 生成过程,以便自动为您的审计实体创建所需的 DDL 语句。

3. 项目API使用文档

以下是 EntityAuditBundle 提供的一些主要 API 方法:

  • find($className, $id, $rev):查找给定修订号下的实体状态。
  • findRevisions($className, $id):查找实体的修订历史。
  • findEntitiesChangedAtRevision($rev):查找在特定修订中更改的实体。
  • getCurrentRevision($className, $id):查找实体的当前修订号。

4. 项目安装方式

EntityAuditBundle 可以通过以下方式安装:

  • Composer:使用 composer require sonata-project/entity-audit-bundle 命令安装。
  • Standalone:对于独立使用,您需要将实体类名传递给 MetadataFactory 实例并配置两个事件监听器。具体请参考项目文档中的 "Installation (Standalone)" 部分。

以上是 EntityAuditBundle 的技术文档概览,希望对您有所帮助。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
54
469
kernelkernel
deepin linux kernel
C
22
5
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
880
519
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
336
1.1 K
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
181
264
cjoycjoy
一个高性能、可扩展、轻量、省心的仓颉Web框架。Rest, 宏路由,Json, 中间件,参数绑定与校验,文件上传下载,MCP......
Cangjie
87
14
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.09 K
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
361
381
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
613
60