dwclaw-cli 1.1.0 → 1.3.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/README.md +121 -23
- package/dist/bundle.js +50 -83
- package/dist/main.js +1 -1
- package/package.json +2 -8
- package/.claude/cron/jobs.json +0 -3
- package/docker/.env +0 -31
- package/docker/Dockerfile +0 -61
- package/docker/docker-compose.yml +0 -43
- package/docker/duclaw.json +0 -9
- package/docker/entrypoint.sh +0 -27
package/package.json
CHANGED
|
@@ -1,20 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"packageManager": "pnpm@10.10.0+sha512.d615db246fe70f25dcfea6d8d73dee782ce23e2245e3c4f6f888249fb568149318637dca73c2c5c8ef2a4ca0d5657fb9567188bfab47f566d1ee6ce987815c39",
|
|
3
3
|
"name": "dwclaw-cli",
|
|
4
|
-
"version": "1.
|
|
4
|
+
"version": "1.3.0",
|
|
5
5
|
"description": "AI Agent 管理框架 - 支持飞书 Channel、团队协作、定时任务、Web 管理界面",
|
|
6
6
|
"bin": {
|
|
7
7
|
"duclaw": "./dist/main.js"
|
|
8
8
|
},
|
|
9
9
|
"files": [
|
|
10
10
|
"dist/",
|
|
11
|
-
"skills/"
|
|
12
|
-
".claude/cron/",
|
|
13
|
-
"docker/Dockerfile",
|
|
14
|
-
"docker/docker-compose.yml",
|
|
15
|
-
"docker/entrypoint.sh",
|
|
16
|
-
"docker/duclaw.json",
|
|
17
|
-
"docker/.env"
|
|
11
|
+
"skills/"
|
|
18
12
|
],
|
|
19
13
|
"scripts": {
|
|
20
14
|
"start": "npx tsx src/main.ts",
|
package/.claude/cron/jobs.json
DELETED
package/docker/.env
DELETED
|
@@ -1,31 +0,0 @@
|
|
|
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"
|
package/docker/Dockerfile
DELETED
|
@@ -1,61 +0,0 @@
|
|
|
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 duclaw.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"]
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
# ============================================================
|
|
2
|
-
# 使用方法:
|
|
3
|
-
# 1. 将 duclaw.tar.gz 加载到 Docker:
|
|
4
|
-
# docker load < duclaw.tar.gz
|
|
5
|
-
# 2. 在本目录下创建以下文件:
|
|
6
|
-
# - .env (环境变量,见下方说明)
|
|
7
|
-
# - duclaw.json (Agent 配置文件)
|
|
8
|
-
# 3. 启动:docker compose up -d
|
|
9
|
-
# ============================================================
|
|
10
|
-
|
|
11
|
-
services:
|
|
12
|
-
agent:
|
|
13
|
-
image: duclaw
|
|
14
|
-
container_name: duclaw
|
|
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
|
-
- ./duclaw.json:/app/duclaw.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:
|
package/docker/duclaw.json
DELETED
package/docker/entrypoint.sh
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
#!/usr/bin/env bash
|
|
2
|
-
set -euo pipefail
|
|
3
|
-
|
|
4
|
-
# ============================================================
|
|
5
|
-
# duclaw 容器入口脚本
|
|
6
|
-
# ============================================================
|
|
7
|
-
|
|
8
|
-
echo "=========================================="
|
|
9
|
-
echo " duclaw (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
|
-
|