Coze智能体开发实战-单Agent综合实战

添加Webhooks

第1步: 创建gitee账号,步骤省。

第2步:某仓库 - 管理 - 添加webHook

第3步:填写URL、勾选pull,不设密码

  • URL 可以是 http 或 https 协议,也支持 http + IP 地址 + 端口的格式,如 http://127.0.0.1:8080/project,但要是外网可直接访问的地址,内网地址无内网穿透则无法使用。
  • 密码 为了保证安全以及识别数据来源,建议设置一个密码,Gitee 将会在 Post 数据中携带这个密码,不设密码可以不填。

第4步:index.php源码

复制代码
<?php 
// 步骤1:检查仓库是否存在,若不存在则克隆
function cloneRepoIfNotExists($repoUrl, $localPath) {
    if (!is_dir($localPath)) { 
        $command = "git clone $repoUrl $localPath";
        exec($command, $output, $returnCode);
        if ($returnCode === 0) {
            return true;
        } else {
            echo "Failed to clone repository: " . implode("\n", $output) . "\n";
            return false;
        }
    }
    return true;
}

// 步骤2:拉取最新代码
function gitPull($localPath) {
    chdir($localPath);
    $command = "git pull";
    exec($command, $output, $returnCode);
    if ($returnCode === 0) {
        return true;
    } else {
        echo "Failed to pull the latest code: " . implode("\n", $output) . "\n";
        return false;
    }
}

// 步骤3:获取增量代码
function getIncrementlCode($oldCommit, $newCommit, $localPath) {
    chdir($localPath);
    // 执行 git diff 命令获取增量代码
    $command = "git diff $oldCommit $newCommit";
    exec($command, $output, $returnCode);
    if ($returnCode === 0) {
        // 将输出合并为一个字符串
        $incrementalCode = implode("\n", $output);
        return $incrementalCode;
    } else {
        echo "Failed to get incremental code: " . implode("\n", $output) . "\n";
        return null;
    }
}

// 步骤4:改写curl代码为PHP调用接口的方式
function callApi($incrementalCode) {
    $url = 'https://api.coze.cn/v1/workflow/run';
    $token = '你自己的coze令牌';
    $workflowId = '你自己的工作流ID';

    $data = [
        "parameters" => [
            "input" => $incrementalCode
        ],
        "workflow_id" => $workflowId
    ];

    $dataJson = json_encode($data);

    $ch = curl_init($url);
    curl_setopt($ch, CURLOPT_POST, 1);
    curl_setopt($ch, CURLOPT_POSTFIELDS, $dataJson);
    curl_setopt($ch, CURLOPT_HTTPHEADER, [
        "Authorization: Bearer $token",
        "Content-Type: application/json"
    ]);
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

    $response = curl_exec($ch);
    $httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE); // 修正:curl_getinfo 用于获取 HTTP 状态码

    curl_close($ch);

    return [
        'http_code' => $httpCode,
        'response' => $response
    ];
}

// 步骤5: 处理 Gitee Webhook请求
// 假设Gitee Webhook 发送的是JSON数据
$inputJSON = file_get_contents('php://input'); // 修正:file_get_content -> file_get_contents
$input = json_decode($inputJSON, TRUE);

// 检查是否为 push 事件
if ($input && isset($input['ref']) && isset($input['before']) && isset($input['after']) && isset($input['repository']['git_http_url'])) {
    $oldCommit = $input['before'];
    $newCommit = $input['after'];
    $repoUrl = $input['repository']['git_http_url'];
    $repoName = basename($repoUrl, '.git');
    $localRepoPath = __DIR__ . '/' . $repoName;

    // 检查并克隆仓库
    if (cloneRepoIfNotExists($repoUrl, $localRepoPath)) {
        // 执行 git pull 操作
        if (gitPull($localRepoPath)) {
            // 获取增量代码
            $incrementalCode = getIncrementlCode($oldCommit, $newCommit, $localRepoPath);

            if ($incrementalCode) {
                // 调用 API 并传递增量代码
                $result = callApi($incrementalCode);
            }
        }
    }
}

代码审查工作流

原理:提交代码后,通过Webhooks,调用工作流检查代码是否符合规范,如果不符合,推送消息给企业微信机器人。

第1步:工作空间 - 资源库 - "+资源" - 工作流

第2步:连接"大模型"

第3步:测试节点

第4步:连接"结束"节点

第5步:试运行

第6步:发布

第7步:工作空间 - 资源库 - 工作流

第8步:单击"check_python_code"名称

复制workflow_id的值,替换index.php的$workflowId的值

第9步:让外部应用访问我们的工作流

第10步:扣子API - 授权 - 个人访问令牌 - 添加新令牌

第11步:弹出对话框里,一定要复制好令牌。因为只显示一次。替换index.php里$token的值。

相关推荐
陆业聪2 分钟前
Windsurf 深度拆解:Codeium 如何用「Flow」重新定义 AI 编程体验
ide·人工智能·ai编程
AAI机器之心6 分钟前
这个RAG框架绝了:无论多少跳,LLM只调用两次,成本暴降
人工智能·python·ai·llm·agent·产品经理·rag
xixixi777778 分钟前
安全嵌入全链路:从模型训练到智能体交互,通信网络是AI安全的“地基”
人工智能·安全·ai·多模态·数据·通信·合规
递归尽头是星辰9 分钟前
Flink 四大基石:核心原理与实战速查
大数据·人工智能·flink·实时计算
1941s13 分钟前
OpenClaw 每日新玩法 | NanoClaw —— 轻量级、安全的 OpenClaw 替代方案
人工智能·安全·agent·openclaw
攻城狮7号22 分钟前
深度解析 GPT-5.4:从“聊天对话”到“原生全能数字员工”的技术演进
人工智能·openai·智能体·gpt-5.4
NAGNIP23 分钟前
一文搞懂CNN经典架构-AlexNet!
人工智能·算法
Agent产品评测局24 分钟前
企业 AI Agent 落地,如何保障数据安全与合规?——企业级智能体安全架构与合规路径深度盘点
人工智能·安全·ai·chatgpt·安全架构
Hello.Reader25 分钟前
深度学习 三次浪潮、三大驱动力与神经科学的恩怨(二)
人工智能·深度学习
ggabb31 分钟前
汉字破局:AI时代的文明反攻与英语世界的“偷师”真相
人工智能