mirror of
https://github.com/1Panel-dev/1Panel.git
synced 2024-12-20 20:37:49 +08:00
201 lines
6.1 KiB
Go
201 lines
6.1 KiB
Go
|
package v2
|
||
|
|
||
|
import (
|
||
|
"encoding/base64"
|
||
|
|
||
|
"github.com/1Panel-dev/1Panel/core/app/api/v2/helper"
|
||
|
"github.com/1Panel-dev/1Panel/core/app/dto"
|
||
|
"github.com/1Panel-dev/1Panel/core/constant"
|
||
|
"github.com/gin-gonic/gin"
|
||
|
)
|
||
|
|
||
|
// @Tags Backup Account
|
||
|
// @Summary Create backup account
|
||
|
// @Description 创建备份账号
|
||
|
// @Accept json
|
||
|
// @Param request body dto.BackupOperate true "request"
|
||
|
// @Success 200
|
||
|
// @Security ApiKeyAuth
|
||
|
// @Router /core/backup [post]
|
||
|
// @x-panel-log {"bodyKeys":["type"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"创建备份账号 [type]","formatEN":"create backup account [type]"}
|
||
|
func (b *BaseApi) CreateBackup(c *gin.Context) {
|
||
|
var req dto.BackupOperate
|
||
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
||
|
return
|
||
|
}
|
||
|
if len(req.Credential) != 0 {
|
||
|
credential, err := base64.StdEncoding.DecodeString(req.Credential)
|
||
|
if err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
||
|
return
|
||
|
}
|
||
|
req.Credential = string(credential)
|
||
|
}
|
||
|
if len(req.AccessKey) != 0 {
|
||
|
accessKey, err := base64.StdEncoding.DecodeString(req.AccessKey)
|
||
|
if err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
||
|
return
|
||
|
}
|
||
|
req.AccessKey = string(accessKey)
|
||
|
}
|
||
|
|
||
|
if err := backupService.Create(req); err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
||
|
return
|
||
|
}
|
||
|
helper.SuccessWithData(c, nil)
|
||
|
}
|
||
|
|
||
|
// @Tags Backup Account
|
||
|
// @Summary Refresh OneDrive token
|
||
|
// @Description 刷新 OneDrive token
|
||
|
// @Success 200
|
||
|
// @Security ApiKeyAuth
|
||
|
// @Router /core/backup/refresh/onedrive [post]
|
||
|
func (b *BaseApi) RefreshOneDriveToken(c *gin.Context) {
|
||
|
backupService.Run()
|
||
|
helper.SuccessWithData(c, nil)
|
||
|
}
|
||
|
|
||
|
// @Tags Backup Account
|
||
|
// @Summary List buckets
|
||
|
// @Description 获取 bucket 列表
|
||
|
// @Accept json
|
||
|
// @Param request body dto.ForBuckets true "request"
|
||
|
// @Success 200 {array} string
|
||
|
// @Security ApiKeyAuth
|
||
|
// @Router /core/backup/search [post]
|
||
|
func (b *BaseApi) ListBuckets(c *gin.Context) {
|
||
|
var req dto.ForBuckets
|
||
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
||
|
return
|
||
|
}
|
||
|
if len(req.Credential) != 0 {
|
||
|
credential, err := base64.StdEncoding.DecodeString(req.Credential)
|
||
|
if err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
||
|
return
|
||
|
}
|
||
|
req.Credential = string(credential)
|
||
|
}
|
||
|
if len(req.AccessKey) != 0 {
|
||
|
accessKey, err := base64.StdEncoding.DecodeString(req.AccessKey)
|
||
|
if err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
||
|
return
|
||
|
}
|
||
|
req.AccessKey = string(accessKey)
|
||
|
}
|
||
|
|
||
|
buckets, err := backupService.GetBuckets(req)
|
||
|
if err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
||
|
return
|
||
|
}
|
||
|
helper.SuccessWithData(c, buckets)
|
||
|
}
|
||
|
|
||
|
// @Tags Backup Account
|
||
|
// @Summary Load OneDrive info
|
||
|
// @Description 获取 OneDrive 信息
|
||
|
// @Accept json
|
||
|
// @Success 200 {object} dto.OneDriveInfo
|
||
|
// @Security ApiKeyAuth
|
||
|
// @Router /core/backup/onedrive [get]
|
||
|
func (b *BaseApi) LoadOneDriveInfo(c *gin.Context) {
|
||
|
data, err := backupService.LoadOneDriveInfo()
|
||
|
if err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
||
|
return
|
||
|
}
|
||
|
helper.SuccessWithData(c, data)
|
||
|
}
|
||
|
|
||
|
// @Tags Backup Account
|
||
|
// @Summary Delete backup account
|
||
|
// @Description 删除备份账号
|
||
|
// @Accept json
|
||
|
// @Param request body dto.OperateByID true "request"
|
||
|
// @Success 200
|
||
|
// @Security ApiKeyAuth
|
||
|
// @Router /core/backup/del [post]
|
||
|
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"backup_accounts","output_column":"type","output_value":"types"}],"formatZH":"删除备份账号 [types]","formatEN":"delete backup account [types]"}
|
||
|
func (b *BaseApi) DeleteBackup(c *gin.Context) {
|
||
|
var req dto.OperateByID
|
||
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
if err := backupService.Delete(req.ID); err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
||
|
return
|
||
|
}
|
||
|
helper.SuccessWithData(c, nil)
|
||
|
}
|
||
|
|
||
|
// @Tags Backup Account
|
||
|
// @Summary Update backup account
|
||
|
// @Description 更新备份账号信息
|
||
|
// @Accept json
|
||
|
// @Param request body dto.BackupOperate true "request"
|
||
|
// @Success 200
|
||
|
// @Security ApiKeyAuth
|
||
|
// @Router /core/backup/update [post]
|
||
|
// @x-panel-log {"bodyKeys":["type"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"更新备份账号 [types]","formatEN":"update backup account [types]"}
|
||
|
func (b *BaseApi) UpdateBackup(c *gin.Context) {
|
||
|
var req dto.BackupOperate
|
||
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
if len(req.Credential) != 0 {
|
||
|
credential, err := base64.StdEncoding.DecodeString(req.Credential)
|
||
|
if err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
||
|
return
|
||
|
}
|
||
|
req.Credential = string(credential)
|
||
|
}
|
||
|
if len(req.AccessKey) != 0 {
|
||
|
accessKey, err := base64.StdEncoding.DecodeString(req.AccessKey)
|
||
|
if err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
||
|
return
|
||
|
}
|
||
|
req.AccessKey = string(accessKey)
|
||
|
}
|
||
|
|
||
|
if err := backupService.Update(req); err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
||
|
return
|
||
|
}
|
||
|
helper.SuccessWithData(c, nil)
|
||
|
}
|
||
|
|
||
|
// @Tags Backup Account
|
||
|
// @Summary Search backup accounts with page
|
||
|
// @Description 获取备份账号列表
|
||
|
// @Accept json
|
||
|
// @Param request body dto.SearchPageWithType true "request"
|
||
|
// @Success 200 {array} dto.BackupList
|
||
|
// @Security ApiKeyAuth
|
||
|
// @Router /core/backup/search [get]
|
||
|
func (b *BaseApi) SearchBackup(c *gin.Context) {
|
||
|
var req dto.SearchPageWithType
|
||
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
||
|
return
|
||
|
}
|
||
|
|
||
|
total, list, err := backupService.SearchWithPage(req)
|
||
|
if err != nil {
|
||
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
||
|
return
|
||
|
}
|
||
|
|
||
|
helper.SuccessWithData(c, dto.PageResult{
|
||
|
Items: list,
|
||
|
Total: total,
|
||
|
})
|
||
|
}
|