From d8669b90bfbdd32497ba22c9181063dbf93a6d5d Mon Sep 17 00:00:00 2001 From: ssongliu <73214554+ssongliu@users.noreply.github.com> Date: Mon, 5 Feb 2024 17:28:12 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20WebDAV=20=E6=94=AF=E6=8C=81=E8=BF=9E?= =?UTF-8?q?=E6=8E=A5=20Alist=20(#3836)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Refs #3495 --- backend/init/migration/migrate.go | 2 + backend/init/migration/migrations/v_1_9.go | 26 +++++++++ backend/utils/cloud_storage/client/webdav.go | 19 ++++--- frontend/src/lang/modules/en.ts | 1 + frontend/src/lang/modules/tw.ts | 3 +- frontend/src/lang/modules/zh.ts | 3 +- .../views/setting/backup-account/index.vue | 7 +-- .../setting/backup-account/sftp/index.vue | 2 +- .../setting/backup-account/webdav/index.vue | 55 +++++++------------ 9 files changed, 65 insertions(+), 53 deletions(-) diff --git a/backend/init/migration/migrate.go b/backend/init/migration/migrate.go index 4ccf3e5c3..faae42bfb 100644 --- a/backend/init/migration/migrate.go +++ b/backend/init/migration/migrate.go @@ -70,6 +70,8 @@ func Init() { migrations.UpdateCronjobSpec, migrations.UpdateBackupRecordPath, migrations.UpdateSnapshotRecords, + + migrations.UpdateWebDavConf, }) if err := m.Migrate(); err != nil { global.LOG.Error(err) diff --git a/backend/init/migration/migrations/v_1_9.go b/backend/init/migration/migrations/v_1_9.go index 551684811..2b78ade00 100644 --- a/backend/init/migration/migrations/v_1_9.go +++ b/backend/init/migration/migrations/v_1_9.go @@ -451,3 +451,29 @@ var UpdateSnapshotRecords = &gormigrate.Migration{ return nil }, } + +var UpdateWebDavConf = &gormigrate.Migration{ + ID: "20240205-update-webdav-conf", + Migrate: func(tx *gorm.DB) error { + var backup model.BackupAccount + _ = tx.Where("type = ?", constant.WebDAV).First(&backup).Error + if backup.ID == 0 { + return nil + } + varMap := make(map[string]interface{}) + if err := json.Unmarshal([]byte(backup.Vars), &varMap); err != nil { + return err + } + delete(varMap, "addressItem") + if port, ok := varMap["port"]; ok { + varMap["address"] = fmt.Sprintf("%s:%v", varMap["address"], port) + delete(varMap, "port") + } + + vars, _ := json.Marshal(varMap) + if err := tx.Model(&model.BackupAccount{}).Where("id = ?", backup.ID).Updates(map[string]interface{}{"vars": string(vars)}).Error; err != nil { + return err + } + return nil + }, +} diff --git a/backend/utils/cloud_storage/client/webdav.go b/backend/utils/cloud_storage/client/webdav.go index 78f4ac633..c1013357c 100644 --- a/backend/utils/cloud_storage/client/webdav.go +++ b/backend/utils/cloud_storage/client/webdav.go @@ -6,6 +6,7 @@ import ( "io" "net/http" "os" + "path" "strings" "github.com/studio-b12/gowebdav" @@ -43,7 +44,7 @@ func NewWebDAVClient(vars map[string]interface{}) (*webDAVClient, error) { } func (s webDAVClient) Upload(src, target string) (bool, error) { - targetFilePath := s.Bucket + "/" + target + targetFilePath := path.Join(s.Bucket, target) srcFile, err := os.Open(src) if err != nil { return false, err @@ -62,7 +63,7 @@ func (s webDAVClient) ListBuckets() ([]interface{}, error) { } func (s webDAVClient) Download(src, target string) (bool, error) { - srcPath := s.Bucket + "/" + src + srcPath := path.Join(s.Bucket, src) info, err := s.client.Stat(srcPath) if err != nil { return false, err @@ -85,30 +86,30 @@ func (s webDAVClient) Download(src, target string) (bool, error) { return true, err } -func (s webDAVClient) Exist(path string) (bool, error) { - if _, err := s.client.Stat(s.Bucket + "/" + path); err != nil { +func (s webDAVClient) Exist(pathItem string) (bool, error) { + if _, err := s.client.Stat(path.Join(s.Bucket, pathItem)); err != nil { return false, err } return true, nil } -func (s webDAVClient) Size(path string) (int64, error) { - file, err := s.client.Stat(s.Bucket + "/" + path) +func (s webDAVClient) Size(pathItem string) (int64, error) { + file, err := s.client.Stat(path.Join(s.Bucket, pathItem)) if err != nil { return 0, err } return file.Size(), nil } -func (s webDAVClient) Delete(filePath string) (bool, error) { - if err := s.client.Remove(s.Bucket + "/" + filePath); err != nil { +func (s webDAVClient) Delete(pathItem string) (bool, error) { + if err := s.client.Remove(path.Join(s.Bucket, pathItem)); err != nil { return false, err } return true, nil } func (s webDAVClient) ListObjects(prefix string) ([]string, error) { - files, err := s.client.ReadDir(s.Bucket + "/" + prefix) + files, err := s.client.ReadDir(path.Join(s.Bucket, prefix)) if err != nil { return nil, err } diff --git a/frontend/src/lang/modules/en.ts b/frontend/src/lang/modules/en.ts index f1723023e..610d7e488 100644 --- a/frontend/src/lang/modules/en.ts +++ b/frontend/src/lang/modules/en.ts @@ -1250,6 +1250,7 @@ const message = { MINIO: 'MINIO', SFTP: 'SFTP', WebDAV: 'WebDAV', + WebDAVAlist: 'WebDAV connect Alist can refer to the official documentation', OneDrive: 'Microsoft OneDrive', isCN: 'Century Internet', isNotCN: 'International Version', diff --git a/frontend/src/lang/modules/tw.ts b/frontend/src/lang/modules/tw.ts index 93045f82a..e24b077fa 100644 --- a/frontend/src/lang/modules/tw.ts +++ b/frontend/src/lang/modules/tw.ts @@ -1173,6 +1173,7 @@ const message = { MINIO: 'MINIO', SFTP: 'SFTP', WebDAV: 'WebDAV', + WebDAVAlist: 'WebDAV 連接 Alist 可參考官方文檔', OneDrive: '微軟 OneDrive', isCN: '世紀互聯', isNotCN: '國際版', @@ -1183,7 +1184,7 @@ const message = { refreshTime: '令牌刷新時間', refreshStatus: '令牌刷新狀態', codeWarning: '當前授權碼格式錯誤,請重新確認!', - backupDir: '備份路徑', + backupDir: '備份目录', code: '授權碼', codeHelper: '請點擊獲取按鈕,然後登錄 OneDrive 復製跳轉鏈接中 code 後面的內容,粘貼到該輸入框中,具體操作可參考官方文檔。', diff --git a/frontend/src/lang/modules/zh.ts b/frontend/src/lang/modules/zh.ts index 09caba71b..c2c1af438 100644 --- a/frontend/src/lang/modules/zh.ts +++ b/frontend/src/lang/modules/zh.ts @@ -1174,6 +1174,7 @@ const message = { MINIO: 'MINIO', SFTP: 'SFTP', WebDAV: 'WebDAV', + WebDAVAlist: 'WebDAV 连接 Alist 可参考官方文档', OneDrive: '微软 OneDrive', isCN: '世纪互联', isNotCN: '国际版', @@ -1184,7 +1185,7 @@ const message = { refreshTime: '令牌刷新时间', refreshStatus: '令牌刷新状态', codeWarning: '当前授权码格式错误,请重新确认!', - backupDir: '备份路径', + backupDir: '备份目录', code: '授权码', codeHelper: '请点击获取按钮,然后登录 OneDrive 复制跳转链接中 code 后面的内容,粘贴到该输入框中,具体操作可参考官方文档。', diff --git a/frontend/src/views/setting/backup-account/index.vue b/frontend/src/views/setting/backup-account/index.vue index 3a3b7e347..1b8d09ade 100644 --- a/frontend/src/views/setting/backup-account/index.vue +++ b/frontend/src/views/setting/backup-account/index.vue @@ -372,7 +372,7 @@ {{ sftpData.varsJson['port'] }} - + {{ sftpData.bucket }} @@ -408,10 +408,7 @@ {{ webDAVData.varsJson['address'] }} - - {{ webDAVData.varsJson['port'] }} - - + {{ webDAVData.bucket }} diff --git a/frontend/src/views/setting/backup-account/sftp/index.vue b/frontend/src/views/setting/backup-account/sftp/index.vue index cfba068d2..b1a8a3771 100644 --- a/frontend/src/views/setting/backup-account/sftp/index.vue +++ b/frontend/src/views/setting/backup-account/sftp/index.vue @@ -39,7 +39,7 @@ v-model.trim="sftpData.rowData!.credential" /> - + diff --git a/frontend/src/views/setting/backup-account/webdav/index.vue b/frontend/src/views/setting/backup-account/webdav/index.vue index 4e1857616..59fbaabc1 100644 --- a/frontend/src/views/setting/backup-account/webdav/index.vue +++ b/frontend/src/views/setting/backup-account/webdav/index.vue @@ -12,20 +12,21 @@ - - - - - - + + + {{ $t('setting.WebDAVAlist') }} + + {{ $t('firewall.quickJump') }} + + - + @@ -67,7 +68,7 @@