V3.5 修复SFTPGo reset password

This commit is contained in:
yuyr 2026-01-04 17:29:45 +08:00
parent 054ed3612d
commit 70f52a907b
4 changed files with 26 additions and 10 deletions

View File

@ -41,10 +41,14 @@ data:
# SFTPGo is optional in dev; when enabled, admin endpoints will call SFTPGo admin API. # SFTPGo is optional in dev; when enabled, admin endpoints will call SFTPGo admin API.
# Admin password is provided by env var `data.sftpgo.admin_password_env`. # Admin password is provided by env var `data.sftpgo.admin_password_env`.
sftpgo: sftpgo:
enabled: false enabled: true
host: "" # shown to users via GET /api/v2/me host: "" # shown to users via GET /api/v2/me
sftp_port: 2022 sftp_port: 2022
admin_api_base: "" # e.g. http://argus-sftpgo:8080 # NOTE: the Ray head container image sometimes fails to resolve docker-internal DNS names
# (e.g. sftpgo/argus-sftpgo). Use the docker bridge gateway + published port for stability.
# - host port 8081 -> sftpgo container 8080
# - 172.22.0.1 is the gateway of `mvp_argus-ray-net` in the dev compose
admin_api_base: "http://172.22.0.1:8081/api/v2" # head 容器内访问 SFTPGo admin API
admin_user: "admin" admin_user: "admin"
admin_password_env: "SFTPGO_ADMIN_PASSWORD" admin_password_env: "SFTPGO_ADMIN_PASSWORD"

View File

@ -32,6 +32,9 @@ services:
ARGUS_SHARED_ROOT: "/private" ARGUS_SHARED_ROOT: "/private"
ARGUS_CLUSTER_NAME: "argus-ray" ARGUS_CLUSTER_NAME: "argus-ray"
ARGUS_LOG_DIR: "/private/common/logs" ARGUS_LOG_DIR: "/private/common/logs"
# Make SFTPGo admin password available to API server started via `docker exec`.
# Keep it consistent with the sftpgo container default below.
SFTPGO_ADMIN_PASSWORD: "${SFTPGO_ADMIN_PASSWORD:-my-dev-sftpgo-admin}"
HF_HOME: "/private/hf" HF_HOME: "/private/hf"
HUGGINGFACE_HUB_CACHE: "/private/hf/hub" HUGGINGFACE_HUB_CACHE: "/private/hf/hub"
TRANSFORMERS_CACHE: "/private/hf/transformers" TRANSFORMERS_CACHE: "/private/hf/transformers"
@ -54,7 +57,10 @@ services:
- ../../shared:/private - ../../shared:/private
- ../../shared/common/sftpgo:/var/lib/sftpgo - ../../shared/common/sftpgo:/var/lib/sftpgo
networks: networks:
- argus-ray-net argus-ray-net:
aliases:
- sftpgo
- argus-sftpgo
environment: environment:
# Create a default admin on first start (used by API server to manage users). # Create a default admin on first start (used by API server to manage users).
# Override on host as needed: # Override on host as needed:

View File

@ -125,8 +125,13 @@ class SFTPGoAdminClient:
perms = dict(user_payload.get("permissions") or {"/": ["*"]}) perms = dict(user_payload.get("permissions") or {"/": ["*"]})
# Ensure /common is visible as a directory and can be traversed. # Ensure /common is visible as a directory and can be traversed.
perms["/common"] = ["list"] perms["/common"] = ["list"]
perms["/common/datasets"] = ["list", "download"] # SFTPGo permissions are path-scoped. In practice, granting on the directory itself may
perms["/common/hf"] = ["list", "download"] # not always cover nested paths depending on client/API behavior, so include common
# wildcard forms to ensure users can read files under these virtual folders.
perms["/common/datasets"] = ["list"]
perms["/common/datasets/*"] = ["list", "download"]
perms["/common/hf"] = ["list"]
perms["/common/hf/*"] = ["list", "download"]
user_payload["permissions"] = perms user_payload["permissions"] = perms
desired_vf = [ desired_vf = [
@ -157,8 +162,10 @@ class SFTPGoAdminClient:
"permissions": { "permissions": {
"/": ["*"], "/": ["*"],
"/common": ["list"], "/common": ["list"],
"/common/datasets": ["list", "download"], "/common/datasets": ["list"],
"/common/hf": ["list", "download"], "/common/datasets/*": ["list", "download"],
"/common/hf": ["list"],
"/common/hf/*": ["list", "download"],
}, },
"virtual_folders": [ "virtual_folders": [
{"name": "common_datasets", "virtual_path": "/common/datasets"}, {"name": "common_datasets", "virtual_path": "/common/datasets"},

View File

@ -23,9 +23,8 @@ if [[ -z "${MVP_INTERNAL_TOKEN:-}" ]]; then
fi fi
env_args=(-e "MVP_INTERNAL_TOKEN=${MVP_INTERNAL_TOKEN}") env_args=(-e "MVP_INTERNAL_TOKEN=${MVP_INTERNAL_TOKEN}")
if [[ -n "${SFTPGO_ADMIN_PASSWORD:-}" ]]; then # If host does not provide it, fall back to the dev default used by docker-compose (kept in sync).
env_args+=(-e "SFTPGO_ADMIN_PASSWORD=${SFTPGO_ADMIN_PASSWORD}") env_args+=(-e "SFTPGO_ADMIN_PASSWORD=${SFTPGO_ADMIN_PASSWORD:-my-dev-sftpgo-admin}")
fi
docker exec -d "${env_args[@]}" "${HEAD_CONTAINER}" bash -lc "nohup python3 /workspace/mvp/py/server.py --config '${CONFIG_IN_CONTAINER}' >>'${LOG_PATH}' 2>&1 & echo \$! >'${PID_PATH}'" docker exec -d "${env_args[@]}" "${HEAD_CONTAINER}" bash -lc "nohup python3 /workspace/mvp/py/server.py --config '${CONFIG_IN_CONTAINER}' >>'${LOG_PATH}' 2>&1 & echo \$! >'${PID_PATH}'"