当前位置: 首页 > news >正文

分享一个实验性的 DAG 流程审计 Skill

背景

随着 AI 能力的不断提升,AI 在代码审计领域已经有了一席之地。我也尝试过去设计不同方法论的审计 skill 去让大模型从不同的角度对代码进行审计,但之前的审计流程编排大多都是串联的,或者说是大阶段串联,每个阶段内部并联执行。这种编排方式也有一定的局限性,当你想设计更为灵活和复杂的流程时,流程梳理起来会变得“糊成一团”,且容易发生耦合的情况。因为每个环节通过文本内容指向下一个环节,在不断迭代的过程中由于缺乏框架性的设计而变得难以梳理。所以,就抱着“能不能做一个调理清晰的执行流程”这个想法,尝试性地用 DAG (有向无环图)的形式构造了一个简单的审计 Skill。

项目地址:https://github.com/ACaiSec/acai-dag-auditor

项目介绍

目前项目的内容只是为了展示架构的使用,所以比较简单,一共 5 个 node:

  1. env_setup:根据开发框架下载依赖库,完成编译
  2. project_parsing:根据编译内容以及合约代码对项目的函数调用与业务流程进行解析与总结
  3. business_flow_analysis:分析合约项目在业务流程层面的安全问题
  4. fund_flow_analysis:分析合约在资金层面的安全问题
  5. summary_output:问题去重,确认,输出漏洞报告

其中 3 和 4 是并行执行的。

image

每个节点首先都需要在 workflow.dag.yaml 文件中进行登记(max_parallel_nodes 为最大并行数量):

version: 1
name: solidity_auditruntime:max_parallel_nodes: 2nodes:- id: env_setupmodule: nodes/env_setup- id: project_parsingmodule: nodes/project_parsing- id: fund_flow_analysismodule: nodes/fund_flow_analysis- id: business_flow_analysismodule: nodes/business_flow_analysis- id: summary_outputmodule: nodes/summary_output

为了避免 context 占用过高,每个 node 都采用 sub-agent 的形式进行调用,调用结果通过输出文件进行返回。所以每个节点之间的关系(在 DAG 中对应 edge 的概念)根据是节点间的输入输出文档进行关联,比如:Node1 的输出文档为 node1-output.md,Node2 的输入文档也是 node1-output.md,那么就认为存在一条 Node1 --> Node2 的边。

每个节点的输入输出文档定义在节点目录下的 node.yaml 文件中实现,比如
上游节点 project_parsing 的输出内容定义为

  outputs:- name: project_overviewpath: project_overview.mdformat: markdowndescription: High-level project summary, contract roles, and business flow- name: call_graphpath: call_graph.yamlformat: yamldescription: Compressed call graph per ast_compress_template.yaml- name: business_flowspath: business_flows.yamlformat: yamldescription: Structured function call chains for each business flow

而它的下游节点 business_flow_analysis 的输入定义,刚好为上游节点的输出。

artifacts:output_dir: ./acai-dag-auditor/artifacts/business_flow_analysis/inputs:- name: project_overviewsource: upstream:project_parsingpath: project_overview.mdrequired: truedescription: Project architecture, contract roles, and business flow- name: business_flowssource: upstream:project_parsingpath: business_flows.yamlrequired: truedescription: Structured function call chains for each business flow- name: call_graphsource: upstream:project_parsingpath: call_graph.yamlrequired: truedescription: Compressed call graph with function call edges and risk annotations

当上游节点执行完毕,且目录中所输出的文件满足了下游节点的输入文件要求时,Agent 将会启动 sub-agent 执行下游节点的任务。

整个项目最核心的内容就介绍完了,接下你就可以根据你自己的需求设计和添加各种节点,搭建你自己的审计流程。

后记

因为这个项目是先有一个想法,然后根据这个想法来实现的一个 demo。可能想法并不成熟,实现过程中也有很多没考虑到的地方。就当是一个积聚内心想法的分享,也非常希望大家能够交流一下看法,毕竟现在很难找到一个交流的平台和社区,长时间的闭门造车最终也只能是在不断的自我否定中止步不前。尤其是现在 AI 时代,分享自己的想法变得困难重重,初步的浅显的想法提出来好像不如 AI 生成的质量高,深刻的详细的想法提出来下一秒就会为别人的 AI 所用。然后大家都开始用 AI 生成内容了,反正质量不会太差,你嫖走得到的也是 AI 的内容,分享也渐渐的变得没意思了。

http://www.jsqmd.com/news/824927/

相关文章:

  • STM32G030F6P6驱动0.96寸TFT彩屏(ST7735S)保姆级教程:从CubeIDE配置到显示字符
  • STM32F103的PD0和PD1引脚除了当晶振,还能这么玩?一个GPIO重映射的实战案例解析
  • 2026年免费去图片水印App排行榜:一键去水印推荐工具大盘点
  • Apple Silicon Mac原生Linux游戏体验:Asahi Linux驱动突破与实战指南
  • 为防数据泄露!教你拆除2024款RAV4混动汽车调制解调器和GPS
  • 明日方舟游戏资源库:2000+高清素材的完整获取与应用指南
  • 当AI的键值记忆遇上大脑:原来我们和AI共享同一套记忆逻辑
  • 别再乱发AT指令了!SIM7600CE模块短信收发实战避坑指南(附STM32代码片段)
  • Python模糊匹配与模式匹配实战:thefuzz与fnmatch模块详解
  • 易服客工作室:谷歌算法更新与排名因素综合指南
  • 如何让GPT-3开口说话?揭秘微调技巧,打造你的专属AI模型!
  • 2026 最稳高薪副业 + 主业赛道,网络安全零基础系统学习大纲,实战项目 + 证书考取 + 求职面试一站式教程
  • Matlab S-Function Builder避坑指南:从‘pointer value’报错到成功生成DSP代码
  • ROS2实战:在Ubuntu 22.04上配置思岚A2激光雷达与Humble环境
  • OpenCore Legacy Patcher终极指南:让老Mac焕发新生的4个简单步骤
  • “这张图根本不像我们设计!”——建筑效果图AI化落地失败的7个隐藏雷区,及住建部最新BIM-AI协同验收标准解读
  • VR-Reversal终极指南:免费将3D VR视频转换为2D播放的完整方案
  • NGINX现严重堆缓冲区溢出漏洞,远程攻击者可执行代码,附受影响版本及修复方法
  • 二进制相移键控(BPSK)系统建模及误码率 - 信噪比(BER-SNR)性能基准测试研究(Matlab代码实现)
  • 明日方舟素材库:从游戏资产到创意引擎的技术解密
  • 2026年照片去水印免费app推荐|无广告手机去水印软件哪款好用?6款主流工具实测对比
  • Potrace实战指南:5分钟掌握位图转矢量的开源神器
  • 别再手动抠图了!用MATLAB实现高光谱ROI自动提取与批量校正(附完整代码)
  • 官宣!网络安全法正式实施,人才缺口 327 万,这 5 类人直接站上风口,年薪百万不是梦
  • 别再乱用电容了!从MCU电源脚到EMC,手把手教你选对电容(附选型速查表)
  • NotebookLM历史研究实战指南:5个被90%学者忽略的文献溯源技巧
  • 使用Python快速接入Taotoken实现多模型调用,只需三步配置
  • 3步轻松解锁QQ音乐加密文件:macOS用户必备的解码工具
  • 从Dev到MLOps仅需17分钟,DeepSeek大模型ArgoCD一键部署全链路,手慢无!
  • 人类不擅长做出复杂的决策。人工智能可以指出这些错误。