mirror of
https://github.com/1Panel-dev/1Panel.git
synced 2025-10-24 06:27:37 +08:00
30 lines
826 B
Go
30 lines
826 B
Go
package middleware
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
|
|
"github.com/1Panel-dev/1Panel/agent/app/api/v2/helper"
|
|
"github.com/1Panel-dev/1Panel/agent/constant"
|
|
"github.com/1Panel-dev/1Panel/agent/global"
|
|
"github.com/gin-gonic/gin"
|
|
)
|
|
|
|
func Certificate() gin.HandlerFunc {
|
|
return func(c *gin.Context) {
|
|
if global.IsMaster {
|
|
c.Next()
|
|
return
|
|
}
|
|
if !c.Request.TLS.HandshakeComplete || len(c.Request.TLS.PeerCertificates) == 0 {
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, errors.New("no such tls peer certificates"))
|
|
return
|
|
}
|
|
cert := c.Request.TLS.PeerCertificates[0]
|
|
if cert.Subject.CommonName != "panel_client" {
|
|
helper.ErrorWithDetail(c, constant.CodeErrInternalServer, constant.ErrTypeInternalServer, fmt.Errorf("err certificate"))
|
|
return
|
|
}
|
|
c.Next()
|
|
}
|
|
}
|