2023-07-20 09:51:57 +00:00
|
|
|
package v1
|
|
|
|
|
|
|
|
import (
|
2023-11-29 02:46:07 +00:00
|
|
|
"encoding/base64"
|
|
|
|
|
2023-07-20 09:51:57 +00:00
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/api/v1/helper"
|
|
|
|
"github.com/1Panel-dev/1Panel/backend/app/dto"
|
|
|
|
"github.com/1Panel-dev/1Panel/backend/constant"
|
|
|
|
"github.com/gin-gonic/gin"
|
|
|
|
)
|
|
|
|
|
|
|
|
// @Tags Database
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Summary Create database
|
2023-07-20 09:51:57 +00:00
|
|
|
// @Accept json
|
2023-08-29 02:50:15 +00:00
|
|
|
// @Param request body dto.DatabaseCreate true "request"
|
2023-07-20 09:51:57 +00:00
|
|
|
// @Success 200
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Router /databases/db [post]
|
2023-10-07 07:46:44 +00:00
|
|
|
// @x-panel-log {"bodyKeys":["name", "type"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"创建远程数据库 [name][type]","formatEN":"create database [name][type]"}
|
2023-08-29 02:50:15 +00:00
|
|
|
func (b *BaseApi) CreateDatabase(c *gin.Context) {
|
|
|
|
var req dto.DatabaseCreate
|
2023-10-27 06:19:26 +00:00
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
2023-07-20 09:51:57 +00:00
|
|
|
return
|
|
|
|
}
|
2023-11-29 02:46:07 +00:00
|
|
|
if req.SSL {
|
|
|
|
key, _ := base64.StdEncoding.DecodeString(req.ClientKey)
|
|
|
|
req.ClientKey = string(key)
|
|
|
|
cert, _ := base64.StdEncoding.DecodeString(req.ClientCert)
|
|
|
|
req.ClientCert = string(cert)
|
|
|
|
ca, _ := base64.StdEncoding.DecodeString(req.RootCert)
|
|
|
|
req.RootCert = string(ca)
|
|
|
|
}
|
2023-10-27 06:19:26 +00:00
|
|
|
|
2023-08-29 02:50:15 +00:00
|
|
|
if err := databaseService.Create(req); err != nil {
|
2023-07-20 09:51:57 +00:00
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
helper.SuccessWithData(c, nil)
|
|
|
|
}
|
|
|
|
|
2023-08-11 14:20:15 +00:00
|
|
|
// @Tags Database
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Summary Check database
|
2023-08-11 14:20:15 +00:00
|
|
|
// @Accept json
|
2023-08-29 02:50:15 +00:00
|
|
|
// @Param request body dto.DatabaseCreate true "request"
|
2023-08-11 14:20:15 +00:00
|
|
|
// @Success 200
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Router /databases/db/check [post]
|
2023-10-07 07:46:44 +00:00
|
|
|
// @x-panel-log {"bodyKeys":["name", "type"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"检测远程数据库 [name][type] 连接性","formatEN":"check if database [name][type] is connectable"}
|
2023-08-29 02:50:15 +00:00
|
|
|
func (b *BaseApi) CheckDatabase(c *gin.Context) {
|
|
|
|
var req dto.DatabaseCreate
|
2023-10-27 06:19:26 +00:00
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
2023-08-11 14:20:15 +00:00
|
|
|
return
|
|
|
|
}
|
2023-11-29 02:46:07 +00:00
|
|
|
if req.SSL {
|
|
|
|
clientKey, _ := base64.StdEncoding.DecodeString(req.ClientKey)
|
|
|
|
req.ClientKey = string(clientKey)
|
|
|
|
clientCert, _ := base64.StdEncoding.DecodeString(req.ClientCert)
|
|
|
|
req.ClientCert = string(clientCert)
|
|
|
|
rootCert, _ := base64.StdEncoding.DecodeString(req.RootCert)
|
|
|
|
req.RootCert = string(rootCert)
|
|
|
|
}
|
2023-10-27 06:19:26 +00:00
|
|
|
|
2023-08-29 02:50:15 +00:00
|
|
|
helper.SuccessWithData(c, databaseService.CheckDatabase(req))
|
2023-08-11 14:20:15 +00:00
|
|
|
}
|
|
|
|
|
2023-07-20 09:51:57 +00:00
|
|
|
// @Tags Database
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Summary Page databases
|
2023-07-20 09:51:57 +00:00
|
|
|
// @Accept json
|
2023-08-29 02:50:15 +00:00
|
|
|
// @Param request body dto.DatabaseSearch true "request"
|
2023-07-20 09:51:57 +00:00
|
|
|
// @Success 200 {object} dto.PageResult
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Router /databases/db/search [post]
|
2023-08-29 02:50:15 +00:00
|
|
|
func (b *BaseApi) SearchDatabase(c *gin.Context) {
|
|
|
|
var req dto.DatabaseSearch
|
2023-10-27 06:19:26 +00:00
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
2023-07-20 09:51:57 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-08-29 02:50:15 +00:00
|
|
|
total, list, err := databaseService.SearchWithPage(req)
|
2023-07-20 09:51:57 +00:00
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
helper.SuccessWithData(c, dto.PageResult{
|
|
|
|
Items: list,
|
|
|
|
Total: total,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// @Tags Database
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Summary List databases
|
2023-08-29 02:50:15 +00:00
|
|
|
// @Success 200 {array} dto.DatabaseOption
|
2023-07-20 09:51:57 +00:00
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Router /databases/db/list/:type [get]
|
2023-08-29 02:50:15 +00:00
|
|
|
func (b *BaseApi) ListDatabase(c *gin.Context) {
|
2023-07-21 10:28:45 +00:00
|
|
|
dbType, err := helper.GetStrParamByKey(c, "type")
|
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
|
|
|
return
|
|
|
|
}
|
2023-08-29 02:50:15 +00:00
|
|
|
list, err := databaseService.List(dbType)
|
2023-07-20 09:51:57 +00:00
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
helper.SuccessWithData(c, list)
|
|
|
|
}
|
|
|
|
|
2024-01-07 14:52:41 +00:00
|
|
|
// @Tags Database
|
2024-11-30 11:44:50 +00:00
|
|
|
// @Summary Retrieve database list based on type
|
2024-01-07 14:52:41 +00:00
|
|
|
// @Success 200 {array} dto.DatabaseItem
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2024-01-07 14:52:41 +00:00
|
|
|
// @Router /databases/db/item/:type [get]
|
|
|
|
func (b *BaseApi) LoadDatabaseItems(c *gin.Context) {
|
|
|
|
dbType, err := helper.GetStrParamByKey(c, "type")
|
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
list, err := databaseService.LoadItems(dbType)
|
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
helper.SuccessWithData(c, list)
|
|
|
|
}
|
|
|
|
|
2023-07-27 08:07:27 +00:00
|
|
|
// @Tags Database
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Summary Get databases
|
2023-08-29 02:50:15 +00:00
|
|
|
// @Success 200 {object} dto.DatabaseInfo
|
2023-07-27 08:07:27 +00:00
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Router /databases/db/:name [get]
|
2023-08-29 02:50:15 +00:00
|
|
|
func (b *BaseApi) GetDatabase(c *gin.Context) {
|
2023-07-27 08:07:27 +00:00
|
|
|
name, err := helper.GetStrParamByKey(c, "name")
|
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
|
|
|
return
|
|
|
|
}
|
2023-08-29 02:50:15 +00:00
|
|
|
data, err := databaseService.Get(name)
|
2023-07-27 08:07:27 +00:00
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
helper.SuccessWithData(c, data)
|
|
|
|
}
|
|
|
|
|
2023-10-08 06:52:14 +00:00
|
|
|
// @Tags Database
|
|
|
|
// @Summary Check before delete remote database
|
|
|
|
// @Accept json
|
|
|
|
// @Param request body dto.OperateByID true "request"
|
|
|
|
// @Success 200 {array} string
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-10-08 06:52:14 +00:00
|
|
|
// @Router /db/remote/del/check [post]
|
|
|
|
func (b *BaseApi) DeleteCheckDatabase(c *gin.Context) {
|
|
|
|
var req dto.OperateByID
|
2023-10-27 06:19:26 +00:00
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
2023-10-08 06:52:14 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
apps, err := databaseService.DeleteCheck(req.ID)
|
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
helper.SuccessWithData(c, apps)
|
|
|
|
}
|
|
|
|
|
2023-07-20 09:51:57 +00:00
|
|
|
// @Tags Database
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Summary Delete database
|
2023-07-20 09:51:57 +00:00
|
|
|
// @Accept json
|
2023-10-08 06:52:14 +00:00
|
|
|
// @Param request body dto.DatabaseDelete true "request"
|
2023-07-20 09:51:57 +00:00
|
|
|
// @Success 200
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Router /databases/db/del [post]
|
2023-10-07 07:46:44 +00:00
|
|
|
// @x-panel-log {"bodyKeys":["ids"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"ids","isList":true,"db":"databases","output_column":"name","output_value":"names"}],"formatZH":"删除远程数据库 [names]","formatEN":"delete database [names]"}
|
2023-08-29 02:50:15 +00:00
|
|
|
func (b *BaseApi) DeleteDatabase(c *gin.Context) {
|
2023-10-08 06:52:14 +00:00
|
|
|
var req dto.DatabaseDelete
|
2023-10-27 06:19:26 +00:00
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
2023-07-20 09:51:57 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-10-08 06:52:14 +00:00
|
|
|
if err := databaseService.Delete(req); err != nil {
|
2023-07-20 09:51:57 +00:00
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
helper.SuccessWithData(c, nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
// @Tags Database
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Summary Update database
|
2023-07-20 09:51:57 +00:00
|
|
|
// @Accept json
|
2023-08-29 02:50:15 +00:00
|
|
|
// @Param request body dto.DatabaseUpdate true "request"
|
2023-07-20 09:51:57 +00:00
|
|
|
// @Success 200
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-08-31 14:28:13 +00:00
|
|
|
// @Router /databases/db/update [post]
|
2023-10-07 07:46:44 +00:00
|
|
|
// @x-panel-log {"bodyKeys":["name"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"更新远程数据库 [name]","formatEN":"update database [name]"}
|
2023-08-29 02:50:15 +00:00
|
|
|
func (b *BaseApi) UpdateDatabase(c *gin.Context) {
|
|
|
|
var req dto.DatabaseUpdate
|
2023-10-27 06:19:26 +00:00
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
2023-07-20 09:51:57 +00:00
|
|
|
return
|
|
|
|
}
|
2023-11-29 02:46:07 +00:00
|
|
|
if req.SSL {
|
|
|
|
cKey, _ := base64.StdEncoding.DecodeString(req.ClientKey)
|
|
|
|
req.ClientKey = string(cKey)
|
|
|
|
cCert, _ := base64.StdEncoding.DecodeString(req.ClientCert)
|
|
|
|
req.ClientCert = string(cCert)
|
|
|
|
ca, _ := base64.StdEncoding.DecodeString(req.RootCert)
|
|
|
|
req.RootCert = string(ca)
|
|
|
|
}
|
2023-07-20 09:51:57 +00:00
|
|
|
|
2023-08-29 02:50:15 +00:00
|
|
|
if err := databaseService.Update(req); err != nil {
|
2023-07-20 09:51:57 +00:00
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
helper.SuccessWithData(c, nil)
|
|
|
|
}
|