2018-06-24 11:22:51 +00:00
|
|
|
'use strict'
|
|
|
|
|
2019-04-12 09:58:24 +00:00
|
|
|
const { toBooleanConfig, toArrayConfig, toIntegerConfig } = require('./utils')
|
2018-06-24 11:22:51 +00:00
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
domain: process.env.HMD_DOMAIN,
|
|
|
|
urlPath: process.env.HMD_URL_PATH,
|
|
|
|
port: toIntegerConfig(process.env.HMD_PORT),
|
|
|
|
urlAddPort: toBooleanConfig(process.env.HMD_URL_ADDPORT),
|
|
|
|
useSSL: toBooleanConfig(process.env.HMD_USESSL),
|
|
|
|
hsts: {
|
|
|
|
enable: toBooleanConfig(process.env.HMD_HSTS_ENABLE),
|
2019-03-04 16:13:33 +00:00
|
|
|
maxAgeSeconds: toIntegerConfig(process.env.HMD_HSTS_MAX_AGE),
|
2018-06-24 11:22:51 +00:00
|
|
|
includeSubdomains: toBooleanConfig(process.env.HMD_HSTS_INCLUDE_SUBDOMAINS),
|
|
|
|
preload: toBooleanConfig(process.env.HMD_HSTS_PRELOAD)
|
|
|
|
},
|
|
|
|
csp: {
|
|
|
|
enable: toBooleanConfig(process.env.HMD_CSP_ENABLE),
|
|
|
|
reportURI: process.env.HMD_CSP_REPORTURI
|
|
|
|
},
|
|
|
|
protocolUseSSL: toBooleanConfig(process.env.HMD_PROTOCOL_USESSL),
|
|
|
|
allowOrigin: toArrayConfig(process.env.HMD_ALLOW_ORIGIN),
|
|
|
|
useCDN: toBooleanConfig(process.env.HMD_USECDN),
|
|
|
|
allowAnonymous: toBooleanConfig(process.env.HMD_ALLOW_ANONYMOUS),
|
|
|
|
allowAnonymousEdits: toBooleanConfig(process.env.HMD_ALLOW_ANONYMOUS_EDITS),
|
|
|
|
allowFreeURL: toBooleanConfig(process.env.HMD_ALLOW_FREEURL),
|
|
|
|
defaultPermission: process.env.HMD_DEFAULT_PERMISSION,
|
|
|
|
dbURL: process.env.HMD_DB_URL,
|
|
|
|
sessionSecret: process.env.HMD_SESSION_SECRET,
|
|
|
|
sessionLife: toIntegerConfig(process.env.HMD_SESSION_LIFE),
|
2019-07-18 04:48:40 +00:00
|
|
|
responseMaxLag: toIntegerConfig(process.env.HMD_RESPONSE_MAX_LAG),
|
2018-06-24 11:22:51 +00:00
|
|
|
imageUploadType: process.env.HMD_IMAGE_UPLOAD_TYPE,
|
|
|
|
imgur: {
|
|
|
|
clientID: process.env.HMD_IMGUR_CLIENTID
|
|
|
|
},
|
|
|
|
s3: {
|
|
|
|
accessKeyId: process.env.HMD_S3_ACCESS_KEY_ID,
|
|
|
|
secretAccessKey: process.env.HMD_S3_SECRET_ACCESS_KEY,
|
|
|
|
region: process.env.HMD_S3_REGION
|
|
|
|
},
|
|
|
|
minio: {
|
|
|
|
accessKey: process.env.HMD_MINIO_ACCESS_KEY,
|
|
|
|
secretKey: process.env.HMD_MINIO_SECRET_KEY,
|
|
|
|
endPoint: process.env.HMD_MINIO_ENDPOINT,
|
|
|
|
secure: toBooleanConfig(process.env.HMD_MINIO_SECURE),
|
|
|
|
port: toIntegerConfig(process.env.HMD_MINIO_PORT)
|
|
|
|
},
|
|
|
|
s3bucket: process.env.HMD_S3_BUCKET,
|
|
|
|
azure: {
|
|
|
|
connectionString: process.env.HMD_AZURE_CONNECTION_STRING,
|
|
|
|
container: process.env.HMD_AZURE_CONTAINER
|
|
|
|
},
|
|
|
|
facebook: {
|
|
|
|
clientID: process.env.HMD_FACEBOOK_CLIENTID,
|
|
|
|
clientSecret: process.env.HMD_FACEBOOK_CLIENTSECRET
|
|
|
|
},
|
|
|
|
twitter: {
|
|
|
|
consumerKey: process.env.HMD_TWITTER_CONSUMERKEY,
|
|
|
|
consumerSecret: process.env.HMD_TWITTER_CONSUMERSECRET
|
|
|
|
},
|
|
|
|
github: {
|
|
|
|
clientID: process.env.HMD_GITHUB_CLIENTID,
|
|
|
|
clientSecret: process.env.HMD_GITHUB_CLIENTSECRET
|
|
|
|
},
|
|
|
|
gitlab: {
|
|
|
|
baseURL: process.env.HMD_GITLAB_BASEURL,
|
|
|
|
clientID: process.env.HMD_GITLAB_CLIENTID,
|
|
|
|
clientSecret: process.env.HMD_GITLAB_CLIENTSECRET,
|
|
|
|
scope: process.env.HMD_GITLAB_SCOPE
|
|
|
|
},
|
|
|
|
mattermost: {
|
|
|
|
baseURL: process.env.HMD_MATTERMOST_BASEURL,
|
|
|
|
clientID: process.env.HMD_MATTERMOST_CLIENTID,
|
|
|
|
clientSecret: process.env.HMD_MATTERMOST_CLIENTSECRET
|
|
|
|
},
|
|
|
|
oauth2: {
|
|
|
|
baseURL: process.env.HMD_OAUTH2_BASEURL,
|
|
|
|
userProfileURL: process.env.HMD_OAUTH2_USER_PROFILE_URL,
|
|
|
|
userProfileUsernameAttr: process.env.HMD_OAUTH2_USER_PROFILE_USERNAME_ATTR,
|
|
|
|
userProfileDisplayNameAttr: process.env.HMD_OAUTH2_USER_PROFILE_DISPLAY_NAME_ATTR,
|
|
|
|
userProfileEmailAttr: process.env.HMD_OAUTH2_USER_PROFILE_EMAIL_ATTR,
|
|
|
|
tokenURL: process.env.HMD_OAUTH2_TOKEN_URL,
|
|
|
|
authorizationURL: process.env.HMD_OAUTH2_AUTHORIZATION_URL,
|
|
|
|
clientID: process.env.HMD_OAUTH2_CLIENT_ID,
|
|
|
|
clientSecret: process.env.HMD_OAUTH2_CLIENT_SECRET
|
|
|
|
},
|
|
|
|
dropbox: {
|
|
|
|
clientID: process.env.HMD_DROPBOX_CLIENTID,
|
|
|
|
clientSecret: process.env.HMD_DROPBOX_CLIENTSECRET,
|
|
|
|
appKey: process.env.HMD_DROPBOX_APPKEY
|
|
|
|
},
|
|
|
|
google: {
|
|
|
|
clientID: process.env.HMD_GOOGLE_CLIENTID,
|
|
|
|
clientSecret: process.env.HMD_GOOGLE_CLIENTSECRET
|
|
|
|
},
|
|
|
|
ldap: {
|
|
|
|
providerName: process.env.HMD_LDAP_PROVIDERNAME,
|
|
|
|
url: process.env.HMD_LDAP_URL,
|
|
|
|
bindDn: process.env.HMD_LDAP_BINDDN,
|
|
|
|
bindCredentials: process.env.HMD_LDAP_BINDCREDENTIALS,
|
|
|
|
searchBase: process.env.HMD_LDAP_SEARCHBASE,
|
|
|
|
searchFilter: process.env.HMD_LDAP_SEARCHFILTER,
|
|
|
|
searchAttributes: toArrayConfig(process.env.HMD_LDAP_SEARCHATTRIBUTES),
|
|
|
|
usernameField: process.env.HMD_LDAP_USERNAMEFIELD,
|
|
|
|
useridField: process.env.HMD_LDAP_USERIDFIELD,
|
|
|
|
tlsca: process.env.HMD_LDAP_TLS_CA
|
|
|
|
},
|
|
|
|
saml: {
|
|
|
|
idpSsoUrl: process.env.HMD_SAML_IDPSSOURL,
|
|
|
|
idpCert: process.env.HMD_SAML_IDPCERT,
|
|
|
|
issuer: process.env.HMD_SAML_ISSUER,
|
|
|
|
identifierFormat: process.env.HMD_SAML_IDENTIFIERFORMAT,
|
|
|
|
groupAttribute: process.env.HMD_SAML_GROUPATTRIBUTE,
|
|
|
|
externalGroups: toArrayConfig(process.env.HMD_SAML_EXTERNALGROUPS, '|', []),
|
|
|
|
requiredGroups: toArrayConfig(process.env.HMD_SAML_REQUIREDGROUPS, '|', []),
|
|
|
|
attribute: {
|
|
|
|
id: process.env.HMD_SAML_ATTRIBUTE_ID,
|
|
|
|
username: process.env.HMD_SAML_ATTRIBUTE_USERNAME,
|
|
|
|
email: process.env.HMD_SAML_ATTRIBUTE_EMAIL
|
|
|
|
}
|
|
|
|
},
|
|
|
|
email: toBooleanConfig(process.env.HMD_EMAIL),
|
|
|
|
allowEmailRegister: toBooleanConfig(process.env.HMD_ALLOW_EMAIL_REGISTER),
|
|
|
|
allowPDFExport: toBooleanConfig(process.env.HMD_ALLOW_PDF_EXPORT)
|
|
|
|
}
|