首页
/ EntityAuditBundle 技术文档

EntityAuditBundle 技术文档

2024-12-25 09:20:15作者:俞予舒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 的技术文档概览,希望对您有所帮助。

热门项目推荐
相关项目推荐

项目优选

收起
Python-100-DaysPython-100-Days
Python - 100天从新手到大师
Python
373
72
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
276
72
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
200
47
xzs-mysqlxzs-mysql
学之思开源考试系统是一款 java + vue 的前后端分离的考试系统。主要优点是开发、部署简单快捷、界面设计友好、代码结构清晰。支持web端和微信小程序,能覆盖到pc机和手机等设备。 支持多种部署方式:集成部署、前后端分离部署、docker部署
HTML
5
1
LangChatLangChat
LangChat: Java LLMs/AI Project, Supports Multi AI Providers( Gitee AI/ 智谱清言 / 阿里通义 / 百度千帆 / DeepSeek / 抖音豆包 / 零一万物 / 讯飞星火 / OpenAI / Gemini / Ollama / Azure / Claude 等大模型), Java生态下AI大模型产品解决方案,快速构建企业级AI知识库、AI机器人应用
Java
11
3
gin-vue-admingin-vue-admin
🚀Vite+Vue3+Gin的开发基础平台,支持TS和JS混用。它集成了JWT鉴权、权限管理、动态路由、显隐可控组件、分页封装、多点登录拦截、资源权限、上传下载、代码生成器【可AI辅助】、表单生成器和可配置的导入导出等开发必备功能。
Go
16
3
source-vuesource-vue
🔥 一直想做一款追求极致用户体验的快速开发平台,看了很多优秀的开源项目但是发现没有合适的。于是利用空闲休息时间对若依框架进行扩展写了一套快速开发系统。如此有了开源字节快速开发平台。该平台基于 Spring Boot + MyBatis + Vue & Element ,包含微信小程序 & Uniapp, Web 报表、可视化大屏、三方登录、支付、短信、邮件、OSS...
Java
24
2
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
898
0
madongmadong
基于Webman的权限管理系统
PHP
4
0
cool-admin-javacool-admin-java
🔥 cool-admin(java版)一个很酷的后台权限管理框架,Ai编码、流程编排、模块化、插件化、CRUD极速开发,永久开源免费,基于springboot3、typescript、vue3、vite、element-ui等构建
Java
18
2