archery修改为不能自提自审核上线SQL

目录

背景

  • 我和同事都可以提交上线SQL,但是不能自己提交的SQL自己去审核通过。
  • 目前的情况是可以自提自审。

修改代码

  • 找到/opt/archery/sql/utils/workflow_audit.py文件
python 复制代码
...省略...
     # 判断用户当前是否是可审核
    @staticmethod
    def can_review(user, workflow_id, workflow_type):
        audit_info = WorkflowAudit.objects.get(
            workflow_id=workflow_id, workflow_type=workflow_type
        )
        group_id = audit_info.group_id
        result = False
        # 只有待审核状态数据才可以审核
        if audit_info.current_status == WorkflowDict.workflow_status["audit_wait"]:
            try:
                auth_group_id = Audit.detail_by_workflow_id(
                    workflow_id, workflow_type
                ).current_audit
                audit_auth_group = Group.objects.get(id=auth_group_id).name
            except Exception:
                raise Exception("当前审批auth_group_id不存在,请检查并清洗历史数据")
            if (
                    auth_group_users([audit_auth_group], group_id)
                            .filter(id=user.id)
                            .exists()
                    or user.is_superuser == 1
            ):
                if workflow_type == 1:
                    if user.has_perm("sql.query_review"):
                        result = True
                elif workflow_type == 2:
                    if user.has_perm("sql.sql_review"):
                        result = True
                elif workflow_type == 3:
                    if user.has_perm("sql.archive_review"):
                        result = True

        if group_id in [1, 2]:    # 增加
            create_user = audit_info.create_user  # 增加
            if create_user == user.username:  # 增加
                result = False   # 增加
        return result
... 省略...
  • group_id 是资源组ID
  • 我这边使用docker运行,把·workflow_audit.py·文件替换就好。运行以下命令。
bash 复制代码
docker cp workflow_audit.py archery:/opt/archery/sql/utils/
  • 然后重启
bash 复制代码
docker restart archery

效果

  • 现在我自己的帐户就没有审批自己提交SQL的权限了,如下图所示。
  • 登录别人的账号有审核的权限,如下图所示。

参考

相关推荐
青春:一叶知秋35 分钟前
【Redis存储】List列表
数据库·redis·缓存
爆更小哇3 小时前
MyBatis的TypeHandler :优雅地实现数据加密与解密
数据库·后端·mybatis
likuolei3 小时前
Eclipse 创建 Java 接口
java·数据库·eclipse
w***15313 小时前
Spring boot启动原理及相关组件
数据库·spring boot·后端
q***65694 小时前
PostgreSQL 17 发布了!非常稳定的版本
数据库·postgresql
云飞云共享云桌面4 小时前
如何降低非标自动化工厂的研发软件采购成本
运维·服务器·网络·数据库·性能优化·自动化
泰克教育官方账号4 小时前
泰涨知识 | 什么是自动化巡检?
运维·服务器·数据库
oneslide4 小时前
分享一个MySQL数据库备份恢复脚本--II
数据库·mysql
Gauss松鼠会4 小时前
【GaussDB】使用DBLINK连接到ORACLE
数据库·sql·database·gaussdb
Arva .5 小时前
深度分页、读写分离、分库分表后 SQL 该如何优化?
数据库·sql