2024-08-07 13:52:34 +08:00
package v2
2024-07-23 14:48:37 +08:00
import (
2024-08-07 13:52:34 +08:00
"github.com/1Panel-dev/1Panel/agent/app/api/v2/helper"
2024-07-23 14:48:37 +08:00
"github.com/1Panel-dev/1Panel/agent/app/dto"
"github.com/1Panel-dev/1Panel/agent/app/dto/request"
"github.com/1Panel-dev/1Panel/agent/constant"
"github.com/gin-gonic/gin"
)
// @Tags Website
// @Summary Page websites
// @Description 获取网站列表分页
// @Accept json
// @Param request body request.WebsiteSearch true "request"
// @Success 200 {object} dto.PageResult
// @Security ApiKeyAuth
// @Router /websites/search [post]
func ( b * BaseApi ) PageWebsite ( c * gin . Context ) {
var req request . WebsiteSearch
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
total , websites , err := websiteService . PageWebsite ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , dto . PageResult {
Total : total ,
Items : websites ,
} )
}
// @Tags Website
// @Summary List websites
// @Description 获取网站列表
// @Success 200 {array} response.WebsiteDTO
// @Security ApiKeyAuth
// @Router /websites/list [get]
func ( b * BaseApi ) GetWebsites ( c * gin . Context ) {
websites , err := websiteService . GetWebsites ( )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , websites )
}
// @Tags Website
// @Summary List website names
// @Description 获取网站列表
// @Success 200 {array} string
// @Security ApiKeyAuth
2024-08-12 17:08:52 +08:00
// @Router /websites/options [post]
2024-07-23 14:48:37 +08:00
func ( b * BaseApi ) GetWebsiteOptions ( c * gin . Context ) {
2024-08-12 17:08:52 +08:00
var req request . WebsiteOptionReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
websites , err := websiteService . GetWebsiteOptions ( req )
2024-07-23 14:48:37 +08:00
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , websites )
}
// @Tags Website
// @Summary Create website
// @Description 创建网站
// @Accept json
// @Param request body request.WebsiteCreate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites [post]
// @x-panel-log {"bodyKeys":["primaryDomain"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"创建网站 [primaryDomain]","formatEN":"Create website [primaryDomain]"}
func ( b * BaseApi ) CreateWebsite ( c * gin . Context ) {
var req request . WebsiteCreate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
err := websiteService . CreateWebsite ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
// @Tags Website
// @Summary Operate website
// @Description 操作网站
// @Accept json
// @Param request body request.WebsiteOp true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/operate [post]
// @x-panel-log {"bodyKeys":["id", "operate"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"websites","output_column":"primary_domain","output_value":"domain"}],"formatZH":"[operate] 网站 [domain]","formatEN":"[operate] website [domain]"}
func ( b * BaseApi ) OpWebsite ( c * gin . Context ) {
var req request . WebsiteOp
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
err := websiteService . OpWebsite ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
// @Tags Website
// @Summary Delete website
// @Description 删除网站
// @Accept json
// @Param request body request.WebsiteDelete true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/del [post]
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"websites","output_column":"primary_domain","output_value":"domain"}],"formatZH":"删除网站 [domain]","formatEN":"Delete website [domain]"}
func ( b * BaseApi ) DeleteWebsite ( c * gin . Context ) {
var req request . WebsiteDelete
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
err := websiteService . DeleteWebsite ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
// @Tags Website
// @Summary Update website
// @Description 更新网站
// @Accept json
// @Param request body request.WebsiteUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/update [post]
// @x-panel-log {"bodyKeys":["primaryDomain"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"更新网站 [primaryDomain]","formatEN":"Update website [primaryDomain]"}
func ( b * BaseApi ) UpdateWebsite ( c * gin . Context ) {
var req request . WebsiteUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateWebsite ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
// @Tags Website
// @Summary Search website by id
// @Description 通过 id 查询网站
// @Accept json
// @Param id path integer true "request"
// @Success 200 {object} response.WebsiteDTO
// @Security ApiKeyAuth
// @Router /websites/:id [get]
func ( b * BaseApi ) GetWebsite ( c * gin . Context ) {
id , err := helper . GetParamID ( c )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrBadRequest , constant . ErrTypeInternalServer , nil )
return
}
website , err := websiteService . GetWebsite ( id )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , website )
}
// @Tags Website Nginx
// @Summary Search website nginx by id
// @Description 通过 id 查询网站 nginx
// @Accept json
// @Param id path integer true "request"
// @Success 200 {object} response.FileInfo
// @Security ApiKeyAuth
// @Router /websites/:id/config/:type [get]
func ( b * BaseApi ) GetWebsiteNginx ( c * gin . Context ) {
id , err := helper . GetParamID ( c )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrBadRequest , constant . ErrTypeInternalServer , nil )
return
}
configType := c . Param ( "type" )
fileInfo , err := websiteService . GetWebsiteNginxConfig ( id , configType )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , fileInfo )
}
// @Tags Website Nginx
// @Summary Load nginx conf
// @Description 获取 nginx 配置
// @Accept json
// @Param request body request.NginxScopeReq true "request"
// @Success 200 {object} response.WebsiteNginxConfig
// @Security ApiKeyAuth
// @Router /websites/config [post]
func ( b * BaseApi ) GetNginxConfig ( c * gin . Context ) {
var req request . NginxScopeReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
config , err := websiteService . GetNginxConfigByScope ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , config )
}
// @Tags Website Nginx
// @Summary Update nginx conf
// @Description 更新 nginx 配置
// @Accept json
// @Param request body request.NginxConfigUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/config/update [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":"nginx 配置修改 [domain]","formatEN":"Nginx conf update [domain]"}
func ( b * BaseApi ) UpdateNginxConfig ( c * gin . Context ) {
var req request . NginxConfigUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateNginxConfigByScope ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
// @Tags Website HTTPS
// @Summary Load https conf
// @Description 获取 https 配置
// @Accept json
// @Param id path integer true "request"
// @Success 200 {object} response.WebsiteHTTPS
// @Security ApiKeyAuth
// @Router /websites/:id/https [get]
func ( b * BaseApi ) GetHTTPSConfig ( c * gin . Context ) {
id , err := helper . GetParamID ( c )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrBadRequest , constant . ErrTypeInternalServer , nil )
return
}
res , err := websiteService . GetWebsiteHTTPS ( id )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website HTTPS
// @Summary Update https conf
// @Description 更新 https 配置
// @Accept json
// @Param request body request.WebsiteHTTPSOp true "request"
// @Success 200 {object} response.WebsiteHTTPS
// @Security ApiKeyAuth
// @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"}
func ( b * BaseApi ) UpdateHTTPSConfig ( c * gin . Context ) {
var req request . WebsiteHTTPSOp
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
tx , ctx := helper . GetTxAndContext ( )
res , err := websiteService . OpWebsiteHTTPS ( ctx , req )
if err != nil {
tx . Rollback ( )
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
tx . Commit ( )
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Check before create website
// @Description 网站创建前检查
// @Accept json
// @Param request body request.WebsiteInstallCheckReq true "request"
// @Success 200 {array} response.WebsitePreInstallCheck
// @Security ApiKeyAuth
// @Router /websites/check [post]
func ( b * BaseApi ) CreateWebsiteCheck ( c * gin . Context ) {
var req request . WebsiteInstallCheckReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
data , err := websiteService . PreInstallCheck ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , data )
}
// @Tags Website Nginx
// @Summary Update website nginx conf
// @Description 更新 网站 nginx 配置
// @Accept json
// @Param request body request.WebsiteNginxUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/nginx/update [post]
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"websites","output_column":"primary_domain","output_value":"domain"}],"formatZH":"[domain] Nginx 配置修改","formatEN":"[domain] Nginx conf update"}
func ( b * BaseApi ) UpdateWebsiteNginxConfig ( c * gin . Context ) {
var req request . WebsiteNginxUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateNginxConfigFile ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
// @Tags Website
// @Summary Operate website log
// @Description 操作网站日志
// @Accept json
// @Param request body request.WebsiteLogReq true "request"
// @Success 200 {object} response.WebsiteLog
// @Security ApiKeyAuth
// @Router /websites/log [post]
// @x-panel-log {"bodyKeys":["id", "operate"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"websites","output_column":"primary_domain","output_value":"domain"}],"formatZH":"[domain][operate] 日志","formatEN":"[domain][operate] logs"}
func ( b * BaseApi ) OpWebsiteLog ( c * gin . Context ) {
var req request . WebsiteLogReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
res , err := websiteService . OpWebsiteLog ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Change default server
// @Description 操作网站日志
// @Accept json
// @Param request body request.WebsiteDefaultUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/default/server [post]
// @x-panel-log {"bodyKeys":["id", "operate"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"websites","output_column":"primary_domain","output_value":"domain"}],"formatZH":"修改默认 server => [domain]","formatEN":"Change default server => [domain]"}
func ( b * BaseApi ) ChangeDefaultServer ( c * gin . Context ) {
var req request . WebsiteDefaultUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . ChangeDefaultServer ( req . ID ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
// @Tags Website PHP
// @Summary Update php version
// @Description 变更 php 版本
// @Accept json
// @Param request body request.WebsitePHPVersionReq true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/php/version [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":"php 版本变更 [domain]","formatEN":"php version update [domain]"}
func ( b * BaseApi ) ChangePHPVersion ( c * gin . Context ) {
var req request . WebsitePHPVersionReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . ChangePHPVersion ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary Get rewrite conf
// @Description 获取伪静态配置
// @Accept json
// @Param request body request.NginxRewriteReq true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/rewrite [post]
func ( b * BaseApi ) GetRewriteConfig ( c * gin . Context ) {
var req request . NginxRewriteReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
res , err := websiteService . GetRewriteConfig ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Update rewrite conf
// @Description 更新伪静态配置
// @Accept json
// @Param request body request.NginxRewriteUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/rewrite/update [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]","formatEN":"Nginx conf rewrite update [domain]"}
func ( b * BaseApi ) UpdateRewriteConfig ( c * gin . Context ) {
var req request . NginxRewriteUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateRewriteConfig ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
// @Tags Website
// @Summary Update Site Dir
// @Description 更新网站目录
// @Accept json
// @Param request body request.WebsiteUpdateDir true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/dir/update [post]
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"websites","output_column":"primary_domain","output_value":"domain"}],"formatZH":"更新网站 [domain] 目录","formatEN":"Update domain [domain] dir"}
func ( b * BaseApi ) UpdateSiteDir ( c * gin . Context ) {
var req request . WebsiteUpdateDir
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateSiteDir ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary Update Site Dir permission
// @Description 更新网站目录权限
// @Accept json
// @Param request body request.WebsiteUpdateDirPermission true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/dir/permission [post]
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"websites","output_column":"primary_domain","output_value":"domain"}],"formatZH":"更新网站 [domain] 目录权限","formatEN":"Update domain [domain] dir permission"}
func ( b * BaseApi ) UpdateSiteDirPermission ( c * gin . Context ) {
var req request . WebsiteUpdateDirPermission
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateSitePermission ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary Get proxy conf
// @Description 获取反向代理配置
// @Accept json
// @Param request body request.WebsiteProxyReq true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/proxies [post]
func ( b * BaseApi ) GetProxyConfig ( c * gin . Context ) {
var req request . WebsiteProxyReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
res , err := websiteService . GetProxies ( req . ID )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Update proxy conf
// @Description 修改反向代理配置
// @Accept json
// @Param request body request.WebsiteProxyConfig true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/proxies/update [post]
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"websites","output_column":"primary_domain","output_value":"domain"}],"formatZH":"修改网站 [domain] 反向代理配置 ","formatEN":"Update domain [domain] proxy config"}
func ( b * BaseApi ) UpdateProxyConfig ( c * gin . Context ) {
var req request . WebsiteProxyConfig
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
err := websiteService . OperateProxy ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary Update proxy file
// @Description 更新反向代理文件
// @Accept json
// @Param request body request.NginxProxyUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/proxy/file [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]","formatEN":"Nginx conf proxy file update [domain]"}
func ( b * BaseApi ) UpdateProxyConfigFile ( c * gin . Context ) {
var req request . NginxProxyUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateProxyFile ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary Get AuthBasic conf
// @Description 获取密码访问配置
// @Accept json
// @Param request body request.NginxAuthReq true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/auths [post]
func ( b * BaseApi ) GetAuthConfig ( c * gin . Context ) {
var req request . NginxAuthReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
res , err := websiteService . GetAuthBasics ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Get AuthBasic conf
// @Description 更新密码访问配置
// @Accept json
// @Param request body request.NginxAuthUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/auths/update [post]
func ( b * BaseApi ) UpdateAuthConfig ( c * gin . Context ) {
var req request . NginxAuthUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateAuthBasic ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
2024-08-09 18:00:39 +08:00
// @Tags Website
// @Summary Get AuthBasic conf
// @Description 获取路由密码访问配置
// @Accept json
// @Param request body request.NginxAuthReq true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/auths/path [post]
func ( b * BaseApi ) GetPathAuthConfig ( c * gin . Context ) {
var req request . NginxAuthReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
res , err := websiteService . GetPathAuthBasics ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Get AuthBasic conf
// @Description 更新路由密码访问配置
// @Accept json
// @Param request body request.NginxPathAuthUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/auths/path/update [post]
func ( b * BaseApi ) UpdatePathAuthConfig ( c * gin . Context ) {
var req request . NginxPathAuthUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdatePathAuthBasic ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
2024-07-23 14:48:37 +08:00
// @Tags Website
// @Summary Get AntiLeech conf
// @Description 获取防盗链配置
// @Accept json
// @Param request body request.NginxCommonReq true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/leech [post]
func ( b * BaseApi ) GetAntiLeech ( c * gin . Context ) {
var req request . NginxCommonReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
res , err := websiteService . GetAntiLeech ( req . WebsiteID )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Update AntiLeech
// @Description 更新防盗链配置
// @Accept json
// @Param request body request.NginxAntiLeechUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/leech/update [post]
func ( b * BaseApi ) UpdateAntiLeech ( c * gin . Context ) {
var req request . NginxAntiLeechUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateAntiLeech ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary Update redirect conf
// @Description 修改重定向配置
// @Accept json
// @Param request body request.NginxRedirectReq true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/redirect/update [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] 重定向理配置 ","formatEN":"Update domain [domain] redirect config"}
func ( b * BaseApi ) UpdateRedirectConfig ( c * gin . Context ) {
var req request . NginxRedirectReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
err := websiteService . OperateRedirect ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary Get redirect conf
// @Description 获取重定向配置
// @Accept json
// @Param request body request.WebsiteProxyReq true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/redirect [post]
func ( b * BaseApi ) GetRedirectConfig ( c * gin . Context ) {
var req request . WebsiteRedirectReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
res , err := websiteService . GetRedirect ( req . WebsiteID )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Update redirect file
// @Description 更新重定向文件
// @Accept json
// @Param request body request.NginxRedirectUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/redirect/file [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]","formatEN":"Nginx conf redirect file update [domain]"}
func ( b * BaseApi ) UpdateRedirectConfigFile ( c * gin . Context ) {
var req request . NginxRedirectUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateRedirectFile ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary Get website dir
// @Description 获取网站目录配置
// @Accept json
// @Param request body request.WebsiteCommonReq true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/dir [post]
func ( b * BaseApi ) GetDirConfig ( c * gin . Context ) {
var req request . WebsiteCommonReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
res , err := websiteService . LoadWebsiteDirConfig ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Get default html
// @Description 获取默认 html
// @Accept json
// @Success 200 {object} response.FileInfo
// @Security ApiKeyAuth
// @Router /websites/default/html/:type [get]
func ( b * BaseApi ) GetDefaultHtml ( c * gin . Context ) {
resourceType , err := helper . GetStrParamByKey ( c , "type" )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrBadRequest , constant . ErrTypeInternalServer , nil )
return
}
fileInfo , err := websiteService . GetDefaultHtml ( resourceType )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , fileInfo )
}
// @Tags Website
// @Summary Update default html
// @Description 更新默认 html
// @Accept json
// @Param request body request.WebsiteHtmlUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/default/html/update [post]
// @x-panel-log {"bodyKeys":["type"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"更新默认 html","formatEN":"Update default html"}
func ( b * BaseApi ) UpdateDefaultHtml ( c * gin . Context ) {
var req request . WebsiteHtmlUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateDefaultHtml ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
2024-08-15 23:15:29 +08:00
// @Tags Website
// @Summary Get website upstreams
// @Description 获取网站 upstreams
// @Accept json
// @Param request body request.WebsiteCommonReq true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/lbs [get]
func ( b * BaseApi ) GetLoadBalances ( c * gin . Context ) {
id , err := helper . GetParamID ( c )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrBadRequest , constant . ErrTypeInternalServer , nil )
return
}
res , err := websiteService . GetLoadBalances ( id )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Create website upstream
// @Description 创建网站 upstream
// @Accept json
// @Param request body request.WebsiteLBCreate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/lbs/create [post]
func ( b * BaseApi ) CreateLoadBalance ( c * gin . Context ) {
var req request . WebsiteLBCreate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . CreateLoadBalance ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary Delete website upstream
// @Description 删除网站 upstream
// @Accept json
// @Param request body request.WebsiteLBDelete true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/lbs/delete [post]
func ( b * BaseApi ) DeleteLoadBalance ( c * gin . Context ) {
var req request . WebsiteLBDelete
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . DeleteLoadBalance ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
2024-08-16 18:09:00 +08:00
// @Tags Website
// @Summary Update website upstream
// @Description 更新网站 upstream
// @Accept json
// @Param request body request.WebsiteLBUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/lbs/update [post]
func ( b * BaseApi ) UpdateLoadBalance ( c * gin . Context ) {
var req request . WebsiteLBUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateLoadBalance ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary Update website upstream file
// @Description 更新网站 upstream 文件
// @Accept json
// @Param request body request.WebsiteLBUpdateFile true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/lbs/file [post]
func ( b * BaseApi ) UpdateLoadBalanceFile ( c * gin . Context ) {
var req request . WebsiteLBUpdateFile
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateLoadBalanceFile ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
2024-08-19 18:04:43 +08:00
func ( b * BaseApi ) ChangeWebsiteGroup ( c * gin . Context ) {
var req dto . UpdateGroup
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . ChangeGroup ( req . Group , req . NewGroup ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
2024-09-12 18:06:22 +08:00
// @Tags Website
// @Summary update website proxy cache config
// @Description 更新网站反代缓存配置
// @Accept json
// @Param request body request.NginxProxyCacheUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/proxy/config [post]
func ( b * BaseApi ) UpdateProxyCache ( c * gin . Context ) {
var req request . NginxProxyCacheUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . UpdateProxyCache ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Summary Get website proxy cache config
// @Description 获取网站反代缓存配置
// @Accept json
// @Param id path int true "id"
// @Success 200 {object} response.NginxProxyCache
// @Security ApiKeyAuth
// @Router /websites/proxy/config/{id} [get]
func ( b * BaseApi ) GetProxyCache ( c * gin . Context ) {
id , err := helper . GetParamID ( c )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrBadRequest , constant . ErrTypeInternalServer , nil )
return
}
res , err := websiteService . GetProxyCache ( id )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
2024-09-13 18:42:27 +08:00
// @Tags Website
// @Summary Set Real IP
// @Description 设置真实IP
// @Accept json
// @Param request body request.WebsiteRealIP true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/realip [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] 网站真实IP配置 ","formatEN":"Modify the real IP configuration of [domain] website"}
func ( b * BaseApi ) SetRealIPConfig ( c * gin . Context ) {
var req request . WebsiteRealIP
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . SetRealIPConfig ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary Get Real IP Config
// @Description 获取真实 IP 配置
// @Accept json
// @Param id path int true "id"
// @Success 200 {object} response.WebsiteRealIP
// @Security ApiKeyAuth
// @Router /websites/realip/config/{id} [get]
func ( b * BaseApi ) GetRealIPConfig ( c * gin . Context ) {
id , err := helper . GetParamID ( c )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrBadRequest , constant . ErrTypeInternalServer , nil )
return
}
res , err := websiteService . GetRealIPConfig ( id )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
2024-09-26 21:59:32 +08:00
// @Tags Website
// @Summary Get website resource
// @Description 获取网站资源
// @Accept json
// @Param id path int true "id"
2024-10-28 18:52:05 +08:00
// @Success 200 {object} response.Resource
2024-09-26 21:59:32 +08:00
// @Security ApiKeyAuth
// @Router /websites/resource/{id} [get]
func ( b * BaseApi ) GetWebsiteResource ( c * gin . Context ) {
id , err := helper . GetParamID ( c )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrBadRequest , constant . ErrTypeInternalServer , nil )
return
}
res , err := websiteService . GetWebsiteResource ( id )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Get databases
// @Description 获取数据库列表
// @Accept json
2024-10-28 18:52:05 +08:00
// @Success 200 {object} response.Database
2024-09-26 21:59:32 +08:00
// @Security ApiKeyAuth
// @Router /websites/databases [get]
func ( b * BaseApi ) GetWebsiteDatabase ( c * gin . Context ) {
res , err := websiteService . ListDatabases ( )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website
// @Summary Change website database
// @Description 切换网站数据库
// @Accept json
// @Param request body request.ChangeDatabase true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/databases [post]
func ( b * BaseApi ) ChangeWebsiteDatabase ( c * gin . Context ) {
var req request . ChangeDatabase
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . ChangeDatabase ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
2024-10-09 21:56:58 +08:00
// @Tags Website
// @Summary Operate custom rewrite
// @Description 编辑自定义重写模版
// @Accept json
// @Param request body request.CustomRewriteOperate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /websites/rewrite/custom [post]
func ( b * BaseApi ) OperateCustomRewrite ( c * gin . Context ) {
var req request . CustomRewriteOperate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteService . OperateCustomRewrite ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website
// @Summary List custom rewrite
// @Description 获取自定义重写模版列表
// @Accept json
// @Success 200 {object} []string
// @Security ApiKeyAuth
// @Router /websites/rewrite/custom [get]
func ( b * BaseApi ) ListCustomRewrite ( c * gin . Context ) {
res , err := websiteService . ListCustomRewrite ( )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}