2023-12-28 08:29:18 +00:00
|
|
|
package v1
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"encoding/base64"
|
|
|
|
|
|
|
|
"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 Postgresql
|
|
|
|
// @Summary Create postgresql database
|
|
|
|
// @Accept json
|
|
|
|
// @Param request body dto.PostgresqlDBCreate true "request"
|
|
|
|
// @Success 200
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-12-28 08:29:18 +00:00
|
|
|
// @Router /databases/pg [post]
|
|
|
|
// @x-panel-log {"bodyKeys":["name"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"创建 postgresql 数据库 [name]","formatEN":"create postgresql database [name]"}
|
|
|
|
func (b *BaseApi) CreatePostgresql(c *gin.Context) {
|
|
|
|
var req dto.PostgresqlDBCreate
|
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(req.Password) != 0 {
|
|
|
|
password, err := base64.StdEncoding.DecodeString(req.Password)
|
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
req.Password = string(password)
|
|
|
|
}
|
|
|
|
|
|
|
|
if _, err := postgresqlService.Create(context.Background(), req); err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
helper.SuccessWithData(c, nil)
|
|
|
|
}
|
|
|
|
|
2024-01-08 09:40:42 +00:00
|
|
|
// @Tags Database Postgresql
|
|
|
|
// @Summary Bind postgresql user
|
|
|
|
// @Accept json
|
|
|
|
// @Param request body dto.PostgresqlBindUser true "request"
|
|
|
|
// @Success 200
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2024-01-08 09:40:42 +00:00
|
|
|
// @Router /databases/pg/bind [post]
|
|
|
|
// @x-panel-log {"bodyKeys":["name", "username"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"绑定 postgresql 数据库 [name] 用户 [username]","formatEN":"bind postgresql database [name] user [username]"}
|
|
|
|
func (b *BaseApi) BindPostgresqlUser(c *gin.Context) {
|
|
|
|
var req dto.PostgresqlBindUser
|
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := postgresqlService.BindUser(req); err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
helper.SuccessWithData(c, nil)
|
|
|
|
}
|
|
|
|
|
2023-12-28 08:29:18 +00:00
|
|
|
// @Tags Database Postgresql
|
|
|
|
// @Summary Update postgresql database description
|
|
|
|
// @Accept json
|
|
|
|
// @Param request body dto.UpdateDescription true "request"
|
|
|
|
// @Success 200
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-12-28 08:29:18 +00:00
|
|
|
// @Router /databases/pg/description [post]
|
|
|
|
// @x-panel-log {"bodyKeys":["id","description"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"database_postgresqls","output_column":"name","output_value":"name"}],"formatZH":"postgresql 数据库 [name] 描述信息修改 [description]","formatEN":"The description of the postgresql database [name] is modified => [description]"}
|
|
|
|
func (b *BaseApi) UpdatePostgresqlDescription(c *gin.Context) {
|
|
|
|
var req dto.UpdateDescription
|
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := postgresqlService.UpdateDescription(req); err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
helper.SuccessWithData(c, nil)
|
|
|
|
}
|
|
|
|
|
2024-01-09 04:43:33 +00:00
|
|
|
// @Tags Database Postgresql
|
|
|
|
// @Summary Change postgresql privileges
|
|
|
|
// @Accept json
|
|
|
|
// @Param request body dto.ChangeDBInfo true "request"
|
|
|
|
// @Success 200
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2024-01-09 04:43:33 +00:00
|
|
|
// @Router /databases/pg/privileges [post]
|
|
|
|
// @x-panel-log {"bodyKeys":["database", "username"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"更新数据库 [database] 用户 [username] 权限","formatEN":"Update [user] privileges of database [database]"}
|
|
|
|
func (b *BaseApi) ChangePostgresqlPrivileges(c *gin.Context) {
|
|
|
|
var req dto.PostgresqlPrivileges
|
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := postgresqlService.ChangePrivileges(req); err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
helper.SuccessWithData(c, nil)
|
|
|
|
}
|
|
|
|
|
2023-12-28 08:29:18 +00:00
|
|
|
// @Tags Database Postgresql
|
|
|
|
// @Summary Change postgresql password
|
|
|
|
// @Accept json
|
|
|
|
// @Param request body dto.ChangeDBInfo true "request"
|
|
|
|
// @Success 200
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-12-28 08:29:18 +00:00
|
|
|
// @Router /databases/pg/password [post]
|
|
|
|
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"database_postgresqls","output_column":"name","output_value":"name"}],"formatZH":"更新数据库 [name] 密码","formatEN":"Update database [name] password"}
|
|
|
|
func (b *BaseApi) ChangePostgresqlPassword(c *gin.Context) {
|
|
|
|
var req dto.ChangeDBInfo
|
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(req.Value) != 0 {
|
|
|
|
value, err := base64.StdEncoding.DecodeString(req.Value)
|
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
req.Value = string(value)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := postgresqlService.ChangePassword(req); err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
helper.SuccessWithData(c, nil)
|
|
|
|
}
|
|
|
|
|
|
|
|
// @Tags Database Postgresql
|
|
|
|
// @Summary Page postgresql databases
|
|
|
|
// @Accept json
|
|
|
|
// @Param request body dto.PostgresqlDBSearch true "request"
|
|
|
|
// @Success 200 {object} dto.PageResult
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-12-28 08:29:18 +00:00
|
|
|
// @Router /databases/pg/search [post]
|
|
|
|
func (b *BaseApi) SearchPostgresql(c *gin.Context) {
|
|
|
|
var req dto.PostgresqlDBSearch
|
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
total, list, err := postgresqlService.SearchWithPage(req)
|
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
helper.SuccessWithData(c, dto.PageResult{
|
|
|
|
Items: list,
|
|
|
|
Total: total,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
// @Tags Database Postgresql
|
|
|
|
// @Summary Load postgresql database from remote
|
|
|
|
// @Accept json
|
|
|
|
// @Param request body dto.PostgresqlLoadDB true "request"
|
2024-12-31 02:32:47 +00:00
|
|
|
// @Param database path string true "database"
|
|
|
|
// @Success 200
|
2023-12-28 08:29:18 +00:00
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2024-12-31 02:32:47 +00:00
|
|
|
// @Router /databases/pg/{database}/load [post]
|
2023-12-28 08:29:18 +00:00
|
|
|
func (b *BaseApi) LoadPostgresqlDBFromRemote(c *gin.Context) {
|
2024-01-08 09:40:42 +00:00
|
|
|
database, err := helper.GetStrParamByKey(c, "database")
|
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrBadRequest, constant.ErrTypeInvalidParams, err)
|
2024-01-02 09:08:13 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2024-01-08 09:40:42 +00:00
|
|
|
if err := postgresqlService.LoadFromRemote(database); err != nil {
|
2024-01-02 09:08:13 +00:00
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
helper.SuccessWithData(c, nil)
|
2023-12-28 08:29:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// @Tags Database Postgresql
|
|
|
|
// @Summary Check before delete postgresql database
|
|
|
|
// @Accept json
|
|
|
|
// @Param request body dto.PostgresqlDBDeleteCheck true "request"
|
|
|
|
// @Success 200 {array} string
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-12-28 08:29:18 +00:00
|
|
|
// @Router /databases/pg/del/check [post]
|
|
|
|
func (b *BaseApi) DeleteCheckPostgresql(c *gin.Context) {
|
|
|
|
var req dto.PostgresqlDBDeleteCheck
|
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
apps, err := postgresqlService.DeleteCheck(req)
|
|
|
|
if err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
helper.SuccessWithData(c, apps)
|
|
|
|
}
|
|
|
|
|
|
|
|
// @Tags Database Postgresql
|
|
|
|
// @Summary Delete postgresql database
|
|
|
|
// @Accept json
|
|
|
|
// @Param request body dto.PostgresqlDBDelete true "request"
|
|
|
|
// @Success 200
|
|
|
|
// @Security ApiKeyAuth
|
2024-12-09 09:57:34 +00:00
|
|
|
// @Security Timestamp
|
2023-12-28 08:29:18 +00:00
|
|
|
// @Router /databases/pg/del [post]
|
|
|
|
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"database_postgresqls","output_column":"name","output_value":"name"}],"formatZH":"删除 postgresql 数据库 [name]","formatEN":"delete postgresql database [name]"}
|
|
|
|
func (b *BaseApi) DeletePostgresql(c *gin.Context) {
|
|
|
|
var req dto.PostgresqlDBDelete
|
|
|
|
if err := helper.CheckBindAndValidate(&req, c); err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
tx, ctx := helper.GetTxAndContext()
|
|
|
|
if err := postgresqlService.Delete(ctx, req); err != nil {
|
|
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, err)
|
|
|
|
tx.Rollback()
|
|
|
|
return
|
|
|
|
}
|
|
|
|
tx.Commit()
|
|
|
|
helper.SuccessWithData(c, nil)
|
|
|
|
}
|