dwclaw-cli 1.2.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/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.2.0",
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",
@@ -1,3 +0,0 @@
1
- {
2
- "jobs": []
3
- }
package/docker/.env DELETED
@@ -1,13 +0,0 @@
1
- # ====== LLM 配置(必填)======
2
- export ANTHROPIC_BASE_URL="https://api.anthropic.com"
3
- export ANTHROPIC_AUTH_TOKEN="your-api-key-here"
4
- export ANTHROPIC_MODEL="claude-sonnet-4-20250514"
5
-
6
- # Redis 存储配置
7
- export REDIS_URL="redis://localhost:6379"
8
-
9
- # ====== 阿里云 OSS 配置(按需填写)======
10
- # export OSS_ENDPOINT="oss-cn-shenzhen"
11
- # export OSS_BUCKET="your-bucket-name"
12
- # export OSS_ACCESS_KEY_ID="your-access-key-id"
13
- # export OSS_ACCESS_KEY_SECRET="your-access-key-secret"
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:
@@ -1,9 +0,0 @@
1
- {
2
- "channels": {
3
- "feishu": {
4
- "enabled": true,
5
- "appId": "cli_a9a505f4bcf81bdf",
6
- "appSecret": "ZE747VyzEYHLrkCFHnPMfeNzQL7IaeLC"
7
- }
8
- }
9
- }
@@ -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
-