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 复制代码
<?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的值。

相关推荐
吾鳴15 小时前
扣子(Coze)实战:一键生成电影推荐爆款图文,影视博主都在偷偷使用!
coze
吾鳴18 小时前
扣子(Coze)实战:0元观影自由!这套“免费看电影看剧”工作流,才是真·薅羊毛王者!
coze
Ronky1 天前
绿联NAS+Coze实现私有AI Agent+RAG自由,打造本地化智能知识引擎
人工智能·coze
吾鳴3 天前
扣子(Coze)实战:输入自媒体赛道=自动生成运营策略图文笔记!
coze
程序员柒叔3 天前
Coze Studio概览(五)--工作流管理
工作流·coze
程序员安仔4 天前
保姆级教程!字节全家桶秒搭扣子开源版,附赠实用 AI 智能体开发实战
coze
葫芦和十三4 天前
解构 Coze Studio:DDD 与整洁架构的 Go 语言最佳实践
后端·领域驱动设计·coze
十盒半价4 天前
React 牵手 Coze 工作流:打造高效开发魔法
react.js·coze·trae
Stara05115 天前
基于Coze平台的自动化情报采集与处理引擎—实现小红书图文到飞书的端到端同步
人工智能·大模型·ocr·飞书·工作流·ai agent·coze
后端小肥肠5 天前
1 分钟出 10w + 职场漫画!Coze 一键生成,小白也能轻松拿捏
人工智能·aigc·coze