2023-11-27 12:04:09 +08:00
package v1
import (
"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/request"
"github.com/1Panel-dev/1Panel/backend/constant"
"github.com/gin-gonic/gin"
2024-07-04 16:02:34 +08:00
"net/http"
"net/url"
"strconv"
2023-11-27 12:04:09 +08:00
)
// @Tags Website CA
// @Summary Page website ca
// @Accept json
// @Param request body request.WebsiteCASearch true "request"
// @Success 200 {object} dto.PageResult
// @Security ApiKeyAuth
2024-12-09 17:57:34 +08:00
// @Security Timestamp
2023-11-27 12:04:09 +08:00
// @Router /websites/ca/search [post]
func ( b * BaseApi ) PageWebsiteCA ( c * gin . Context ) {
var req request . WebsiteCASearch
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
total , cas , err := websiteCAService . Page ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , dto . PageResult {
Total : total ,
Items : cas ,
} )
}
// @Tags Website CA
// @Summary Create website ca
// @Accept json
// @Param request body request.WebsiteCACreate true "request"
// @Success 200 {object} request.WebsiteCACreate
// @Security ApiKeyAuth
2024-12-09 17:57:34 +08:00
// @Security Timestamp
2023-11-27 12:04:09 +08:00
// @Router /websites/ca [post]
// @x-panel-log {"bodyKeys":["name"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"创建网站 ca [name]","formatEN":"Create website ca [name]"}
func ( b * BaseApi ) CreateWebsiteCA ( c * gin . Context ) {
var req request . WebsiteCACreate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
res , err := websiteCAService . Create ( req )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website CA
// @Summary Get website ca
// @Accept json
// @Param id path int true "id"
// @Success 200 {object} response.WebsiteCADTO
// @Security ApiKeyAuth
2024-12-09 17:57:34 +08:00
// @Security Timestamp
2023-11-27 12:04:09 +08:00
// @Router /websites/ca/{id} [get]
func ( b * BaseApi ) GetWebsiteCA ( c * gin . Context ) {
id , err := helper . GetParamID ( c )
if err != nil {
return
}
res , err := websiteCAService . GetCA ( id )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , res )
}
// @Tags Website CA
// @Summary Delete website ca
// @Accept json
// @Param request body request.WebsiteCommonReq true "request"
// @Success 200
// @Security ApiKeyAuth
2024-12-09 17:57:34 +08:00
// @Security Timestamp
2023-11-27 12:04:09 +08:00
// @Router /websites/ca/del [post]
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"website_cas","output_column":"name","output_value":"name"}],"formatZH":"删除网站 ca [name]","formatEN":"Delete website ca [name]"}
func ( b * BaseApi ) DeleteWebsiteCA ( c * gin . Context ) {
var req request . WebsiteCommonReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := websiteCAService . Delete ( req . ID ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
// @Tags Website CA
// @Summary Obtain SSL
// @Accept json
// @Param request body request.WebsiteCAObtain true "request"
// @Success 200
// @Security ApiKeyAuth
2024-12-09 17:57:34 +08:00
// @Security Timestamp
2023-11-27 12:04:09 +08:00
// @Router /websites/ca/obtain [post]
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"website_cas","output_column":"name","output_value":"name"}],"formatZH":"自签 SSL 证书 [name]","formatEN":"Obtain SSL [name]"}
func ( b * BaseApi ) ObtainWebsiteCA ( c * gin . Context ) {
var req request . WebsiteCAObtain
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
2023-11-29 22:04:08 +08:00
if _ , err := websiteCAService . ObtainSSL ( req ) ; err != nil {
2023-11-27 12:04:09 +08:00
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
2023-11-27 18:36:10 +08:00
// @Tags Website CA
2024-11-30 19:44:50 +08:00
// @Summary Renew Obtain SSL
2023-11-27 18:36:10 +08:00
// @Accept json
// @Param request body request.WebsiteCAObtain true "request"
// @Success 200
// @Security ApiKeyAuth
2024-12-09 17:57:34 +08:00
// @Security Timestamp
2023-12-15 18:14:09 +08:00
// @Router /websites/ca/renew [post]
2023-11-27 18:36:10 +08:00
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"website_cas","output_column":"name","output_value":"name"}],"formatZH":"自签 SSL 证书 [name]","formatEN":"Obtain SSL [name]"}
func ( b * BaseApi ) RenewWebsiteCA ( c * gin . Context ) {
var req request . WebsiteCARenew
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
2023-11-29 22:04:08 +08:00
if _ , err := websiteCAService . ObtainSSL ( request . WebsiteCAObtain {
2023-11-27 18:36:10 +08:00
SSLID : req . SSLID ,
Renew : true ,
Unit : "year" ,
Time : 1 ,
} ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithOutData ( c )
}
2024-07-04 16:02:34 +08:00
// @Tags Website CA
// @Summary Download CA file
// @Accept json
// @Param request body request.WebsiteResourceReq true "request"
// @Success 200
// @Security ApiKeyAuth
2024-12-09 17:57:34 +08:00
// @Security Timestamp
2024-07-04 16:02:34 +08:00
// @Router /websites/ca/download [post]
// @x-panel-log {"bodyKeys":["id"],"paramKeys":[],"BeforeFunctions":[{"input_column":"id","input_value":"id","isList":false,"db":"website_cas","output_column":"name","output_value":"name"}],"formatZH":"下载 CA 证书文件 [name]","formatEN":"download ca file [name]"}
func ( b * BaseApi ) DownloadCAFile ( c * gin . Context ) {
var req request . WebsiteResourceReq
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
file , err := websiteCAService . DownloadFile ( req . ID )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
defer file . Close ( )
info , err := file . Stat ( )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
c . Header ( "Content-Length" , strconv . FormatInt ( info . Size ( ) , 10 ) )
c . Header ( "Content-Disposition" , "attachment; filename*=utf-8''" + url . PathEscape ( info . Name ( ) ) )
http . ServeContent ( c . Writer , c . Request , info . Name ( ) , info . ModTime ( ) , file )
}