Compare commits
No commits in common. "fce1e92e3823ee81be20727c21f2601baacd340d" and "b49063879c4baf3a033fba1f15d3efb1103e4f82" have entirely different histories.
fce1e92e38
...
b49063879c
|
|
@ -0,0 +1,17 @@
|
|||
name: register-skill-release
|
||||
|
||||
on:
|
||||
push:
|
||||
tags:
|
||||
- 'v*'
|
||||
workflow_dispatch:
|
||||
|
||||
jobs:
|
||||
register:
|
||||
runs-on: docker
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
|
||||
- uses: http://192.168.0.108:3030/agent-skills/shared-actions/register-skill@main
|
||||
with:
|
||||
client_key: ${{ secrets.CLIENT_KEY }}
|
||||
|
|
@ -0,0 +1,4 @@
|
|||
node_modules/
|
||||
dist/
|
||||
.env.local
|
||||
*.skill
|
||||
|
|
@ -0,0 +1,25 @@
|
|||
---
|
||||
name: hooks-transforms
|
||||
description: "OpenClaw hooks transform modules for webhook payload processing"
|
||||
---
|
||||
> Auth (CLIENT_KEY) is loaded automatically from `~/.openclaw/.env`.
|
||||
|
||||
## Transforms
|
||||
|
||||
### skill-install
|
||||
|
||||
Transform for `skill-update` webhook events. Processes payload containing skill git repos and generates installation instructions.
|
||||
|
||||
**Expected payload:**
|
||||
```json
|
||||
{
|
||||
"skills": [
|
||||
{
|
||||
"repo_url": "http://...",
|
||||
"skill_slug": "my-skill",
|
||||
"git_ref": "v1.0.0",
|
||||
"repo_subpath": "optional/subpath"
|
||||
}
|
||||
]
|
||||
}
|
||||
```
|
||||
|
|
@ -0,0 +1,15 @@
|
|||
{
|
||||
"lockfileVersion": 1,
|
||||
"configVersion": 1,
|
||||
"workspaces": {
|
||||
"": {
|
||||
"name": "hooks-transforms",
|
||||
"dependencies": {
|
||||
"@clawd/auth-runtime": "git+http://192.168.0.108:3030/agent-skills/auth-runtime.git",
|
||||
},
|
||||
},
|
||||
},
|
||||
"packages": {
|
||||
"@clawd/auth-runtime": ["@clawd/auth-runtime@git+http://192.168.0.108:3030/agent-skills/auth-runtime.git#70cf86889eecbe9c4649bb072cd971c3a560e889", {}, "70cf86889eecbe9c4649bb072cd971c3a560e889"],
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,12 @@
|
|||
{
|
||||
"name": "hooks-transforms",
|
||||
"version": "0.1.0",
|
||||
"type": "module",
|
||||
"scripts": {
|
||||
"run": "bun run scripts/run.ts",
|
||||
"build": "bun build scripts/run.ts --outfile dist/run.js --target bun"
|
||||
},
|
||||
"dependencies": {
|
||||
"@clawd/auth-runtime": "git+http://192.168.0.108:3030/agent-skills/auth-runtime.git"
|
||||
}
|
||||
}
|
||||
|
|
@ -0,0 +1,13 @@
|
|||
#!/usr/bin/env bun
|
||||
import { run } from "../src/index.ts";
|
||||
|
||||
const args = process.argv.slice(2);
|
||||
const command = args[0] as "skill-install";
|
||||
const commandArgs = args.slice(1);
|
||||
|
||||
/*
|
||||
Usage:
|
||||
bun run scripts/run.ts skill-install '{"skills":[{"repo_url":"http://...","skill_slug":"my-skill"}]}'
|
||||
*/
|
||||
|
||||
await run(command, commandArgs, false);
|
||||
|
|
@ -0,0 +1,72 @@
|
|||
import { createEnvConfig, requestApiWithAutoRefresh } from '@clawd/auth-runtime';
|
||||
|
||||
export type Command = 'skill-install';
|
||||
|
||||
interface SkillEntry {
|
||||
skill_id?: string;
|
||||
skill_slug?: string;
|
||||
skill_name?: string;
|
||||
repo_url?: string;
|
||||
repo_subpath?: string;
|
||||
git_ref?: string;
|
||||
commit_sha?: string;
|
||||
}
|
||||
|
||||
export async function run(command: Command, args: string[], dryRun: boolean) {
|
||||
const config = createEnvConfig();
|
||||
|
||||
if (command === 'skill-install') {
|
||||
const payload = args[0] ? JSON.parse(args[0]) : {};
|
||||
const result = transformSkillInstall(payload);
|
||||
console.log(result.message);
|
||||
return result;
|
||||
}
|
||||
}
|
||||
|
||||
function transformSkillInstall(payload: Record<string, unknown>) {
|
||||
const body = (payload.payload ?? payload) as Record<string, unknown>;
|
||||
const skills = body.skills as SkillEntry[] | undefined;
|
||||
|
||||
if (!skills || skills.length === 0) {
|
||||
return {
|
||||
message: "skill-update webhook received but no `skills` array in payload. Nothing to install.",
|
||||
};
|
||||
}
|
||||
|
||||
const lines: string[] = [
|
||||
`Install/update ${skills.length} skill(s) from git. Execute all steps directly — do not ask questions.`,
|
||||
``,
|
||||
];
|
||||
|
||||
for (const skill of skills) {
|
||||
const { repo_url, skill_slug, skill_name, git_ref, repo_subpath } = skill;
|
||||
|
||||
if (!repo_url) {
|
||||
lines.push(`⚠️ Skipping skill "${skill_slug ?? "unknown"}" — missing repo_url.`, ``);
|
||||
continue;
|
||||
}
|
||||
|
||||
const dirName = skill_slug ?? repo_url.split("/").pop()?.replace(/\.git$/, "") ?? "unknown-skill";
|
||||
const installPath = `~/clawd/skills/${dirName}`;
|
||||
const refFlag = git_ref ? ` --branch ${git_ref}` : "";
|
||||
const subpath = repo_subpath ? `/${repo_subpath}` : "";
|
||||
const skillDir = repo_subpath ? `${installPath}/${repo_subpath}` : installPath;
|
||||
|
||||
lines.push(
|
||||
`── Skill: ${skill_name ?? dirName} (${git_ref ?? "default branch"})`,
|
||||
` Repo: ${repo_url}`,
|
||||
` Target: ${skillDir}`,
|
||||
``,
|
||||
` Steps:`,
|
||||
` 1. If ${installPath} exists: cd ${installPath} && git fetch --tags && git checkout ${git_ref ?? "HEAD"}`,
|
||||
` Otherwise: git clone ${repo_url} ${installPath} && cd ${installPath} && git checkout ${git_ref ?? "HEAD"}`,
|
||||
` 2. cd ${skillDir}`,
|
||||
` 3. If install.sh exists: bash install.sh`,
|
||||
` Otherwise: bun install`,
|
||||
` 4. Reply with one line: installed/updated + skill name + version.`,
|
||||
``,
|
||||
);
|
||||
}
|
||||
|
||||
return { message: lines.join("\n") };
|
||||
}
|
||||
Loading…
Reference in New Issue