1
0
mirror of https://github.com/1Panel-dev/1Panel.git synced 2025-01-19 00:09:16 +08:00

fix: correct Swagger API definitions (#7606)

Signed-off-by: Ryan Wang <i@ryanc.cc>
This commit is contained in:
Ryan Wang 2024-12-31 10:32:47 +08:00 committed by GitHub
parent fc401ffd8f
commit 5187b20252
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
24 changed files with 1456 additions and 1067 deletions

View File

@ -68,7 +68,7 @@ func (b *BaseApi) SyncApp(c *gin.Context) {
// @Success 200 {object} response.AppDTO // @Success 200 {object} response.AppDTO
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /apps/:key [get] // @Router /apps/{key} [get]
func (b *BaseApi) GetApp(c *gin.Context) { func (b *BaseApi) GetApp(c *gin.Context) {
appKey, err := helper.GetStrParamByKey(c, "key") appKey, err := helper.GetStrParamByKey(c, "key")
if err != nil { if err != nil {
@ -88,11 +88,11 @@ func (b *BaseApi) GetApp(c *gin.Context) {
// @Accept json // @Accept json
// @Param appId path integer true "app id" // @Param appId path integer true "app id"
// @Param version path string true "app version" // @Param version path string true "app version"
// @Param version path string true "app type" // @Param type path string true "app type"
// @Success 200 {object} response.AppDetailDTO // @Success 200 {object} response.AppDetailDTO
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /apps/detail/:appId/:version/:type [get] // @Router /apps/detail/{appId}/{version}/{type} [get]
func (b *BaseApi) GetAppDetail(c *gin.Context) { func (b *BaseApi) GetAppDetail(c *gin.Context) {
appID, err := helper.GetIntParamByKey(c, "appId") appID, err := helper.GetIntParamByKey(c, "appId")
if err != nil { if err != nil {
@ -112,11 +112,11 @@ func (b *BaseApi) GetAppDetail(c *gin.Context) {
// @Tags App // @Tags App
// @Summary Get app detail by id // @Summary Get app detail by id
// @Accept json // @Accept json
// @Param appId path integer true "id" // @Param id path integer true "id"
// @Success 200 {object} response.AppDetailDTO // @Success 200 {object} response.AppDetailDTO
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /apps/details/:id [get] // @Router /apps/details/{id} [get]
func (b *BaseApi) GetAppDetailByID(c *gin.Context) { func (b *BaseApi) GetAppDetailByID(c *gin.Context) {
appDetailID, err := helper.GetIntParamByKey(c, "id") appDetailID, err := helper.GetIntParamByKey(c, "id")
if err != nil { if err != nil {

View File

@ -104,10 +104,11 @@ func (b *BaseApi) LoadPort(c *gin.Context) {
// @Summary Search app password by key // @Summary Search app password by key
// @Accept json // @Accept json
// @Param request body dto.OperationWithNameAndType true "request" // @Param request body dto.OperationWithNameAndType true "request"
// @Param key path string true "key"
// @Success 200 {string} response.DatabaseConn // @Success 200 {string} response.DatabaseConn
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /apps/installed/conninfo/:key [get] // @Router /apps/installed/conninfo/{key} [get]
func (b *BaseApi) LoadConnInfo(c *gin.Context) { func (b *BaseApi) LoadConnInfo(c *gin.Context) {
var req dto.OperationWithNameAndType var req dto.OperationWithNameAndType
if err := helper.CheckBindAndValidate(&req, c); err != nil { if err := helper.CheckBindAndValidate(&req, c); err != nil {
@ -128,7 +129,7 @@ func (b *BaseApi) LoadConnInfo(c *gin.Context) {
// @Success 200 {array} dto.AppResource // @Success 200 {array} dto.AppResource
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /apps/installed/delete/check/:appInstallId [get] // @Router /apps/installed/delete/check/{appInstallId} [get]
func (b *BaseApi) DeleteCheck(c *gin.Context) { func (b *BaseApi) DeleteCheck(c *gin.Context) {
appInstallId, err := helper.GetIntParamByKey(c, "appInstallId") appInstallId, err := helper.GetIntParamByKey(c, "appInstallId")
if err != nil { if err != nil {
@ -187,7 +188,7 @@ func (b *BaseApi) OperateInstalled(c *gin.Context) {
// @Success 200 {array} response.AppService // @Success 200 {array} response.AppService
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /apps/services/:key [get] // @Router /apps/services/{key} [get]
func (b *BaseApi) GetServices(c *gin.Context) { func (b *BaseApi) GetServices(c *gin.Context) {
key := c.Param("key") key := c.Param("key")
services, err := appInstallService.GetServices(key) services, err := appInstallService.GetServices(key)
@ -201,7 +202,6 @@ func (b *BaseApi) GetServices(c *gin.Context) {
// @Tags App // @Tags App
// @Summary Search app update version by install id // @Summary Search app update version by install id
// @Accept json // @Accept json
// @Param appInstallId path integer true "request"
// @Success 200 {array} dto.AppVersion // @Success 200 {array} dto.AppVersion
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
@ -269,7 +269,7 @@ func (b *BaseApi) GetDefaultConfig(c *gin.Context) {
// @Success 200 {object} response.AppParam // @Success 200 {object} response.AppParam
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /apps/installed/params/:appInstallId [get] // @Router /apps/installed/params/{appInstallId} [get]
func (b *BaseApi) GetParams(c *gin.Context) { func (b *BaseApi) GetParams(c *gin.Context) {
appInstallId, err := helper.GetIntParamByKey(c, "appInstallId") appInstallId, err := helper.GetIntParamByKey(c, "appInstallId")
if err != nil { if err != nil {

View File

@ -120,6 +120,7 @@ func (b *BaseApi) LoadClamBaseInfo(c *gin.Context) {
// @Summary Operate Clam // @Summary Operate Clam
// @Accept json // @Accept json
// @Param request body dto.Operate true "request" // @Param request body dto.Operate true "request"
// @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /toolbox/clam/operate [post] // @Router /toolbox/clam/operate [post]
@ -142,6 +143,7 @@ func (b *BaseApi) OperateClam(c *gin.Context) {
// @Summary Clean clam record // @Summary Clean clam record
// @Accept json // @Accept json
// @Param request body dto.OperateByID true "request" // @Param request body dto.OperateByID true "request"
// @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /toolbox/clam/record/clean [post] // @Router /toolbox/clam/record/clean [post]

View File

@ -106,7 +106,7 @@ func (b *BaseApi) SearchRedisCommand(c *gin.Context) {
// @Tags Command // @Tags Command
// @Summary Tree commands // @Summary Tree commands
// @Accept json // @Accept json
// @Success 200 {Array} dto.CommandTree // @Success 200 {array} dto.CommandTree
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /hosts/command/tree [get] // @Router /hosts/command/tree [get]
@ -122,7 +122,7 @@ func (b *BaseApi) SearchCommandTree(c *gin.Context) {
// @Tags Redis Command // @Tags Redis Command
// @Summary List redis commands // @Summary List redis commands
// @Success 200 {Array} dto.RedisCommand // @Success 200 {array} dto.RedisCommand
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /hosts/command/redis [get] // @Router /hosts/command/redis [get]

View File

@ -1,13 +1,14 @@
package v1 package v1
import ( import (
"strconv"
"github.com/1Panel-dev/1Panel/backend/app/api/v1/helper" "github.com/1Panel-dev/1Panel/backend/app/api/v1/helper"
"github.com/1Panel-dev/1Panel/backend/app/dto" "github.com/1Panel-dev/1Panel/backend/app/dto"
"github.com/1Panel-dev/1Panel/backend/constant" "github.com/1Panel-dev/1Panel/backend/constant"
"github.com/1Panel-dev/1Panel/backend/global" "github.com/1Panel-dev/1Panel/backend/global"
"github.com/gin-gonic/gin" "github.com/gin-gonic/gin"
"github.com/pkg/errors" "github.com/pkg/errors"
"strconv"
) )
// @Tags Container // @Tags Container
@ -394,7 +395,7 @@ func (b *BaseApi) ContainerOperation(c *gin.Context) {
// @Success 200 {object} dto.ContainerStats // @Success 200 {object} dto.ContainerStats
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /containers/stats/:id [get] // @Router /containers/stats/{id} [get]
func (b *BaseApi) ContainerStats(c *gin.Context) { func (b *BaseApi) ContainerStats(c *gin.Context) {
containerID, ok := c.Params.Get("id") containerID, ok := c.Params.Get("id")
if !ok { if !ok {
@ -438,6 +439,7 @@ func (b *BaseApi) Inspect(c *gin.Context) {
// @Param since query string false "since" // @Param since query string false "since"
// @Param follow query string false "follow" // @Param follow query string false "follow"
// @Param tail query string false "tail" // @Param tail query string false "tail"
// @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /containers/search/log [post] // @Router /containers/search/log [post]
@ -464,6 +466,7 @@ func (b *BaseApi) ContainerLogs(c *gin.Context) {
// @Summary Download Container logs // @Summary Download Container logs
// @Accept json // @Accept json
// @Param request body dto.ContainerLog true "request" // @Param request body dto.ContainerLog true "request"
// @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /containers/download/log [post] // @Router /containers/download/log [post]
@ -680,6 +683,7 @@ func (b *BaseApi) ComposeUpdate(c *gin.Context) {
// @Param since query string false "date" // @Param since query string false "date"
// @Param follow query string false "follow" // @Param follow query string false "follow"
// @Param tail query string false "tail" // @Param tail query string false "tail"
// @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /containers/compose/search/log [get] // @Router /containers/compose/search/log [get]

View File

@ -34,7 +34,7 @@ func (b *BaseApi) LoadDashboardOsInfo(c *gin.Context) {
// @Success 200 {object} dto.DashboardBase // @Success 200 {object} dto.DashboardBase
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /dashboard/base/:ioOption/:netOption [get] // @Router /dashboard/base/{ioOption}/{netOption} [get]
func (b *BaseApi) LoadDashboardBaseInfo(c *gin.Context) { func (b *BaseApi) LoadDashboardBaseInfo(c *gin.Context) {
ioOption, ok := c.Params.Get("ioOption") ioOption, ok := c.Params.Get("ioOption")
if !ok { if !ok {
@ -78,7 +78,7 @@ func (b *BaseApi) LoadDashboardCurrentInfo(c *gin.Context) {
// @Success 200 // @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /dashboard/system/restart/:operation [post] // @Router /dashboard/system/restart/{operation} [post]
func (b *BaseApi) SystemRestart(c *gin.Context) { func (b *BaseApi) SystemRestart(c *gin.Context) {
operation, ok := c.Params.Get("operation") operation, ok := c.Params.Get("operation")
if !ok { if !ok {

View File

@ -93,10 +93,11 @@ func (b *BaseApi) SearchDatabase(c *gin.Context) {
// @Tags Database // @Tags Database
// @Summary List databases // @Summary List databases
// @Param type path string true "type"
// @Success 200 {array} dto.DatabaseOption // @Success 200 {array} dto.DatabaseOption
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /databases/db/list/:type [get] // @Router /databases/db/list/{type} [get]
func (b *BaseApi) ListDatabase(c *gin.Context) { func (b *BaseApi) ListDatabase(c *gin.Context) {
dbType, err := helper.GetStrParamByKey(c, "type") dbType, err := helper.GetStrParamByKey(c, "type")
if err != nil { if err != nil {
@ -114,10 +115,11 @@ func (b *BaseApi) ListDatabase(c *gin.Context) {
// @Tags Database // @Tags Database
// @Summary Retrieve database list based on type // @Summary Retrieve database list based on type
// @Param type path string true "type"
// @Success 200 {array} dto.DatabaseItem // @Success 200 {array} dto.DatabaseItem
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /databases/db/item/:type [get] // @Router /databases/db/item/{type} [get]
func (b *BaseApi) LoadDatabaseItems(c *gin.Context) { func (b *BaseApi) LoadDatabaseItems(c *gin.Context) {
dbType, err := helper.GetStrParamByKey(c, "type") dbType, err := helper.GetStrParamByKey(c, "type")
if err != nil { if err != nil {
@ -135,10 +137,11 @@ func (b *BaseApi) LoadDatabaseItems(c *gin.Context) {
// @Tags Database // @Tags Database
// @Summary Get databases // @Summary Get databases
// @Param name path string true "name"
// @Success 200 {object} dto.DatabaseInfo // @Success 200 {object} dto.DatabaseInfo
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /databases/db/:name [get] // @Router /databases/db/{name} [get]
func (b *BaseApi) GetDatabase(c *gin.Context) { func (b *BaseApi) GetDatabase(c *gin.Context) {
name, err := helper.GetStrParamByKey(c, "name") name, err := helper.GetStrParamByKey(c, "name")
if err != nil { if err != nil {

View File

@ -217,6 +217,7 @@ func (b *BaseApi) ListDBName(c *gin.Context) {
// @Summary Load mysql database from remote // @Summary Load mysql database from remote
// @Accept json // @Accept json
// @Param request body dto.MysqlLoadDB true "request" // @Param request body dto.MysqlLoadDB true "request"
// @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /databases/load [post] // @Router /databases/load [post]

View File

@ -168,9 +168,11 @@ func (b *BaseApi) SearchPostgresql(c *gin.Context) {
// @Summary Load postgresql database from remote // @Summary Load postgresql database from remote
// @Accept json // @Accept json
// @Param request body dto.PostgresqlLoadDB true "request" // @Param request body dto.PostgresqlLoadDB true "request"
// @Param database path string true "database"
// @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /databases/pg/:database/load [post] // @Router /databases/pg/{database}/load [post]
func (b *BaseApi) LoadPostgresqlDBFromRemote(c *gin.Context) { func (b *BaseApi) LoadPostgresqlDBFromRemote(c *gin.Context) {
database, err := helper.GetStrParamByKey(c, "database") database, err := helper.GetStrParamByKey(c, "database")
if err != nil { if err != nil {

View File

@ -28,7 +28,7 @@ func (b *BaseApi) LoadDeviceBaseInfo(c *gin.Context) {
// @Tags Device // @Tags Device
// @Summary list time zone options // @Summary list time zone options
// @Accept json // @Accept json
// @Success 200 {Array} string // @Success 200 {array} string
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /toolbox/device/zone/options [get] // @Router /toolbox/device/zone/options [get]

View File

@ -29,7 +29,7 @@ func (b *BaseApi) LoadFail2BanBaseInfo(c *gin.Context) {
// @Summary Page fail2ban ip list // @Summary Page fail2ban ip list
// @Accept json // @Accept json
// @Param request body dto.Fail2BanSearch true "request" // @Param request body dto.Fail2BanSearch true "request"
// @Success 200 {Array} string // @Success 200 {array} string
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /toolbox/fail2ban/search [post] // @Router /toolbox/fail2ban/search [post]
@ -52,6 +52,7 @@ func (b *BaseApi) SearchFail2Ban(c *gin.Context) {
// @Summary Operate fail2ban // @Summary Operate fail2ban
// @Accept json // @Accept json
// @Param request body dto.Operate true "request" // @Param request body dto.Operate true "request"
// @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /toolbox/fail2ban/operate [post] // @Router /toolbox/fail2ban/operate [post]
@ -74,6 +75,7 @@ func (b *BaseApi) OperateFail2Ban(c *gin.Context) {
// @Summary Operate sshd of fail2ban // @Summary Operate sshd of fail2ban
// @Accept json // @Accept json
// @Param request body dto.Operate true "request" // @Param request body dto.Operate true "request"
// @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /toolbox/fail2ban/operate/sshd [post] // @Router /toolbox/fail2ban/operate/sshd [post]

View File

@ -290,6 +290,7 @@ func (b *BaseApi) SaveContent(c *gin.Context) {
// @Tags File // @Tags File
// @Summary Upload file // @Summary Upload file
// @Accept multipart/form-data
// @Param file formData file true "request" // @Param file formData file true "request"
// @Success 200 // @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
@ -662,6 +663,7 @@ func mergeChunks(fileName string, fileDir string, dstDir string, chunkCount int,
// @Tags File // @Tags File
// @Summary Chunk upload file // @Summary Chunk upload file
// @Accept multipart/form-data
// @Param file formData file true "request" // @Param file formData file true "request"
// @Success 200 // @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth

View File

@ -55,6 +55,7 @@ func (b *BaseApi) LoadFtpLogInfo(c *gin.Context) {
// @Summary Operate FTP // @Summary Operate FTP
// @Accept json // @Accept json
// @Param request body dto.Operate true "request" // @Param request body dto.Operate true "request"
// @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /toolbox/ftp/operate [post] // @Router /toolbox/ftp/operate [post]

View File

@ -56,7 +56,7 @@ func (b *BaseApi) TestByInfo(c *gin.Context) {
// @Success 200 {boolean} connStatus // @Success 200 {boolean} connStatus
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /hosts/test/byid/:id [post] // @Router /hosts/test/byid/{id} [post]
func (b *BaseApi) TestByID(c *gin.Context) { func (b *BaseApi) TestByID(c *gin.Context) {
id, err := helper.GetParamID(c) id, err := helper.GetParamID(c)
if err != nil { if err != nil {

View File

@ -118,7 +118,7 @@ func (b *BaseApi) UpdateRuntime(c *gin.Context) {
// @Success 200 // @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /runtimes/:id [get] // @Router /runtimes/{id} [get]
func (b *BaseApi) GetRuntime(c *gin.Context) { func (b *BaseApi) GetRuntime(c *gin.Context) {
id, err := helper.GetIntParamByKey(c, "id") id, err := helper.GetIntParamByKey(c, "id")
if err != nil { if err != nil {

View File

@ -26,6 +26,7 @@ func (b *BaseApi) GetSSHInfo(c *gin.Context) {
// @Summary Operate SSH // @Summary Operate SSH
// @Accept json // @Accept json
// @Param request body dto.Operate true "request" // @Param request body dto.Operate true "request"
// @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /host/ssh/operate [post] // @Router /host/ssh/operate [post]

View File

@ -166,7 +166,7 @@ func (b *BaseApi) UpdateWebsite(c *gin.Context) {
// @Success 200 {object} response.WebsiteDTO // @Success 200 {object} response.WebsiteDTO
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /websites/:id [get] // @Router /websites/{id} [get]
func (b *BaseApi) GetWebsite(c *gin.Context) { func (b *BaseApi) GetWebsite(c *gin.Context) {
id, err := helper.GetParamID(c) id, err := helper.GetParamID(c)
if err != nil { if err != nil {
@ -185,10 +185,11 @@ func (b *BaseApi) GetWebsite(c *gin.Context) {
// @Summary Search website nginx by id // @Summary Search website nginx by id
// @Accept json // @Accept json
// @Param id path integer true "request" // @Param id path integer true "request"
// @Param type path string true "type"
// @Success 200 {object} response.FileInfo // @Success 200 {object} response.FileInfo
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /websites/:id/config/:type [get] // @Router /websites/{id}/config/{type} [get]
func (b *BaseApi) GetWebsiteNginx(c *gin.Context) { func (b *BaseApi) GetWebsiteNginx(c *gin.Context) {
id, err := helper.GetParamID(c) id, err := helper.GetParamID(c)
if err != nil { if err != nil {
@ -254,7 +255,7 @@ func (b *BaseApi) UpdateNginxConfig(c *gin.Context) {
// @Success 200 {object} response.WebsiteHTTPS // @Success 200 {object} response.WebsiteHTTPS
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /websites/:id/https [get] // @Router /websites/{id}/https [get]
func (b *BaseApi) GetHTTPSConfig(c *gin.Context) { func (b *BaseApi) GetHTTPSConfig(c *gin.Context) {
id, err := helper.GetParamID(c) id, err := helper.GetParamID(c)
if err != nil { if err != nil {
@ -272,11 +273,12 @@ func (b *BaseApi) GetHTTPSConfig(c *gin.Context) {
// @Tags Website HTTPS // @Tags Website HTTPS
// @Summary Update https conf // @Summary Update https conf
// @Accept json // @Accept json
// @Param id path integer true "request"
// @Param request body request.WebsiteHTTPSOp true "request" // @Param request body request.WebsiteHTTPSOp true "request"
// @Success 200 {object} response.WebsiteHTTPS // @Success 200 {object} response.WebsiteHTTPS
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /websites/:id/https [post] // @Router /websites/{id}/https [post]
// @x-panel-log {"bodyKeys":["websiteId"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"websiteId","isList":false,"db":"websites","output_column":"primary_domain","output_value":"domain"}],"formatZH":"更新网站 [domain] https 配置","formatEN":"Update website https [domain] conf"} // @x-panel-log {"bodyKeys":["websiteId"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"websiteId","isList":false,"db":"websites","output_column":"primary_domain","output_value":"domain"}],"formatZH":"更新网站 [domain] https 配置","formatEN":"Update website https [domain] conf"}
func (b *BaseApi) UpdateHTTPSConfig(c *gin.Context) { func (b *BaseApi) UpdateHTTPSConfig(c *gin.Context) {
var req request.WebsiteHTTPSOp var req request.WebsiteHTTPSOp
@ -386,7 +388,7 @@ func (b *BaseApi) ChangeDefaultServer(c *gin.Context) {
// @Success 200 {object} response.PHPConfig // @Success 200 {object} response.PHPConfig
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /websites/php/config/:id [get] // @Router /websites/php/config/{id} [get]
func (b *BaseApi) GetWebsitePHPConfig(c *gin.Context) { func (b *BaseApi) GetWebsitePHPConfig(c *gin.Context) {
id, err := helper.GetParamID(c) id, err := helper.GetParamID(c)
if err != nil { if err != nil {
@ -782,10 +784,11 @@ func (b *BaseApi) GetDirConfig(c *gin.Context) {
// @Tags Website // @Tags Website
// @Summary Get default html // @Summary Get default html
// @Accept json // @Accept json
// @Param type path string true "type"
// @Success 200 {object} response.FileInfo // @Success 200 {object} response.FileInfo
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /websites/default/html/:type [get] // @Router /websites/default/html/{type} [get]
func (b *BaseApi) GetDefaultHtml(c *gin.Context) { func (b *BaseApi) GetDefaultHtml(c *gin.Context) {
resourceType, err := helper.GetStrParamByKey(c, "type") resourceType, err := helper.GetStrParamByKey(c, "type")
if err != nil { if err != nil {

View File

@ -57,7 +57,7 @@ func (b *BaseApi) CreateWebDomain(c *gin.Context) {
// @Success 200 {array} model.WebsiteDomain // @Success 200 {array} model.WebsiteDomain
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /websites/domains/:websiteId [get] // @Router /websites/domains/{websiteId} [get]
func (b *BaseApi) GetWebDomains(c *gin.Context) { func (b *BaseApi) GetWebDomains(c *gin.Context) {
websiteId, err := helper.GetIntParamByKey(c, "websiteId") websiteId, err := helper.GetIntParamByKey(c, "websiteId")
if err != nil { if err != nil {

View File

@ -138,7 +138,7 @@ func (b *BaseApi) DeleteWebsiteSSL(c *gin.Context) {
// @Success 200 // @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /websites/ssl/website/:websiteId [get] // @Router /websites/ssl/website/{websiteId} [get]
func (b *BaseApi) GetWebsiteSSLByWebsiteId(c *gin.Context) { func (b *BaseApi) GetWebsiteSSLByWebsiteId(c *gin.Context) {
websiteId, err := helper.GetIntParamByKey(c, "websiteId") websiteId, err := helper.GetIntParamByKey(c, "websiteId")
if err != nil { if err != nil {
@ -160,7 +160,7 @@ func (b *BaseApi) GetWebsiteSSLByWebsiteId(c *gin.Context) {
// @Success 200 // @Success 200
// @Security ApiKeyAuth // @Security ApiKeyAuth
// @Security Timestamp // @Security Timestamp
// @Router /websites/ssl/:id [get] // @Router /websites/ssl/{id} [get]
func (b *BaseApi) GetWebsiteSSLById(c *gin.Context) { func (b *BaseApi) GetWebsiteSSLById(c *gin.Context) {
id, err := helper.GetParamID(c) id, err := helper.GetParamID(c)
if err != nil { if err != nil {

View File

@ -19,7 +19,7 @@ type Fail2BanSearch struct {
} }
type Fail2BanUpdate struct { type Fail2BanUpdate struct {
Key string `json:"key" validate:"required,oneof=port bantime findtime maxretry banaction logpath port"` Key string `json:"key" validate:"required,oneof=port bantime findtime maxretry banaction logpath"`
Value string `json:"value"` Value string `json:"value"`
} }

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff

View File

@ -34,6 +34,8 @@ definitions:
type: string type: string
apiKey: apiKey:
type: string type: string
apiKeyValidityTime:
type: string
ipWhiteList: ipWhiteList:
type: string type: string
type: object type: object
@ -384,6 +386,17 @@ definitions:
- command - command
- name - name
type: object type: object
dto.CommandTree:
properties:
children:
items:
$ref: '#/definitions/dto.CommandInfo'
type: array
id:
type: integer
label:
type: string
type: object
dto.CommonBackup: dto.CommonBackup:
properties: properties:
detailName: detailName:
@ -1362,7 +1375,6 @@ definitions:
- maxretry - maxretry
- banaction - banaction
- logpath - logpath
- port
type: string type: string
value: value:
type: string type: string
@ -1822,6 +1834,7 @@ definitions:
- zh - zh
- en - en
- tw - tw
- ru
type: string type: string
name: name:
type: string type: string
@ -2977,6 +2990,8 @@ definitions:
type: string type: string
apiKey: apiKey:
type: string type: string
apiKeyValidityTime:
type: string
appStoreLastModified: appStoreLastModified:
type: string type: string
appStoreSyncStatus: appStoreSyncStatus:
@ -5662,7 +5677,7 @@ info:
title: 1Panel title: 1Panel
version: "1.0" version: "1.0"
paths: paths:
/apps/:key: /apps/{key}:
get: get:
consumes: consumes:
- application/json - application/json
@ -5694,7 +5709,7 @@ paths:
summary: Get app list update summary: Get app list update
tags: tags:
- App - App
/apps/detail/:appId/:version/:type: /apps/detail/{appId}/{version}/{type}:
get: get:
consumes: consumes:
- application/json - application/json
@ -5711,7 +5726,7 @@ paths:
type: string type: string
- description: app type - description: app type
in: path in: path
name: version name: type
required: true required: true
type: string type: string
responses: responses:
@ -5725,14 +5740,14 @@ paths:
summary: Search app detail by appid summary: Search app detail by appid
tags: tags:
- App - App
/apps/details/:id: /apps/details/{id}:
get: get:
consumes: consumes:
- application/json - application/json
parameters: parameters:
- description: id - description: id
in: path in: path
name: appId name: id
required: true required: true
type: integer type: integer
responses: responses:
@ -5834,7 +5849,7 @@ paths:
summary: Search default config by key summary: Search default config by key
tags: tags:
- App - App
/apps/installed/conninfo/:key: /apps/installed/conninfo/{key}:
get: get:
consumes: consumes:
- application/json - application/json
@ -5845,6 +5860,11 @@ paths:
required: true required: true
schema: schema:
$ref: '#/definitions/dto.OperationWithNameAndType' $ref: '#/definitions/dto.OperationWithNameAndType'
- description: key
in: path
name: key
required: true
type: string
responses: responses:
"200": "200":
description: OK description: OK
@ -5856,7 +5876,7 @@ paths:
summary: Search app password by key summary: Search app password by key
tags: tags:
- App - App
/apps/installed/delete/check/:appInstallId: /apps/installed/delete/check/{appInstallId}:
get: get:
consumes: consumes:
- application/json - application/json
@ -5991,7 +6011,7 @@ paths:
formatEN: '[operate] App [appKey][appName]' formatEN: '[operate] App [appKey][appName]'
formatZH: '[operate] 应用 [appKey][appName]' formatZH: '[operate] 应用 [appKey][appName]'
paramKeys: [] paramKeys: []
/apps/installed/params/:appInstallId: /apps/installed/params/{appInstallId}:
get: get:
consumes: consumes:
- application/json - application/json
@ -6109,12 +6129,6 @@ paths:
post: post:
consumes: consumes:
- application/json - application/json
parameters:
- description: request
in: path
name: appInstallId
required: true
type: integer
responses: responses:
"200": "200":
description: OK description: OK
@ -6148,7 +6162,7 @@ paths:
summary: List apps summary: List apps
tags: tags:
- App - App
/apps/services/:key: /apps/services/{key}:
get: get:
consumes: consumes:
- application/json - application/json
@ -6447,7 +6461,9 @@ paths:
in: query in: query
name: tail name: tail
type: string type: string
responses: {} responses:
"200":
description: OK
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -6645,7 +6661,9 @@ paths:
required: true required: true
schema: schema:
$ref: '#/definitions/dto.ContainerLog' $ref: '#/definitions/dto.ContainerLog'
responses: {} responses:
"200":
description: OK
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -7469,14 +7487,16 @@ paths:
in: query in: query
name: tail name: tail
type: string type: string
responses: {} responses:
"200":
description: OK
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
summary: Container logs summary: Container logs
tags: tags:
- Container - Container
/containers/stats/:id: /containers/stats/{id}:
get: get:
parameters: parameters:
- description: container id - description: container id
@ -8071,7 +8091,7 @@ paths:
formatEN: update cronjob [name] formatEN: update cronjob [name]
formatZH: 更新计划任务 [name] formatZH: 更新计划任务 [name]
paramKeys: [] paramKeys: []
/dashboard/base/:ioOption/:netOption: /dashboard/base/{ioOption}/{netOption}:
get: get:
consumes: consumes:
- application/json - application/json
@ -8134,7 +8154,7 @@ paths:
summary: Load dashboard current info summary: Load dashboard current info
tags: tags:
- Dashboard - Dashboard
/dashboard/system/restart/:operation: /dashboard/system/restart/{operation}:
post: post:
consumes: consumes:
- application/json - application/json
@ -8372,8 +8392,14 @@ paths:
formatEN: create database [name][type] formatEN: create database [name][type]
formatZH: 创建远程数据库 [name][type] formatZH: 创建远程数据库 [name][type]
paramKeys: [] paramKeys: []
/databases/db/:name: /databases/db/{name}:
get: get:
parameters:
- description: name
in: path
name: name
required: true
type: string
responses: responses:
"200": "200":
description: OK description: OK
@ -8446,8 +8472,14 @@ paths:
formatEN: delete database [names] formatEN: delete database [names]
formatZH: 删除远程数据库 [names] formatZH: 删除远程数据库 [names]
paramKeys: [] paramKeys: []
/databases/db/item/:type: /databases/db/item/{type}:
get: get:
parameters:
- description: type
in: path
name: type
required: true
type: string
responses: responses:
"200": "200":
description: OK description: OK
@ -8461,8 +8493,14 @@ paths:
summary: Retrieve database list based on type summary: Retrieve database list based on type
tags: tags:
- Database - Database
/databases/db/list/:type: /databases/db/list/{type}:
get: get:
parameters:
- description: type
in: path
name: type
required: true
type: string
responses: responses:
"200": "200":
description: OK description: OK
@ -8627,7 +8665,9 @@ paths:
required: true required: true
schema: schema:
$ref: '#/definitions/dto.MysqlLoadDB' $ref: '#/definitions/dto.MysqlLoadDB'
responses: {} responses:
"200":
description: OK
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -8685,7 +8725,7 @@ paths:
formatEN: create postgresql database [name] formatEN: create postgresql database [name]
formatZH: 创建 postgresql 数据库 [name] formatZH: 创建 postgresql 数据库 [name]
paramKeys: [] paramKeys: []
/databases/pg/:database/load: /databases/pg/{database}/load:
post: post:
consumes: consumes:
- application/json - application/json
@ -8696,7 +8736,14 @@ paths:
required: true required: true
schema: schema:
$ref: '#/definitions/dto.PostgresqlLoadDB' $ref: '#/definitions/dto.PostgresqlLoadDB'
responses: {} - description: database
in: path
name: database
required: true
type: string
responses:
"200":
description: OK
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -9332,6 +9379,8 @@ paths:
paramKeys: [] paramKeys: []
/files/chunkupload: /files/chunkupload:
post: post:
consumes:
- multipart/form-data
parameters: parameters:
- description: request - description: request
in: formData in: formData
@ -9862,6 +9911,8 @@ paths:
- File - File
/files/upload: /files/upload:
post: post:
consumes:
- multipart/form-data
parameters: parameters:
- description: request - description: request
in: formData in: formData
@ -10152,7 +10203,9 @@ paths:
required: true required: true
schema: schema:
$ref: '#/definitions/dto.Operate' $ref: '#/definitions/dto.Operate'
responses: {} responses:
"200":
description: OK
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -10522,7 +10575,9 @@ paths:
"200": "200":
description: OK description: OK
schema: schema:
type: Array items:
$ref: '#/definitions/dto.RedisCommand'
type: array
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -10641,7 +10696,9 @@ paths:
"200": "200":
description: OK description: OK
schema: schema:
type: Array items:
$ref: '#/definitions/dto.CommandTree'
type: array
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -10892,7 +10949,7 @@ paths:
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
summary: Uodate address group summary: Update address group
tags: tags:
- Firewall - Firewall
/hosts/firewall/update/description: /hosts/firewall/update/description:
@ -10994,7 +11051,7 @@ paths:
summary: Page host summary: Page host
tags: tags:
- Host - Host
/hosts/test/byid/:id: /hosts/test/byid/{id}:
post: post:
consumes: consumes:
- application/json - application/json
@ -11394,7 +11451,7 @@ paths:
formatEN: Create runtime [name] formatEN: Create runtime [name]
formatZH: 创建运行环境 [name] formatZH: 创建运行环境 [name]
paramKeys: [] paramKeys: []
/runtimes/:id: /runtimes/{id}:
get: get:
consumes: consumes:
- application/json - application/json
@ -12879,7 +12936,9 @@ paths:
required: true required: true
schema: schema:
$ref: '#/definitions/dto.Operate' $ref: '#/definitions/dto.Operate'
responses: {} responses:
"200":
description: OK
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -12904,7 +12963,9 @@ paths:
required: true required: true
schema: schema:
$ref: '#/definitions/dto.OperateByID' $ref: '#/definitions/dto.OperateByID'
responses: {} responses:
"200":
description: OK
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -13254,7 +13315,9 @@ paths:
"200": "200":
description: OK description: OK
schema: schema:
type: Array items:
type: string
type: array
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -13298,7 +13361,9 @@ paths:
required: true required: true
schema: schema:
$ref: '#/definitions/dto.Operate' $ref: '#/definitions/dto.Operate'
responses: {} responses:
"200":
description: OK
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -13323,7 +13388,9 @@ paths:
required: true required: true
schema: schema:
$ref: '#/definitions/dto.Operate' $ref: '#/definitions/dto.Operate'
responses: {} responses:
"200":
description: OK
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -13345,7 +13412,9 @@ paths:
"200": "200":
description: OK description: OK
schema: schema:
type: Array items:
type: string
type: array
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -13507,7 +13576,9 @@ paths:
required: true required: true
schema: schema:
$ref: '#/definitions/dto.Operate' $ref: '#/definitions/dto.Operate'
responses: {} responses:
"200":
description: OK
security: security:
- ApiKeyAuth: [] - ApiKeyAuth: []
- Timestamp: [] - Timestamp: []
@ -13641,7 +13712,7 @@ paths:
formatEN: Create website [primaryDomain] formatEN: Create website [primaryDomain]
formatZH: 创建网站 [primaryDomain] formatZH: 创建网站 [primaryDomain]
paramKeys: [] paramKeys: []
/websites/:id: /websites/{id}:
get: get:
consumes: consumes:
- application/json - application/json
@ -13662,7 +13733,7 @@ paths:
summary: Search website by id summary: Search website by id
tags: tags:
- Website - Website
/websites/:id/config/:type: /websites/{id}/config/{type}:
get: get:
consumes: consumes:
- application/json - application/json
@ -13672,6 +13743,11 @@ paths:
name: id name: id
required: true required: true
type: integer type: integer
- description: type
in: path
name: type
required: true
type: string
responses: responses:
"200": "200":
description: OK description: OK
@ -13683,7 +13759,7 @@ paths:
summary: Search website nginx by id summary: Search website nginx by id
tags: tags:
- Website Nginx - Website Nginx
/websites/:id/https: /websites/{id}/https:
get: get:
consumes: consumes:
- application/json - application/json
@ -13708,6 +13784,11 @@ paths:
consumes: consumes:
- application/json - application/json
parameters: parameters:
- description: request
in: path
name: id
required: true
type: integer
- description: request - description: request
in: body in: body
name: request name: request
@ -14145,10 +14226,16 @@ paths:
formatEN: Nginx conf update [domain] formatEN: Nginx conf update [domain]
formatZH: nginx 配置修改 [domain] formatZH: nginx 配置修改 [domain]
paramKeys: [] paramKeys: []
/websites/default/html/:type: /websites/default/html/{type}:
get: get:
consumes: consumes:
- application/json - application/json
parameters:
- description: type
in: path
name: type
required: true
type: string
responses: responses:
"200": "200":
description: OK description: OK
@ -14478,7 +14565,7 @@ paths:
formatEN: Create domain [domain] formatEN: Create domain [domain]
formatZH: 创建域名 [domain] formatZH: 创建域名 [domain]
paramKeys: [] paramKeys: []
/websites/domains/:websiteId: /websites/domains/{websiteId}:
get: get:
consumes: consumes:
- application/json - application/json
@ -14740,7 +14827,7 @@ paths:
formatEN: '[domain] PHP conf update' formatEN: '[domain] PHP conf update'
formatZH: '[domain] PHP 配置修改' formatZH: '[domain] PHP 配置修改'
paramKeys: [] paramKeys: []
/websites/php/config/:id: /websites/php/config/{id}:
get: get:
consumes: consumes:
- application/json - application/json
@ -15103,7 +15190,7 @@ paths:
formatEN: Create website ssl [primaryDomain] formatEN: Create website ssl [primaryDomain]
formatZH: 创建网站 ssl [primaryDomain] formatZH: 创建网站 ssl [primaryDomain]
paramKeys: [] paramKeys: []
/websites/ssl/:id: /websites/ssl/{id}:
get: get:
consumes: consumes:
- application/json - application/json
@ -15325,7 +15412,7 @@ paths:
formatEN: Upload ssl [type] formatEN: Upload ssl [type]
formatZH: 上传 ssl [type] formatZH: 上传 ssl [type]
paramKeys: [] paramKeys: []
/websites/ssl/website/:websiteId: /websites/ssl/website/{websiteId}:
get: get:
consumes: consumes:
- application/json - application/json
@ -15385,7 +15472,7 @@ securityDefinitions:
-H "1Panel-Timestamp: <current_unix_timestamp>" -H "1Panel-Timestamp: <current_unix_timestamp>"
``` ```
- `1Panel-Token` is the key for the panel API Key. - `1Panel-Token` is the key for the panel API Key.
in: Header in: header
name: 1Panel-Token name: 1Panel-Token
type: apiKey type: apiKey
Timestamp: Timestamp:

View File

@ -4,9 +4,10 @@ import (
"fmt" "fmt"
"os" "os"
_ "net/http/pprof"
"github.com/1Panel-dev/1Panel/cmd/server/cmd" "github.com/1Panel-dev/1Panel/cmd/server/cmd"
_ "github.com/1Panel-dev/1Panel/cmd/server/docs" _ "github.com/1Panel-dev/1Panel/cmd/server/docs"
_ "net/http/pprof"
) )
// @title 1Panel // @title 1Panel
@ -28,7 +29,7 @@ import (
// @description ``` // @description ```
// @description - `1Panel-Token` is the key for the panel API Key. // @description - `1Panel-Token` is the key for the panel API Key.
// @type apiKey // @type apiKey
// @in Header // @in header
// @name 1Panel-Token // @name 1Panel-Token
// @securityDefinitions.apikey Timestamp // @securityDefinitions.apikey Timestamp