# 数据合规与留存策略 > 版本:v1.0 | 状态:已生效 > 关联:tech/INTERFACE.md、PRODUCTION_PHASE1_STATUS.md --- ## 1. 数据分类 ### 1.1 数据类别 | 类别 | 内容 | 示例 | |------|------|------| | 用户数据 | 用户在客服系统中的会话、消息、工单 | session_id、message_content、ticket_id | | 账户数据 | 与主系统关联的用户身份、配额、Token | user_id、email、quota | | 行为数据 | 用户操作日志、审计日志 | audit_logs、action、source_ip | | 运营数据 | 转人工原因、统计指标 | handoff_reason、priority | --- ## 2. 数据合规要求 ### 2.1 法律法规遵循 本系统应遵循以下合规要求: | 要求 | 说明 | 当前状态 | |------|------|----------| | 数据最小化 | 只收集业务必需的数据 | 部分满足 | | 目的限定 | 数据仅用于客服目的,不用于其他用途 | 满足 | | 用户知情 | 用户应知道自己的数据被收集 | 待补充 | | 删除权 | 用户请求删除时,应可删除相关数据 | 待实现 | ### 2.2 敏感数据处理 | 数据类型 | 存储要求 | 展示要求 | 当前状态 | |----------|----------|----------|----------| | 用户邮箱 | 加密存储(待实现) | 脱敏后展示 | 未实现 | | 手机号 | 加密存储(待实现) | 脱敏后展示 | 未实现 | | 消息内容 | 明文存储 | 不脱敏 | 已实现 | | 退款金额 | 明文存储 | 需登录态 | 已实现 | | IP 地址 | 明文存储 | 日志中记录 | 已实现 | --- ## 3. 数据留存策略 ### 3.1 留存周期 | 数据类型 | 留存周期 | 说明 | |----------|----------|------| | 审计日志(security) | 2 年 | 不可删除,用于安全审计 | | 审计日志(operation) | 1 年 | 工单操作记录 | | 会话消息 | 90 天 | 用户对话历史 | | 工单记录 | 1 年 | 已解决/已关闭工单 | | 开放工单 | 永久保留 | 直到关闭 | | 健康检查日志 | 30 天 | 运维数据 | ### 3.2 数据删除流程 **触发条件**: - 用户主动请求删除(GDPR/个人信息保护法) - 超过留存周期的数据 **删除执行**: 1. 软删除:在对应记录上标记 `deleted_at` 时间戳 2. 硬删除:超过保留期后执行物理删除(仅 admin 可执行) 3. 备份清理:删除备份中的对应数据 > **注**:软删除和硬删除机制**当前未实现**(所有数据直接物理删除),需 Phase 4 补充。 ### 3.3 数据隔离 | 隔离维度 | 当前状态 | 说明 | |----------|----------|------| | 多租户隔离 | 未实现 | 生产一期仅支持单租户 | | 测试数据隔离 | 部分实现 | 测试环境使用独立数据库 | 跨租户数据访问 | --- ## 4. 审计日志规范 ### 4.1 审计日志表结构 **表**:`cs_audit_logs` | 字段 | 类型 | 说明 | |------|------|------| | id | uuid | 审计记录唯一 ID | | tenant_id | string | 租户 ID(当前固定为 `default`) | | object_type | string | 对象类型:ticket、session、message | | object_id | string | 对象 ID | | action | string | 操作类型:create/update/delete/security_reject | | before_state | jsonb | 操作前状态(可选) | | after_state | jsonb | 操作后状态(可选) | | actor_id | string | 操作者 ID(若为空则降级为 open_id) | | source_ip | string | 操作来源 IP(**P0 缺口:当前未写入**) | | created_at | timestamp | 创建时间 | ### 4.2 记录范围 **已记录**: - ✅ 工单创建(ticket.create) - ✅ 消息处理(message.processed) - ✅ 审计写入失败(fail-closed,整体请求返回错误) **未记录(P0 缺口)**: - ❌ 工单分配(ticket.assign) - ❌ 工单解决(ticket.resolve) - ❌ 安全拒绝事件(signature_invalid、timestamp_invalid、body_rejected) ### 4.3 审计日志不可篡改性 - 审计日志表**无 UPDATE / DELETE 权限**,仅 INSERT - 定期备份到冷存储 - 备份文件设置保留策略(2年) --- ## 5. 数据库安全 ### 5.1 PostgreSQL 安全 | 要求 | 当前状态 | |------|----------| | 强密码策略 | ✅ 配置文件中使用强密码 | | SSL 连接 | ✅ 支持 SSL(配置项:`POSTGRES_SSL_MODE`) | | 最小权限原则 | ✅ 应用使用专用数据库用户,仅授予必要权限 | | 连接池限制 | ✅ 使用 pgbouncer 或内置连接池 | | 定期备份 | 手动备份(待自动化) | ### 5.2 备份策略 | 备份类型 | 频率 | 保留时间 | |----------|------|----------| | 全量备份 | 每天 | 30 天 | | 增量备份 | 每小时 | 7 天 | | 审计日志备份 | 每周 | 2 年 | | 异地备份 | 每月 | 1 年 | > **注**:备份自动化**当前未落地**,需在部署阶段补充。 --- ## 6. 当前阶段说明 ### 6.1 已满足的合规项 - 数据最小化:系统只收集业务必需字段 - 审计日志持久化到 PostgreSQL,fail-closed 保证审计不丢失 - 无外部数据共享 - 单租户数据隔离 ### 6.2 待补充的合规项 | 项目 | 优先级 | 说明 | |------|--------|------| | 敏感数据加密存储 | P1 | 邮箱、手机号等加密存储 | | 软删除/硬删除机制 | P1 | 支持用户数据删除请求 | | 备份自动化 | P1 | 定时备份脚本 | | 用户知情同意 | P1 | 前端告知用户数据收集 | | 隐私政策页面 | P1 | 展示数据处理说明 | | RBAC 权限模型 | P0 | 防止越权访问 | --- ## 7. 当前版本状态 - **本文档版本**:v1.0 - **生效日期**:2026-04-30 - **下次审查**:Phase 4 补充隐私政策后