mirror of
https://github.com/yusing/godoxy.git
synced 2025-07-16 02:04:04 +02:00
disabled auth by default (when no JWT secret is specified)
This commit is contained in:
parent
c6a9a816f6
commit
b63ebfcb3b
3 changed files with 11 additions and 2 deletions
|
@ -90,7 +90,7 @@ func LogoutHandler(w http.ResponseWriter, r *http.Request) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func RequireAuth(next http.HandlerFunc) http.HandlerFunc {
|
func RequireAuth(next http.HandlerFunc) http.HandlerFunc {
|
||||||
if common.IsDebugSkipAuth {
|
if common.IsDebugSkipAuth || common.APIJWTSecret == nil {
|
||||||
return next
|
return next
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,6 +23,9 @@ func generateJWTKey(size int) string {
|
||||||
}
|
}
|
||||||
|
|
||||||
func decodeJWTKey(key string) []byte {
|
func decodeJWTKey(key string) []byte {
|
||||||
|
if key == "" {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
bytes, err := base64.StdEncoding.DecodeString(key)
|
bytes, err := base64.StdEncoding.DecodeString(key)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Panic().Err(err).Msg("failed to decode jwt key")
|
log.Panic().Err(err).Msg("failed to decode jwt key")
|
||||||
|
|
|
@ -33,12 +33,18 @@ var (
|
||||||
APIHTTPPort,
|
APIHTTPPort,
|
||||||
APIHTTPURL = GetAddrEnv("GOPROXY_API_ADDR", "127.0.0.1:8888", "http")
|
APIHTTPURL = GetAddrEnv("GOPROXY_API_ADDR", "127.0.0.1:8888", "http")
|
||||||
|
|
||||||
APIJWTSecret = decodeJWTKey(GetEnv("GOPROXY_API_JWT_SECRET", generateJWTKey(32)))
|
APIJWTSecret = decodeJWTKey(GetEnv("GOPROXY_API_JWT_SECRET", ""))
|
||||||
APIJWTTokenTTL = GetDurationEnv("GOPROXY_API_JWT_TOKEN_TTL", time.Hour)
|
APIJWTTokenTTL = GetDurationEnv("GOPROXY_API_JWT_TOKEN_TTL", time.Hour)
|
||||||
APIUser = GetEnv("GOPROXY_API_USER", "admin")
|
APIUser = GetEnv("GOPROXY_API_USER", "admin")
|
||||||
APIPasswordHash = HashPassword(GetEnv("GOPROXY_API_PASSWORD", "password"))
|
APIPasswordHash = HashPassword(GetEnv("GOPROXY_API_PASSWORD", "password"))
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
if APIJWTSecret == nil {
|
||||||
|
log.Warn().Msg("API JWT secret is empty, authentication is disabled")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func GetEnvBool(key string, defaultValue bool) bool {
|
func GetEnvBool(key string, defaultValue bool) bool {
|
||||||
value, ok := os.LookupEnv(key)
|
value, ok := os.LookupEnv(key)
|
||||||
if !ok || value == "" {
|
if !ok || value == "" {
|
||||||
|
|
Loading…
Add table
Reference in a new issue