dwclaw-cli 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/docker/.env ADDED
@@ -0,0 +1,31 @@
1
+ # Anthropic标准的LLM配置
2
+ export ANTHROPIC_BASE_URL="https://open.bigmodel.cn/api/anthropic"
3
+ export ANTHROPIC_AUTH_TOKEN="a4fd749ac2824c55a88946fc13a50e23.VPMAm8nUNaAWWS3E"
4
+ export ANTHROPIC_MODEL="glm-5-turbo"
5
+
6
+ # export ANTHROPIC_AUTH_TOKEN="sk-ovAppXlMQPzKrZtin70GQMWU2oYhz1JosO1OuSL3XJK1p3Ch"
7
+ # export ANTHROPIC_BASE_URL="https://api.moonshot.cn/anthropic"
8
+ # export ANTHROPIC_MODEL="kimi-k2.5"
9
+
10
+ # export ANTHROPIC_AUTH_TOKEN="sk-ubieV5j9VQPKa8tmjYINBVcLpA8tGOAYcxba5xdkhbKskCW9"
11
+ # export ANTHROPIC_BASE_URL="https://llm.fastgpt.cn"
12
+ # export ANTHROPIC_MODEL="claude-opus-4-6"
13
+ # export ANTHROPIC_AUTH_STYLE="bearer"
14
+ # Redis 存储配置
15
+ export REDIS_URL="redis://localhost:6379"
16
+
17
+ # 阿里云 oss配置
18
+ export OSS_ENDPOINT="oss-cn-shenzhen" # 如果在华南1(深圳) - 可以在阿里云网页中呼出oss-ai 问这个参数具体的值
19
+ export OSS_BUCKET="duclaw"
20
+ export OSS_ACCESS_KEY_ID="LTAI5tMvohtE4QAd7jxXgNmE"
21
+ export OSS_ACCESS_KEY_SECRET="RpXIRm3UBhmqsFjc84fIm6LAiD5nYh"
22
+
23
+ # 项目中用到的路径配置
24
+ export JOB_PATH="/Users/duzicong/code/duzicong/agent-template-ts/.claude/cron/jobs.json"
25
+ export JOB_HISTORY_DIR="/Users/duzicong/code/duzicong/agent-template-ts/cron"
26
+ export APP_TEMP_DIR="/Users/duzicong/code/duzicong/agent-template-ts/data"
27
+
28
+ # 图片理解工具用的LLM配置
29
+ export TOOL_IMAGE_ANTHROPIC_AUTH_TOKEN="sk-ovAppXlMQPzKrZtin70GQMWU2oYhz1JosO1OuSL3XJK1p3Ch"
30
+ export TOOL_IMAGE_ANTHROPIC_BASE_URL="https://api.moonshot.cn/anthropic"
31
+ export TOOL_IMAGE_ANTHROPIC_MODEL="kimi-k2.5"
@@ -0,0 +1,61 @@
1
+ # ============================================================
2
+ # agent-template-ts — Docker 镜像
3
+ # 基于 Node.js 23 (Debian bookworm),保留常用 CLI 工具
4
+ # Redis 等中间件在容器外部提供,不打包在镜像内
5
+ # ============================================================
6
+
7
+ # ---------- Stage 1: 安装后端依赖 ----------
8
+ # 使用完整版 bookworm(自带 python3/make/g++),避免网络下载编译工具
9
+ FROM node:23-bookworm AS deps
10
+
11
+ # 安装 pnpm
12
+ RUN npm install -g pnpm@10.10.0
13
+
14
+ WORKDIR /app
15
+
16
+ # 先拷贝包管理文件,利用 Docker 缓存
17
+ COPY package.json pnpm-lock.yaml pnpm-workspace.yaml ./
18
+
19
+ # 安装生产依赖 + tsx(tsx 在 devDependencies 但启动需要)
20
+ RUN pnpm install --frozen-lockfile --prod && \
21
+ pnpm add -D tsx
22
+
23
+ # ---------- Stage 2: 运行时镜像 ----------
24
+ # 使用完整版 bookworm 作为运行时(自带常用 CLI 工具)
25
+ FROM node:23-bookworm AS runtime
26
+
27
+ # 安装 pnpm(运行时也需要,tsx 通过 npx 调用)
28
+ RUN npm install -g pnpm@10.10.0
29
+
30
+ # 创建应用目录
31
+ WORKDIR /app
32
+
33
+ # 从 deps 阶段拷贝 node_modules
34
+ COPY --from=deps /app/node_modules ./node_modules
35
+
36
+ # 拷贝前端构建产物(需先在本地执行 pnpm build:web)
37
+ COPY web/dist ./web/dist
38
+
39
+ # 拷贝项目源代码和配置
40
+ COPY package.json pnpm-lock.yaml agent-template.json ./
41
+ COPY src/ ./src/
42
+
43
+ # skills 目录(运行时按需挂载)
44
+ RUN mkdir -p /app/skills
45
+
46
+ # 创建运行时需要的目录
47
+ RUN mkdir -p /app/cron /app/data
48
+
49
+ # 拷贝入口脚本
50
+ COPY docker/entrypoint.sh /entrypoint.sh
51
+ RUN chmod +x /entrypoint.sh
52
+
53
+ # ── 环境变量默认值(运行时通过 docker-compose 或 -e 覆盖)──
54
+ ENV NODE_ENV=production
55
+ ENV JOB_PATH=/app/data/jobs.json
56
+ ENV JOB_HISTORY_DIR=/app/cron
57
+
58
+ EXPOSE 3000
59
+
60
+ ENTRYPOINT ["/entrypoint.sh"]
61
+ CMD ["pnpm", "start"]
@@ -0,0 +1,9 @@
1
+ {
2
+ "channels": {
3
+ "feishu": {
4
+ "enabled": true,
5
+ "appId": "cli_a9a505f4bcf81bdf",
6
+ "appSecret": "ZE747VyzEYHLrkCFHnPMfeNzQL7IaeLC"
7
+ }
8
+ }
9
+ }
@@ -0,0 +1,43 @@
1
+ # ============================================================
2
+ # 使用方法:
3
+ # 1. 将 agent-template-ts.tar.gz 加载到 Docker:
4
+ # docker load < agent-template-ts.tar.gz
5
+ # 2. 在本目录下创建以下文件:
6
+ # - .env (环境变量,见下方说明)
7
+ # - agent-template.json (Agent 配置文件)
8
+ # 3. 启动:docker compose up -d
9
+ # ============================================================
10
+
11
+ services:
12
+ agent:
13
+ image: agent-template-ts
14
+ container_name: agent-template-ts
15
+ restart: unless-stopped
16
+
17
+ # ── 环境变量 ──
18
+ env_file:
19
+ - .env
20
+ environment:
21
+ - NODE_ENV=production
22
+ - REDIS_URL=redis://host.docker.internal:6379
23
+ - JOB_PATH=/app/data/jobs.json
24
+ - JOB_HISTORY_DIR=/app/cron
25
+
26
+ # ── 挂载配置文件 & 持久化数据 ──
27
+ volumes:
28
+ # Agent 配置文件(必须)
29
+ - ./agent-template.json:/app/agent-template.json:ro
30
+ # 持久化数据
31
+ - agent-data:/app/data
32
+ - agent-cron:/app/cron
33
+
34
+ # ── 网络 ──
35
+ extra_hosts:
36
+ - "host.docker.internal:host-gateway"
37
+
38
+ ports:
39
+ - "3000:3000"
40
+
41
+ volumes:
42
+ agent-data:
43
+ agent-cron:
@@ -0,0 +1,27 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+
4
+ # ============================================================
5
+ # agent-template-ts 容器入口脚本
6
+ # ============================================================
7
+
8
+ echo "=========================================="
9
+ echo " agent-template-ts (Docker)"
10
+ echo " Node $(node --version) | pnpm $(pnpm --version)"
11
+ echo " ENV: ${NODE_ENV:-production}"
12
+ echo "=========================================="
13
+
14
+ # 确保运行时目录存在
15
+ mkdir -p "${JOB_HISTORY_DIR:-/app/cron}"
16
+
17
+ # 如果 JOB_PATH 指定的文件不存在,初始化一个空数组
18
+ JOB_FILE="${JOB_PATH:-/app/data/jobs.json}"
19
+ if [ ! -f "$JOB_FILE" ]; then
20
+ mkdir -p "$(dirname "$JOB_FILE")"
21
+ echo '[]' > "$JOB_FILE"
22
+ echo "[entrypoint] 初始化 jobs 文件: $JOB_FILE"
23
+ fi
24
+
25
+ # 执行传入的命令(默认 pnpm start)
26
+ exec "$@"
27
+
package/package.json ADDED
@@ -0,0 +1,53 @@
1
+ {
2
+ "packageManager": "pnpm@10.10.0+sha512.d615db246fe70f25dcfea6d8d73dee782ce23e2245e3c4f6f888249fb568149318637dca73c2c5c8ef2a4ca0d5657fb9567188bfab47f566d1ee6ce987815c39",
3
+ "name": "dwclaw-cli",
4
+ "version": "1.0.0",
5
+ "description": "AI Agent 管理框架 - 支持飞书 Channel、团队协作、定时任务、Web 管理界面",
6
+ "bin": {
7
+ "duclaw": "./dist/main.js"
8
+ },
9
+ "files": [
10
+ "dist/",
11
+ "skills/",
12
+ ".claude/cron/",
13
+ "docker/Dockerfile",
14
+ "docker/docker-compose.yml",
15
+ "docker/entrypoint.sh",
16
+ "docker/agent-template.json",
17
+ "docker/.env"
18
+ ],
19
+ "scripts": {
20
+ "start": "npx tsx src/main.ts",
21
+ "dev:web": "cd web && pnpm dev",
22
+ "build": "node build.js",
23
+ "build:tsc": "tsc",
24
+ "build:web": "cd web && pnpm build",
25
+ "build:all": "pnpm build:web && pnpm build"
26
+ },
27
+ "dependencies": {
28
+ "@anthropic-ai/sdk": "^0.78.0",
29
+ "@hono/node-server": "^1.19.11",
30
+ "@larksuiteoapi/node-sdk": "^1.59.0",
31
+ "ali-oss": "^6.23.0",
32
+ "better-sqlite3": "^12.8.0",
33
+ "chokidar": "^5.0.0",
34
+ "dayjs": "^1.11.20",
35
+ "diff": "^8.0.3",
36
+ "dotenv": "^17.3.1",
37
+ "hono": "^4.12.9",
38
+ "node-cron": "^4.2.1",
39
+ "redis": "^5.11.0"
40
+ },
41
+ "devDependencies": {
42
+ "@types/ali-oss": "^6.23.3",
43
+ "@types/better-sqlite3": "^7.6.13",
44
+ "@types/diff": "^8.0.0",
45
+ "@types/node": "^25.3.3",
46
+ "@types/node-cron": "^3.0.11",
47
+ "esbuild": "^0.27.5",
48
+ "javascript-obfuscator": "^5.4.1",
49
+ "tsx": "^4.21.0",
50
+ "typescript": "^5.9.3",
51
+ "vitest": "^4.0.18"
52
+ }
53
+ }
@@ -0,0 +1,11 @@
1
+ {
2
+ "version": 1,
3
+ "skills": {
4
+ "github-api": {
5
+ "name": "GitHub",
6
+ "zip_url": "https://lightmake.site/api/v1/download?slug=github-api",
7
+ "source": "skillhub",
8
+ "version": "1.0.3"
9
+ }
10
+ }
11
+ }
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2026 Maton
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.