2019-05-13 09:38:53 -06:00
// Copyright 2019 The Gitea Authors. All rights reserved.
2022-11-27 11:20:29 -07:00
// SPDX-License-Identifier: MIT
2019-05-13 09:38:53 -06:00
package setting
import (
"time"
"code.gitea.io/gitea/modules/log"
)
2022-01-20 10:46:10 -07:00
// CORSConfig defines CORS settings
var CORSConfig = struct {
Enabled bool
2023-12-25 06:01:24 -07:00
AllowDomain [ ] string // FIXME: this option is from legacy code, it actually works as "AllowedOrigins". When refactoring in the future, the config option should also be renamed together.
2022-01-20 10:46:10 -07:00
Methods [ ] string
MaxAge time . Duration
AllowCredentials bool
2022-11-10 23:39:27 -07:00
Headers [ ] string
2022-01-20 10:46:10 -07:00
XFrameOptions string
} {
2023-04-19 13:30:10 -06:00
AllowDomain : [ ] string { "*" } ,
Methods : [ ] string { "GET" , "HEAD" , "POST" , "PUT" , "PATCH" , "DELETE" , "OPTIONS" } ,
2022-11-10 23:39:27 -07:00
Headers : [ ] string { "Content-Type" , "User-Agent" } ,
2023-04-19 13:30:10 -06:00
MaxAge : 10 * time . Minute ,
2022-01-20 10:46:10 -07:00
XFrameOptions : "SAMEORIGIN" ,
}
2019-05-13 09:38:53 -06:00
2023-02-19 09:12:01 -07:00
func loadCorsFrom ( rootCfg ConfigProvider ) {
mustMapSetting ( rootCfg , "cors" , & CORSConfig )
2020-01-29 00:47:46 -07:00
if CORSConfig . Enabled {
2019-05-13 09:38:53 -06:00
log . Info ( "CORS Service Enabled" )
}
}