wuran commited on
Commit
67bfca0
·
verified ·
1 Parent(s): de946cf

Update sync_data.sh

Browse files
Files changed (1) hide show
  1. sync_data.sh +93 -379
sync_data.sh CHANGED
@@ -1,22 +1,17 @@
1
  #!/bin/bash
2
 
3
- # 检查必要的环境变量
4
- if [ -z "$G_NAME" ] || [ -z "$G_TOKEN" ]; then
5
- echo "缺少必要的环境变量 G_NAMEG_TOKEN"
6
  exit 1
7
  fi
8
 
9
- # 使用独立的工作目录,避免与配置目录冲突
10
  WORK_DIR="/tmp/mcp_sync_work"
11
- GITHUB_DATA_DIR="$WORK_DIR/github_data"
12
 
13
  # 从 WebDAV 恢复配置的函数
14
  restore_from_webdav() {
15
- if [ -z "$WEBDAV_URL" ] || [ -z "$WEBDAV_USERNAME" ] || [ -z "$WEBDAV_PASSWORD" ]; then
16
- echo "WebDAV 环境变量缺失,无法从 WebDAV 恢复。"
17
- return 1
18
- fi
19
-
20
  echo "正在从 WebDAV 恢复配置文件..."
21
 
22
  # 创建临时恢复目录
@@ -26,7 +21,7 @@ restore_from_webdav() {
26
  # 获取WebDAV上所有备份文件列表
27
  echo "获取 WebDAV 备份文件列表..."
28
 
29
- # 尝试使用PROPFIND方法获取目录列表(WebDAV标准方法)
30
  RAW_RESPONSE=$(curl -s -X PROPFIND \
31
  --user "$WEBDAV_USERNAME:$WEBDAV_PASSWORD" \
32
  -H "Depth: 1" \
@@ -40,13 +35,8 @@ restore_from_webdav() {
40
  fi
41
 
42
  # 多种匹配方式
43
- # 方式1: 从XML响应中提取文件名
44
  BACKUP_LIST1=$(echo "$RAW_RESPONSE" | grep -oE '<D:displayname[^>]*>[^<]*mcp_backup_[0-9]+_[0-9]+\.tar\.gz[^<]*</D:displayname>' | sed 's/<[^>]*>//g')
45
-
46
- # 方式2: 从href属性中提取
47
  BACKUP_LIST2=$(echo "$RAW_RESPONSE" | grep -oE 'href="[^"]*mcp_backup_[0-9]+_[0-9]+\.tar\.gz[^"]*"' | sed 's/.*href="[^"]*\///g' | sed 's/".*//g')
48
-
49
- # 方式3: 简单文本匹配
50
  BACKUP_LIST3=$(echo "$RAW_RESPONSE" | grep -oE 'mcp_backup_[0-9]+_[0-9]+\.tar\.gz')
51
 
52
  # 合并所有结果
@@ -143,203 +133,82 @@ restore_from_webdav() {
143
  return 0
144
  }
145
 
146
- # 解析仓库名和用户名
147
- IFS='/' read -r GITHUB_USER GITHUB_REPO <<< "$G_NAME"
148
-
149
- # 构建 GitHub 仓库的克隆 URL,包含令牌
150
- REPO_URL="https://${G_TOKEN}@github.com/${G_NAME}.git"
151
- mkdir -p "$GITHUB_DATA_DIR"
152
-
153
- # 克隆仓库
154
- echo "正在克隆仓库到 $GITHUB_DATA_DIR ……"
155
- git clone "$REPO_URL" "$GITHUB_DATA_DIR" || {
156
- echo "克隆失败,请检查 G_NAME 和 G_TOKEN 是否正确。"
157
- exit 1
158
- }
159
-
160
- # 检查命令行参数,支持选择恢复源
161
- RESTORE_SOURCE="auto" # 默认自动选择
162
- if [ "$1" = "--restore-webdav" ]; then
163
- RESTORE_SOURCE="webdav"
164
- elif [ "$1" = "--restore-github" ]; then
165
- RESTORE_SOURCE="github"
166
- elif [ "$1" = "--restore-only" ]; then
167
- RESTORE_SOURCE="$2"
168
- if [ "$RESTORE_SOURCE" = "webdav" ]; then
169
- restore_from_webdav
170
- exit 0
171
- elif [ "$RESTORE_SOURCE" = "github" ]; then
172
- RESTORE_SOURCE="github"
173
- else
174
- echo "用法: $0 --restore-only [github|webdav]"
175
- exit 1
176
- fi
177
- fi
178
-
179
- # 恢复逻辑
180
- if [ "$RESTORE_SOURCE" = "webdav" ]; then
181
- # 仅从 WebDAV 恢复
182
  restore_from_webdav
183
- elif [ "$RESTORE_SOURCE" = "github" ] || [ "$RESTORE_SOURCE" = "auto" ]; then
184
- # 从 GitHub 恢复(根据环境变量决定是否包含tools)
185
- GITHUB_RESTORED=0
186
- GITHUB_TOOLS_RESTORED=0
187
-
188
- if [ "$GITHUB_BACKUP_TOOLS" = "true" ]; then
189
- echo "从 GitHub 恢复配置(config 和 tools 目录)..."
190
- else
191
- echo "从 GitHub 恢复配置(仅 config 目录)..."
192
- fi
193
-
194
- # 检查并恢复 config 目录
195
- if [ -d "$GITHUB_DATA_DIR/config" ] && [ "$(ls -A $GITHUB_DATA_DIR/config 2>/dev/null)" ]; then
196
- echo "从 GitHub 恢复 config 目录..."
197
- mkdir -p /mcp-proxy-server/config
198
- cp -r "$GITHUB_DATA_DIR/config"/* /mcp-proxy-server/config/
199
- echo "GitHub: config 目录恢复成功"
200
- GITHUB_RESTORED=1
201
- else
202
- echo "GitHub 仓库中没有 config 目录或目录为空"
203
- fi
204
-
205
- # 检查并恢复 tools 目录(仅当环境变量允许时)
206
- if [ "$GITHUB_BACKUP_TOOLS" = "true" ]; then
207
- if [ -d "$GITHUB_DATA_DIR/tools" ] && [ "$(ls -A $GITHUB_DATA_DIR/tools 2>/dev/null)" ]; then
208
- echo "从 GitHub 恢复 tools 目录..."
209
- mkdir -p /tools
210
- cp -r "$GITHUB_DATA_DIR/tools"/* /tools/
211
- echo "GitHub: tools 目录恢复成功"
212
- GITHUB_TOOLS_RESTORED=1
213
- else
214
- echo "GitHub 仓库中没有 tools 目录或目录为空"
215
- fi
216
- else
217
- echo "跳过 tools 目录恢复(由 GITHUB_BACKUP_TOOLS=false 控制)"
218
- # 当 GITHUB_BACKUP_TOOLS=false 时,强制从 WebDAV 恢复 tools
219
- GITHUB_TOOLS_RESTORED=0
220
- fi
221
-
222
- # auto 模式的补充恢复逻辑
223
- if [ "$RESTORE_SOURCE" = "auto" ]; then
224
- if [ "$GITHUB_RESTORED" = "0" ]; then
225
- # GitHub完全没有恢复任何内容,尝试完整WebDAV恢复
226
- echo "GitHub 中没有找到任何配置,尝试从 WebDAV 恢复..."
227
- restore_from_webdav || echo "WebDAV 恢复失败,将在同步时重新备份"
228
- elif [ "$GITHUB_TOOLS_RESTORED" = "0" ]; then
229
- # GitHub恢复了config但没有tools,或者禁用了GitHub tools备份,从WebDAV恢复tools
230
- if [ "$GITHUB_BACKUP_TOOLS" = "false" ]; then
231
- echo "GitHub tools 备份已禁用,从 WebDAV 恢复 tools 目录..."
232
- else
233
- echo "GitHub 中没有 tools 目录,尝试从 WebDAV 补充恢复..."
234
- fi
235
- restore_from_webdav || echo "WebDAV 恢复失败"
236
- fi
237
- elif [ "$GITHUB_RESTORED" = "1" ]; then
238
- echo "从 GitHub 恢复配置完成"
239
- else
240
- echo "GitHub 中没有可恢复的配置"
241
- fi
242
  fi
243
 
 
 
 
244
  # 如果是仅恢复模式,则退出
245
  if [ "$1" = "--restore-only" ]; then
246
  exit 0
247
  fi
248
 
249
- # 定义同步函数
250
  sync_data() {
 
 
 
 
 
251
  while true; do
252
- # 1. 同步到 GitHub
253
- echo "正在开始同步"
254
- # 进入仓库目录
255
- cd "$GITHUB_DATA_DIR"
256
- # 配置 Git 用户信息
257
- git config user.name "AutoSync Bot"
258
- git config user.email "[email protected]"
259
-
260
- # 确保在正确的分支
261
- git checkout main || git checkout master
262
-
263
- # 复制最新的配置文件
264
- GITHUB_BACKUP_TOOLS=${GITHUB_BACKUP_TOOLS:-true}
265
 
266
- if [ "$GITHUB_BACKUP_TOOLS" = "true" ]; then
267
- echo "检查配置文件变化(GitHub 备份 config 和 tools 目录)..."
268
- else
269
- echo "检查配置文件变化(GitHub 仅备份 config 目录)..."
270
- fi
271
-
272
- # 先从GitHub拉取最新状态,实现双向同步
273
- echo "从 GitHub 拉取最新状态..."
274
- git fetch origin
275
-
276
- # 检查是否有远程更新
277
- LOCAL_COMMIT=$(git rev-parse HEAD)
278
- REMOTE_COMMIT=$(git rev-parse origin/$(git branch --show-current))
279
 
280
- if [ "$LOCAL_COMMIT" != "$REMOTE_COMMIT" ]; then
281
- echo "检测到 GitHub 有更新,正在同步..."
 
 
 
282
 
283
- # 保存本地文件状态
284
- TEMP_BACKUP_DIR="$WORK_DIR/local_backup"
285
- rm -rf "$TEMP_BACKUP_DIR"
286
- mkdir -p "$TEMP_BACKUP_DIR"
287
 
288
- # 备份本地的config和tools到临时目录
289
- if [ -d "/mcp-proxy-server/config" ]; then
290
- cp -r "/mcp-proxy-server/config" "$TEMP_BACKUP_DIR/" 2>/dev/null || true
291
- fi
292
- if [ -d "/tools" ] && [ "$GITHUB_BACKUP_TOOLS" = "true" ]; then
293
- cp -r "/tools" "$TEMP_BACKUP_DIR/" 2>/dev/null || true
294
  fi
 
 
 
 
 
 
 
295
 
296
- # 执行硬重置到远程状态
297
- git reset --hard origin/$(git branch --show-current)
298
 
299
- # 从GitHub更新本地文件
300
- if [ -d "./config" ] && [ "$(ls -A ./config 2>/dev/null)" ]; then
301
- echo " GitHub 更新 config 目录..."
302
- mkdir -p /mcp-proxy-server/config
303
- cp -r ./config/* /mcp-proxy-server/config/
304
- else
305
- # 如果GitHub中没有config目录,清空本地config
306
- echo "GitHub 中没有 config 目录,清空本地 config..."
307
- rm -rf /mcp-proxy-server/config/*
308
  fi
 
 
 
 
 
309
 
310
- # 根据GITHUB_BACKUP_TOOLS设置处理tools目录
311
- if [ "$GITHUB_BACKUP_TOOLS" = "true" ]; then
312
- if [ -d "./tools" ] && [ "$(ls -A ./tools 2>/dev/null)" ]; then
313
- echo "从 GitHub 更新 tools 目录..."
314
- mkdir -p /tools
315
- rm -rf /tools/* # 清空现有tools
316
- cp -r ./tools/* /tools/
317
- else
318
- # 如果GitHub中没有tools目录,清空本地tools
319
- echo "GitHub 中没有 tools 目录,清空本地 tools..."
320
- rm -rf /tools/*
321
- fi
322
- else
323
- # 如果禁用了GitHub tools备份,从WebDAV恢复tools
324
- echo "GitHub tools 备份已禁用,从 WebDAV 恢复 tools 目录..."
325
- restore_from_webdav || echo "WebDAV 恢复失败"
326
- fi
327
 
328
- echo "GitHub 同步完成"
 
 
 
329
 
330
- # 清理临时备份
331
- rm -rf "$TEMP_BACKUP_DIR"
332
- else
333
- echo "GitHub 状态已是最新"
334
- fi
335
-
336
- # 同步 config 目录到 GitHub
337
- if [ -d "/mcp-proxy-server/config" ]; then
338
- # 检查是否有非工作目录的文件
339
- CONFIG_FILES=$(ls -A /mcp-proxy-server/config 2>/dev/null | grep -v -E '(github_data|temp_backup|webdav_restore)' || true)
340
 
341
- if [ -n "$CONFIG_FILES" ]; then
342
- # 使用 cp 代替 rsync,逐步复制,排除工作目录
 
343
  for item in /mcp-proxy-server/config/*; do
344
  if [ -e "$item" ]; then
345
  BASENAME=$(basename "$item")
@@ -348,219 +217,64 @@ sync_data() {
348
  ;;
349
  *)
350
  if [ -d "$item" ]; then
351
- cp -r "$item" ./config/ 2>/dev/null
352
  else
353
- cp "$item" ./config/ 2>/dev/null
354
  fi
355
  ;;
356
  esac
357
  fi
358
  done
359
  fi
360
- fi
361
-
362
- # 同步 tools 目录到 GitHub(处理多个MCP仓库)
363
- if [ "$GITHUB_BACKUP_TOOLS" = "true" ] && [ -d "/tools" ] && [ "$(ls -A /tools 2>/dev/null)" ]; then
364
- # 清空目标目录
365
- rm -rf ./tools/*
366
-
367
- echo "处理 tools 目录中的 MCP 工具..."
368
-
369
- PROCESSED_COUNT=0
370
 
371
- # 逐个处理 tools 目录下的MCP工具
372
- for item in /tools/*; do
373
- if [ -e "$item" ]; then
374
- BASENAME=$(basename "$item")
375
-
376
- if [ -d "$item" ]; then
377
- echo " 处理 MCP 工具: $BASENAME"
378
-
379
- # 检查是否是Git仓库
380
- if [ -d "$item/.git" ]; then
381
- echo " 检测到Git仓库,排除.git目录"
382
- fi
383
-
384
- # 创建目标目录
385
- mkdir -p "./tools/$BASENAME"
386
-
387
- # 复制目录内容
388
- if [ "$(ls -A "$item" 2>/dev/null)" ]; then
389
- # 复制所有普通文件和目录(排除.git)
390
- for subitem in "$item"/*; do
391
- if [ -e "$subitem" ] && [ "$(basename "$subitem")" != ".git" ]; then
392
- cp -r "$subitem" "./tools/$BASENAME/" 2>/dev/null || true
393
- fi
394
- done
395
-
396
- # 复制隐藏文件,但排除 .git 目录
397
- for hidden in "$item"/.[!.]*; do
398
- if [ -e "$hidden" ] && [ "$(basename "$hidden")" != ".git" ]; then
399
- cp -r "$hidden" "./tools/$BASENAME/" 2>/dev/null || true
400
- fi
401
- done
402
-
403
- # 检查复制结果
404
- COPIED_FILES=$(ls -A "./tools/$BASENAME" 2>/dev/null | wc -l)
405
- echo " → 已复制 $COPIED_FILES 个文件/目录"
406
  else
407
- # 空目录创建 .gitkeep
408
- touch "./tools/$BASENAME/.gitkeep"
409
- echo " → 空目录,已创建 .gitkeep"
410
  fi
411
-
412
- PROCESSED_COUNT=$((PROCESSED_COUNT + 1))
413
- else
414
- # 直接复制文件
415
- echo " 复制文件: $BASENAME"
416
- cp "$item" "./tools/" 2>/dev/null || true
417
- PROCESSED_COUNT=$((PROCESSED_COUNT + 1))
418
  fi
419
- fi
420
- done
421
-
422
- # 显示处理结果摘要
423
- if [ "$PROCESSED_COUNT" -gt 0 ]; then
424
- echo "总计处理 $PROCESSED_COUNT 个 MCP 工具"
425
- fi
426
- elif [ "$GITHUB_BACKUP_TOOLS" = "false" ]; then
427
- echo "跳过 tools 目录(由 GITHUB_BACKUP_TOOLS=false 控制)"
428
- fi
429
-
430
- # 检查是否有变化
431
- CONFIG_CHANGED=0
432
- TOOLS_CHANGED=0
433
-
434
- # 检查 config 目录变化(用于 GitHub 备份)
435
- if [[ -n $(git status -s) ]]; then
436
- CONFIG_CHANGED=1
437
- fi
438
-
439
- # 检查 tools 目录变化(用于 WebDAV 备份)
440
- TOOLS_LAST_CHECK_FILE="$WORK_DIR/tools_last_check"
441
- if [ -d "/tools" ] && [ "$(ls -A /tools 2>/dev/null)" ]; then
442
- # 获取 tools 目录的最新修改时间
443
- CURRENT_TOOLS_TIME=$(find /tools -type f -exec stat -c %Y {} \; 2>/dev/null | sort -n | tail -1)
444
-
445
- if [ -f "$TOOLS_LAST_CHECK_FILE" ]; then
446
- LAST_TOOLS_TIME=$(cat "$TOOLS_LAST_CHECK_FILE" 2>/dev/null || echo "0")
447
- if [ "$CURRENT_TOOLS_TIME" != "$LAST_TOOLS_TIME" ]; then
448
- TOOLS_CHANGED=1
449
- fi
450
- else
451
- TOOLS_CHANGED=1
452
- fi
453
-
454
- # 更新检查时间戳
455
- echo "$CURRENT_TOOLS_TIME" > "$TOOLS_LAST_CHECK_FILE"
456
- fi
457
-
458
- # 根据变化情况执行备份
459
- if [ "$CONFIG_CHANGED" = "1" ] || [ "$TOOLS_CHANGED" = "1" ]; then
460
- echo "检测到文件变化,开始备份..."
461
-
462
- # GitHub 备份(仅当 config 有变化时)
463
- if [ "$CONFIG_CHANGED" = "1" ]; then
464
- if [ "$GITHUB_BACKUP_TOOLS" = "true" ]; then
465
- echo "→ GitHub 备份 (config + tools)"
466
- git add config/ tools/
467
- git commit -m "Auto sync config and tools $(date '+%Y-%m-%d %H:%M:%S')"
468
- else
469
- echo "→ GitHub 备份 (config only)"
470
- git add config/
471
- git commit -m "Auto sync config $(date '+%Y-%m-%d %H:%M:%S')"
472
- fi
473
- git push origin HEAD >/dev/null 2>&1 && echo " ✓ 推送成功" || echo " ✗ 推送失败"
474
  fi
475
 
476
- # WebDAV 备份(当 config 或 tools 有变化时)
477
- if [ -z "$WEBDAV_URL" ] || [ -z "$WEBDAV_USERNAME" ] || [ -z "$WEBDAV_PASSWORD" ]; then
478
- echo " WebDAV 环境变量缺失,跳过"
479
- else
480
- echo "→ WebDAV 备份 (config + tools)"
481
- # 使用时间戳(年月日时分),每次同步都创建新备份
482
- FILENAME="mcp_backup_$(date +'%Y%m%d_%H%M').tar.gz"
483
-
484
- # 创建临时备份压缩包(使用独立目录)
485
- TEMP_DIR="$WORK_DIR/temp_backup"
486
- rm -rf "$TEMP_DIR"
487
- mkdir -p "$TEMP_DIR"
488
-
489
- # 复制要备份的目录到临时目录(WebDAV 备份包含 config 和 tools)
490
- BACKUP_CREATED=0
491
-
492
- if [ -d "/mcp-proxy-server/config" ]; then
493
- CONFIG_FILES=$(ls -A /mcp-proxy-server/config 2>/dev/null | grep -v -E '(github_data|temp_backup|webdav_restore)' || true)
494
-
495
- if [ -n "$CONFIG_FILES" ]; then
496
- mkdir -p "$TEMP_DIR/config"
497
- for item in /mcp-proxy-server/config/*; do
498
- if [ -e "$item" ]; then
499
- BASENAME=$(basename "$item")
500
- case "$BASENAME" in
501
- github_data|temp_backup|webdav_restore)
502
- ;;
503
- *)
504
- if [ -d "$item" ]; then
505
- cp -r "$item" "$TEMP_DIR/config/" 2>/dev/null && BACKUP_CREATED=1
506
- else
507
- cp "$item" "$TEMP_DIR/config/" 2>/dev/null && BACKUP_CREATED=1
508
- fi
509
- ;;
510
- esac
511
- fi
512
- done
513
- fi
514
- fi
515
 
516
- if [ -d "/tools" ] && [ "$(ls -A /tools 2>/dev/null)" ]; then
517
- mkdir -p "$TEMP_DIR/tools"
518
- for item in /tools/*; do
519
- if [ -e "$item" ]; then
520
- BASENAME=$(basename "$item")
521
- if [ -d "$item" ]; then
522
- mkdir -p "$TEMP_DIR/tools/$BASENAME"
523
- if [ "$(ls -A "$item" 2>/dev/null)" ]; then
524
- cp -r "$item"/* "$TEMP_DIR/tools/$BASENAME/" 2>/dev/null && BACKUP_CREATED=1
525
- cp -r "$item"/.[!.]* "$TEMP_DIR/tools/$BASENAME/" 2>/dev/null || true
526
- else
527
- touch "$TEMP_DIR/tools/$BASENAME/.gitkeep"
528
- BACKUP_CREATED=1
529
- fi
530
- else
531
- cp "$item" "$TEMP_DIR/tools/" 2>/dev/null && BACKUP_CREATED=1
532
- fi
533
- fi
534
- done
535
- fi
536
-
537
- # 创建压缩包
538
- if [ "$BACKUP_CREATED" = "1" ] && [ "$(ls -A $TEMP_DIR)" ]; then
539
- (cd "$TEMP_DIR" && tar -czf "../$FILENAME" .)
540
-
541
- curl -T "$WORK_DIR/$FILENAME" --user "$WEBDAV_USERNAME:$WEBDAV_PASSWORD" "$WEBDAV_URL/$FILENAME" >/dev/null 2>&1 && echo " ✓ 上传成功" || echo " ✗ 上传失败"
542
- rm -f "$WORK_DIR/$FILENAME"
543
  else
544
- echo " ✗ 无文件可备份"
545
  fi
546
-
547
- rm -rf "$TEMP_DIR"
 
548
  fi
549
 
550
- echo "备份完成"
551
-
552
  else
553
  echo "无文件变化,跳过备份"
554
  fi
555
 
556
- # 返回上级目录
557
- cd - > /dev/null
558
-
559
- # 3. 等待统一的时间间隔
560
  SYNC_INTERVAL=${SYNC_INTERVAL:-7200} # 默认间隔时间为 7200 秒
561
  echo "等待 ${SYNC_INTERVAL} 秒后进行下一次检查..."
562
  sleep $SYNC_INTERVAL
563
-
564
  done
565
  }
566
 
 
1
  #!/bin/bash
2
 
3
+ # 检查必要的WebDAV环境变量
4
+ if [ -z "$WEBDAV_URL" ] || [ -z "$WEBDAV_USERNAME" ] || [ -z "$WEBDAV_PASSWORD" ]; then
5
+ echo "缺少必要的WebDAV环境变量:WEBDAV_URL, WEBDAV_USERNAMEWEBDAV_PASSWORD"
6
  exit 1
7
  fi
8
 
9
+ # 使用独立的工作目录
10
  WORK_DIR="/tmp/mcp_sync_work"
11
+ mkdir -p "$WORK_DIR"
12
 
13
  # 从 WebDAV 恢复配置的函数
14
  restore_from_webdav() {
 
 
 
 
 
15
  echo "正在从 WebDAV 恢复配置文件..."
16
 
17
  # 创建临时恢复目录
 
21
  # 获取WebDAV上所有备份文件列表
22
  echo "获取 WebDAV 备份文件列表..."
23
 
24
+ # 尝试使用PROPFIND方法获取目录列表
25
  RAW_RESPONSE=$(curl -s -X PROPFIND \
26
  --user "$WEBDAV_USERNAME:$WEBDAV_PASSWORD" \
27
  -H "Depth: 1" \
 
35
  fi
36
 
37
  # 多种匹配方式
 
38
  BACKUP_LIST1=$(echo "$RAW_RESPONSE" | grep -oE '<D:displayname[^>]*>[^<]*mcp_backup_[0-9]+_[0-9]+\.tar\.gz[^<]*</D:displayname>' | sed 's/<[^>]*>//g')
 
 
39
  BACKUP_LIST2=$(echo "$RAW_RESPONSE" | grep -oE 'href="[^"]*mcp_backup_[0-9]+_[0-9]+\.tar\.gz[^"]*"' | sed 's/.*href="[^"]*\///g' | sed 's/".*//g')
 
 
40
  BACKUP_LIST3=$(echo "$RAW_RESPONSE" | grep -oE 'mcp_backup_[0-9]+_[0-9]+\.tar\.gz')
41
 
42
  # 合并所有结果
 
133
  return 0
134
  }
135
 
136
+ # 处理恢复参数
137
+ if [ "$1" = "--restore-only" ] && [ "$2" = "webdav" ]; then
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
138
  restore_from_webdav
139
+ exit 0
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
140
  fi
141
 
142
+ # 启动时自动从WebDAV恢复
143
+ restore_from_webdav || echo "WebDAV恢复失败,将在同步时重新备份"
144
+
145
  # 如果是仅恢复模式,则退出
146
  if [ "$1" = "--restore-only" ]; then
147
  exit 0
148
  fi
149
 
150
+ # 定义同步函数(只使用WebDAV)
151
  sync_data() {
152
+ # 初始化时间戳文件
153
+ CONFIG_LAST_CHECK_FILE="$WORK_DIR/config_last_check"
154
+ TOOLS_LAST_CHECK_FILE="$WORK_DIR/tools_last_check"
155
+ touch "$CONFIG_LAST_CHECK_FILE" "$TOOLS_LAST_CHECK_FILE"
156
+
157
  while true; do
158
+ echo "正在开始同步检查"
 
 
 
 
 
 
 
 
 
 
 
 
159
 
160
+ # 检查config和tools目录变化
161
+ CONFIG_CHANGED=0
162
+ TOOLS_CHANGED=0
 
 
 
 
 
 
 
 
 
 
163
 
164
+ # 检查config目录变化
165
+ if [ -d "/mcp-proxy-server/config" ] && [ "$(ls -A /mcp-proxy-server/config 2>/dev/null)" ]; then
166
+ # 获取config目录的最新修改时间
167
+ CURRENT_CONFIG_TIME=$(find /mcp-proxy-server/config -type f -exec stat -c %Y {} \; 2>/dev/null | sort -n | tail -1)
168
+ [ -z "$CURRENT_CONFIG_TIME" ] && CURRENT_CONFIG_TIME=0
169
 
170
+ # 获取上次记录的时间
171
+ LAST_CONFIG_TIME=$(cat "$CONFIG_LAST_CHECK_FILE" 2>/dev/null || echo 0)
 
 
172
 
173
+ if [ "$CURRENT_CONFIG_TIME" -gt "$LAST_CONFIG_TIME" ]; then
174
+ CONFIG_CHANGED=1
175
+ echo "检测到 config 目录变化"
 
 
 
176
  fi
177
+ fi
178
+
179
+ # 检查tools目录变化
180
+ if [ -d "/tools" ] && [ "$(ls -A /tools 2>/dev/null)" ]; then
181
+ # 获取tools目录的最新修改时间
182
+ CURRENT_TOOLS_TIME=$(find /tools -type f -exec stat -c %Y {} \; 2>/dev/null | sort -n | tail -1)
183
+ [ -z "$CURRENT_TOOLS_TIME" ] && CURRENT_TOOLS_TIME=0
184
 
185
+ # 获取上次记录的时间
186
+ LAST_TOOLS_TIME=$(cat "$TOOLS_LAST_CHECK_FILE" 2>/dev/null || echo 0)
187
 
188
+ if [ "$CURRENT_TOOLS_TIME" -gt "$LAST_TOOLS_TIME" ]; then
189
+ TOOLS_CHANGED=1
190
+ echo "检测到 tools 目录变化"
 
 
 
 
 
 
191
  fi
192
+ fi
193
+
194
+ # 如果有变化,执行WebDAV备份
195
+ if [ "$CONFIG_CHANGED" = "1" ] || [ "$TOOLS_CHANGED" = "1" ]; then
196
+ echo "检测到文件变化,开始WebDAV备份..."
197
 
198
+ # 使用时间戳创建备份文件名
199
+ FILENAME="mcp_backup_$(date +'%Y%m%d_%H%M').tar.gz"
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
200
 
201
+ # 创建临时备份压缩包
202
+ TEMP_DIR="$WORK_DIR/temp_backup"
203
+ rm -rf "$TEMP_DIR"
204
+ mkdir -p "$TEMP_DIR"
205
 
206
+ # 复制要备份的目录到临时目录
207
+ BACKUP_CREATED=0
 
 
 
 
 
 
 
 
208
 
209
+ # 备份config目录(排除工作目录)
210
+ if [ -d "/mcp-proxy-server/config" ] && [ "$(ls -A /mcp-proxy-server/config 2>/dev/null)" ]; then
211
+ mkdir -p "$TEMP_DIR/config"
212
  for item in /mcp-proxy-server/config/*; do
213
  if [ -e "$item" ]; then
214
  BASENAME=$(basename "$item")
 
217
  ;;
218
  *)
219
  if [ -d "$item" ]; then
220
+ cp -r "$item" "$TEMP_DIR/config/" 2>/dev/null && BACKUP_CREATED=1
221
  else
222
+ cp "$item" "$TEMP_DIR/config/" 2>/dev/null && BACKUP_CREATED=1
223
  fi
224
  ;;
225
  esac
226
  fi
227
  done
228
  fi
 
 
 
 
 
 
 
 
 
 
229
 
230
+ # 备份tools目录
231
+ if [ -d "/tools" ] && [ "$(ls -A /tools 2>/dev/null)" ]; then
232
+ mkdir -p "$TEMP_DIR/tools"
233
+ for item in /tools/*; do
234
+ if [ -e "$item" ]; then
235
+ BASENAME=$(basename "$item")
236
+ if [ -d "$item" ]; then
237
+ mkdir -p "$TEMP_DIR/tools/$BASENAME"
238
+ if [ "$(ls -A "$item" 2>/dev/null)" ]; then
239
+ cp -r "$item"/* "$TEMP_DIR/tools/$BASENAME/" 2>/dev/null && BACKUP_CREATED=1
240
+ cp -r "$item"/.[!.]* "$TEMP_DIR/tools/$BASENAME/" 2>/dev/null || true
241
+ else
242
+ touch "$TEMP_DIR/tools/$BASENAME/.gitkeep"
243
+ BACKUP_CREATED=1
244
+ fi
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
245
  else
246
+ cp "$item" "$TEMP_DIR/tools/" 2>/dev/null && BACKUP_CREATED=1
 
 
247
  fi
 
 
 
 
 
 
 
248
  fi
249
+ done
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
250
  fi
251
 
252
+ # 创建压缩包并上传
253
+ if [ "$BACKUP_CREATED" = "1" ] && [ "$(ls -A $TEMP_DIR)" ]; then
254
+ (cd "$TEMP_DIR" && tar -czf "../$FILENAME" .)
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
255
 
256
+ if curl -T "$WORK_DIR/$FILENAME" --user "$WEBDAV_USERNAME:$WEBDAV_PASSWORD" "$WEBDAV_URL/$FILENAME" >/dev/null 2>&1; then
257
+ echo "WebDAV备份上传成功: $FILENAME"
258
+ # 更新记录文件
259
+ [ "$CONFIG_CHANGED" = "1" ] && echo "$CURRENT_CONFIG_TIME" > "$CONFIG_LAST_CHECK_FILE"
260
+ [ "$TOOLS_CHANGED" = "1" ] && echo "$CURRENT_TOOLS_TIME" > "$TOOLS_LAST_CHECK_FILE"
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
261
  else
262
+ echo "WebDAV备份上传失败"
263
  fi
264
+ rm -f "$WORK_DIR/$FILENAME"
265
+ else
266
+ echo "无文件可备份"
267
  fi
268
 
269
+ rm -rf "$TEMP_DIR"
 
270
  else
271
  echo "无文件变化,跳过备份"
272
  fi
273
 
274
+ # 等待下一次检查
 
 
 
275
  SYNC_INTERVAL=${SYNC_INTERVAL:-7200} # 默认间隔时间为 7200 秒
276
  echo "等待 ${SYNC_INTERVAL} 秒后进行下一次检查..."
277
  sleep $SYNC_INTERVAL
 
278
  done
279
  }
280