2022-09-15 02:44:43 +00:00
package v1
import (
2024-05-29 03:05:09 +00:00
"encoding/base64"
2022-09-14 15:27:17 +00:00
"errors"
2023-08-02 14:36:37 +00:00
"os"
"path"
2022-09-14 15:27:17 +00:00
2022-10-17 08:32:31 +00:00
"github.com/1Panel-dev/1Panel/backend/app/api/v1/helper"
"github.com/1Panel-dev/1Panel/backend/app/dto"
"github.com/1Panel-dev/1Panel/backend/constant"
"github.com/1Panel-dev/1Panel/backend/global"
"github.com/1Panel-dev/1Panel/backend/utils/mfa"
2022-09-15 02:44:43 +00:00
"github.com/gin-gonic/gin"
)
2023-01-04 14:31:51 +00:00
// @Tags System Setting
// @Summary Load system setting info
// @Success 200 {object} dto.SettingInfo
// @Security ApiKeyAuth
// @Router /settings/search [post]
2022-09-15 02:44:43 +00:00
func ( b * BaseApi ) GetSettingInfo ( c * gin . Context ) {
setting , err := settingService . GetSettingInfo ( )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , setting )
}
2023-01-31 07:22:05 +00:00
// @Tags System Setting
// @Summary Load system available status
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/search/available [get]
func ( b * BaseApi ) GetSystemAvailable ( c * gin . Context ) {
helper . SuccessWithData ( c , nil )
}
2023-01-04 14:31:51 +00:00
// @Tags System Setting
// @Summary Update system setting
// @Accept json
// @Param request body dto.SettingUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/update [post]
2023-10-07 07:46:44 +00:00
// @x-panel-log {"bodyKeys":["key","value"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"修改系统配置 [key] => [value]","formatEN":"update system setting [key] => [value]"}
2022-09-09 09:17:02 +00:00
func ( b * BaseApi ) UpdateSetting ( c * gin . Context ) {
2022-09-15 02:44:43 +00:00
var req dto . SettingUpdate
2023-10-27 06:19:26 +00:00
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
2022-09-15 02:44:43 +00:00
return
}
2023-02-10 10:07:29 +00:00
if err := settingService . Update ( req . Key , req . Value ) ; err != nil {
2022-09-08 10:47:15 +00:00
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
2023-04-17 03:12:43 +00:00
return
}
helper . SuccessWithData ( c , nil )
}
2024-05-29 03:05:09 +00:00
// @Tags System Setting
// @Summary Update proxy setting
// @Accept json
// @Param request body dto.ProxyUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/proxy/update [post]
// @x-panel-log {"bodyKeys":["proxyUrl","proxyPort"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"服务器代理配置 [proxyPort]:[proxyPort]","formatEN":"set proxy [proxyPort]:[proxyPort]."}
func ( b * BaseApi ) UpdateProxy ( c * gin . Context ) {
var req dto . ProxyUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if len ( req . ProxyPasswd ) != 0 && len ( req . ProxyType ) != 0 {
pass , err := base64 . StdEncoding . DecodeString ( req . ProxyPasswd )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrBadRequest , constant . ErrTypeInvalidParams , err )
return
}
req . ProxyPasswd = string ( pass )
}
if err := settingService . UpdateProxy ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
2024-04-08 08:52:07 +00:00
// @Tags System Setting
// @Summary Update system setting
// @Accept json
// @Param request body dto.SettingUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/menu/update [post]
2024-04-11 09:16:10 +00:00
// @x-panel-log {"bodyKeys":[],"paramKeys":[],"BeforeFunctions":[],"formatZH":"隐藏高级功能菜单","formatEN":"Hide advanced feature menu."}
2024-04-08 08:52:07 +00:00
func ( b * BaseApi ) UpdateMenu ( c * gin . Context ) {
var req dto . SettingUpdate
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := settingService . Update ( req . Key , req . Value ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
2023-01-04 14:31:51 +00:00
// @Tags System Setting
// @Summary Update system password
// @Accept json
// @Param request body dto.PasswordUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/password/update [post]
2023-10-07 07:46:44 +00:00
// @x-panel-log {"bodyKeys":[],"paramKeys":[],"BeforeFunctions":[],"formatZH":"修改系统密码","formatEN":"update system password"}
2022-09-08 10:47:15 +00:00
func ( b * BaseApi ) UpdatePassword ( c * gin . Context ) {
var req dto . PasswordUpdate
2023-10-27 06:19:26 +00:00
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
2022-09-08 10:47:15 +00:00
return
}
if err := settingService . UpdatePassword ( c , req . OldPassword , req . NewPassword ) ; err != nil {
2022-09-15 02:44:43 +00:00
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
2022-09-13 10:45:03 +00:00
2023-04-25 06:34:16 +00:00
// @Tags System Setting
// @Summary Update system ssl
// @Accept json
// @Param request body dto.SSLUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/ssl/update [post]
2023-10-07 07:46:44 +00:00
// @x-panel-log {"bodyKeys":["ssl"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"修改系统 ssl => [ssl]","formatEN":"update system ssl => [ssl]"}
2023-04-25 06:34:16 +00:00
func ( b * BaseApi ) UpdateSSL ( c * gin . Context ) {
var req dto . SSLUpdate
2023-10-27 06:19:26 +00:00
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
2023-04-25 06:34:16 +00:00
return
}
if err := settingService . UpdateSSL ( c , req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
// @Tags System Setting
// @Summary Load system cert info
// @Success 200 {object} dto.SettingInfo
// @Security ApiKeyAuth
// @Router /settings/ssl/info [get]
func ( b * BaseApi ) LoadFromCert ( c * gin . Context ) {
info , err := settingService . LoadFromCert ( )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , info )
}
2023-08-02 14:36:37 +00:00
// @Tags System Setting
// @Summary Download system cert
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/ssl/download [post]
func ( b * BaseApi ) DownloadSSL ( c * gin . Context ) {
pathItem := path . Join ( global . CONF . System . BaseDir , "1panel/secret/server.crt" )
if _ , err := os . Stat ( pathItem ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
c . File ( pathItem )
}
2023-10-25 02:41:26 +00:00
// @Tags System Setting
// @Summary Load system address
// @Accept json
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/interface [get]
func ( b * BaseApi ) LoadInterfaceAddr ( c * gin . Context ) {
data , err := settingService . LoadInterfaceAddr ( )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , data )
}
// @Tags System Setting
// @Summary Update system bind info
// @Accept json
// @Param request body dto.BindInfo true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/bind/update [post]
// @x-panel-log {"bodyKeys":["ipv6", "bindAddress"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"修改系统监听信息 => ipv6: [ipv6], 监听 IP: [bindAddress]","formatEN":"update system bind info => ipv6: [ipv6], 监听 IP: [bindAddress]"}
func ( b * BaseApi ) UpdateBindInfo ( c * gin . Context ) {
var req dto . BindInfo
2023-10-27 06:19:26 +00:00
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
2023-10-25 02:41:26 +00:00
return
}
if err := settingService . UpdateBindInfo ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
2023-01-29 08:38:34 +00:00
// @Tags System Setting
// @Summary Update system port
// @Accept json
// @Param request body dto.PortUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/port/update [post]
2023-10-07 07:46:44 +00:00
// @x-panel-log {"bodyKeys":["serverPort"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"修改系统端口 => [serverPort]","formatEN":"update system port => [serverPort]"}
2023-01-29 08:38:34 +00:00
func ( b * BaseApi ) UpdatePort ( c * gin . Context ) {
var req dto . PortUpdate
2023-10-27 06:19:26 +00:00
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
2023-01-29 08:38:34 +00:00
return
}
if err := settingService . UpdatePort ( req . ServerPort ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
2023-01-04 14:31:51 +00:00
// @Tags System Setting
// @Summary Reset system password expired
// @Accept json
// @Param request body dto.PasswordUpdate true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/expired/handle [post]
2023-10-07 07:46:44 +00:00
// @x-panel-log {"bodyKeys":[],"paramKeys":[],"BeforeFunctions":[],"formatZH":"重置过期密码","formatEN":"reset an expired Password"}
2022-09-29 08:15:59 +00:00
func ( b * BaseApi ) HandlePasswordExpired ( c * gin . Context ) {
var req dto . PasswordUpdate
2023-10-27 06:19:26 +00:00
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
2022-09-29 08:15:59 +00:00
return
}
if err := settingService . HandlePasswordExpired ( c , req . OldPassword , req . NewPassword ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
2023-05-22 09:45:39 +00:00
// @Tags System Setting
2024-11-30 11:44:50 +00:00
// @Summary Load local base dir
2023-01-29 08:38:34 +00:00
// @Success 200 {string} path
// @Security ApiKeyAuth
// @Router /settings/basedir [get]
func ( b * BaseApi ) LoadBaseDir ( c * gin . Context ) {
helper . SuccessWithData ( c , global . CONF . System . DataDir )
}
2023-01-04 14:31:51 +00:00
// @Tags System Setting
// @Summary Load mfa info
2023-09-28 07:46:18 +00:00
// @Accept json
// @Param request body dto.MfaCredential true "request"
2023-01-04 14:31:51 +00:00
// @Success 200 {object} mfa.Otp
// @Security ApiKeyAuth
2023-09-28 07:46:18 +00:00
// @Router /settings/mfa [post]
func ( b * BaseApi ) LoadMFA ( c * gin . Context ) {
var req dto . MfaRequest
2023-10-27 06:19:26 +00:00
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
2023-06-25 09:52:13 +00:00
return
}
2023-09-28 07:46:18 +00:00
otp , err := mfa . GetOtp ( "admin" , req . Title , req . Interval )
2022-09-14 15:27:17 +00:00
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , otp )
}
2023-01-04 14:31:51 +00:00
// @Tags System Setting
// @Summary Bind mfa
// @Accept json
// @Param request body dto.MfaCredential true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/mfa/bind [post]
2023-10-07 07:46:44 +00:00
// @x-panel-log {"bodyKeys":[],"paramKeys":[],"BeforeFunctions":[],"formatZH":"mfa 绑定","formatEN":"bind mfa"}
2022-09-14 15:27:17 +00:00
func ( b * BaseApi ) MFABind ( c * gin . Context ) {
var req dto . MfaCredential
2023-10-27 06:19:26 +00:00
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
2022-09-14 15:27:17 +00:00
return
}
2023-10-27 06:19:26 +00:00
2023-06-25 09:52:13 +00:00
success := mfa . ValidCode ( req . Code , req . Interval , req . Secret )
2022-09-14 15:27:17 +00:00
if ! success {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , errors . New ( "code is not valid" ) )
return
}
2023-06-25 09:52:13 +00:00
if err := settingService . Update ( "MFAInterval" , req . Interval ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
2023-02-10 10:07:29 +00:00
if err := settingService . Update ( "MFAStatus" , "enable" ) ; err != nil {
2022-09-14 15:27:17 +00:00
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
2023-02-10 10:07:29 +00:00
if err := settingService . Update ( "MFASecret" , req . Secret ) ; err != nil {
2022-09-14 15:27:17 +00:00
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}
2024-11-21 14:09:00 +00:00
// @Tags System Setting
2024-11-30 11:44:50 +00:00
// @Summary Generate api key
2024-11-21 14:09:00 +00:00
// @Accept json
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/api/config/generate/key [post]
// @x-panel-log {"bodyKeys":[],"paramKeys":[],"BeforeFunctions":[],"formatZH":"生成 API 接口密钥","formatEN":"generate api key"}
func ( b * BaseApi ) GenerateApiKey ( c * gin . Context ) {
panelToken := c . GetHeader ( "1Panel-Token" )
if panelToken != "" {
helper . ErrorWithDetail ( c , constant . CodeErrUnauthorized , constant . ErrApiConfigDisable , nil )
return
}
apiKey , err := settingService . GenerateApiKey ( )
if err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , apiKey )
}
// @Tags System Setting
// @Summary Update api config
// @Accept json
// @Param request body dto.ApiInterfaceConfig true "request"
// @Success 200
// @Security ApiKeyAuth
// @Router /settings/api/config/update [post]
// @x-panel-log {"bodyKeys":["ipWhiteList"],"paramKeys":[],"BeforeFunctions":[],"formatZH":"更新 API 接口配置 => IP 白名单: [ipWhiteList]","formatEN":"update api config => IP White List: [ipWhiteList]"}
func ( b * BaseApi ) UpdateApiConfig ( c * gin . Context ) {
panelToken := c . GetHeader ( "1Panel-Token" )
if panelToken != "" {
helper . ErrorWithDetail ( c , constant . CodeErrUnauthorized , constant . ErrApiConfigDisable , nil )
return
}
var req dto . ApiInterfaceConfig
if err := helper . CheckBindAndValidate ( & req , c ) ; err != nil {
return
}
if err := settingService . UpdateApiConfig ( req ) ; err != nil {
helper . ErrorWithDetail ( c , constant . CodeErrInternalServer , constant . ErrTypeInternalServer , err )
return
}
helper . SuccessWithData ( c , nil )
}