mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-21 20:47:08 -05:00
[CE/SP] Rebrand common env variables to Overleaf
GitOrigin-RevId: 92439946f909f115df26a2bad79269f88741a9ac
This commit is contained in:
parent
2b76aa7df9
commit
389eb9105b
6 changed files with 106 additions and 109 deletions
|
@ -26,13 +26,13 @@ services:
|
||||||
# - /var/run/docker.sock:/var/run/docker.sock
|
# - /var/run/docker.sock:/var/run/docker.sock
|
||||||
environment:
|
environment:
|
||||||
|
|
||||||
SHARELATEX_APP_NAME: Overleaf Community Edition
|
OVERLEAF_APP_NAME: Overleaf Community Edition
|
||||||
|
|
||||||
SHARELATEX_MONGO_URL: mongodb://mongo/sharelatex
|
OVERLEAF_MONGO_URL: mongodb://mongo/sharelatex
|
||||||
|
|
||||||
# Same property, unfortunately with different names in
|
# Same property, unfortunately with different names in
|
||||||
# different locations
|
# different locations
|
||||||
SHARELATEX_REDIS_HOST: redis
|
OVERLEAF_REDIS_HOST: redis
|
||||||
REDIS_HOST: redis
|
REDIS_HOST: redis
|
||||||
|
|
||||||
ENABLED_LINKED_FILE_TYPES: 'project_file,project_output_file'
|
ENABLED_LINKED_FILE_TYPES: 'project_file,project_output_file'
|
||||||
|
@ -50,29 +50,29 @@ services:
|
||||||
## Set for SSL via nginx-proxy
|
## Set for SSL via nginx-proxy
|
||||||
#VIRTUAL_HOST: 103.112.212.22
|
#VIRTUAL_HOST: 103.112.212.22
|
||||||
|
|
||||||
# SHARELATEX_SITE_URL: http://overleaf.example.com
|
# OVERLEAF_SITE_URL: http://overleaf.example.com
|
||||||
# SHARELATEX_NAV_TITLE: Overleaf Community Edition
|
# OVERLEAF_NAV_TITLE: Overleaf Community Edition
|
||||||
# SHARELATEX_HEADER_IMAGE_URL: http://example.com/mylogo.png
|
# OVERLEAF_HEADER_IMAGE_URL: http://example.com/mylogo.png
|
||||||
# SHARELATEX_ADMIN_EMAIL: support@it.com
|
# OVERLEAF_ADMIN_EMAIL: support@it.com
|
||||||
|
|
||||||
# SHARELATEX_LEFT_FOOTER: '[{"text": "Another page I want to link to can be found <a href=\"here\">here</a>"} ]'
|
# OVERLEAF_LEFT_FOOTER: '[{"text": "Another page I want to link to can be found <a href=\"here\">here</a>"} ]'
|
||||||
# SHARELATEX_RIGHT_FOOTER: '[{"text": "Hello I am on the Right"} ]'
|
# OVERLEAF_RIGHT_FOOTER: '[{"text": "Hello I am on the Right"} ]'
|
||||||
|
|
||||||
# SHARELATEX_EMAIL_FROM_ADDRESS: "hello@example.com"
|
# OVERLEAF_EMAIL_FROM_ADDRESS: "hello@example.com"
|
||||||
|
|
||||||
# SHARELATEX_EMAIL_AWS_SES_ACCESS_KEY_ID:
|
# OVERLEAF_EMAIL_AWS_SES_ACCESS_KEY_ID:
|
||||||
# SHARELATEX_EMAIL_AWS_SES_SECRET_KEY:
|
# OVERLEAF_EMAIL_AWS_SES_SECRET_KEY:
|
||||||
|
|
||||||
# SHARELATEX_EMAIL_SMTP_HOST: smtp.example.com
|
# OVERLEAF_EMAIL_SMTP_HOST: smtp.example.com
|
||||||
# SHARELATEX_EMAIL_SMTP_PORT: 587
|
# OVERLEAF_EMAIL_SMTP_PORT: 587
|
||||||
# SHARELATEX_EMAIL_SMTP_SECURE: false
|
# OVERLEAF_EMAIL_SMTP_SECURE: false
|
||||||
# SHARELATEX_EMAIL_SMTP_USER:
|
# OVERLEAF_EMAIL_SMTP_USER:
|
||||||
# SHARELATEX_EMAIL_SMTP_PASS:
|
# OVERLEAF_EMAIL_SMTP_PASS:
|
||||||
# SHARELATEX_EMAIL_SMTP_TLS_REJECT_UNAUTH: true
|
# OVERLEAF_EMAIL_SMTP_TLS_REJECT_UNAUTH: true
|
||||||
# SHARELATEX_EMAIL_SMTP_IGNORE_TLS: false
|
# OVERLEAF_EMAIL_SMTP_IGNORE_TLS: false
|
||||||
# SHARELATEX_EMAIL_SMTP_NAME: '127.0.0.1'
|
# OVERLEAF_EMAIL_SMTP_NAME: '127.0.0.1'
|
||||||
# SHARELATEX_EMAIL_SMTP_LOGGER: true
|
# OVERLEAF_EMAIL_SMTP_LOGGER: true
|
||||||
# SHARELATEX_CUSTOM_EMAIL_FOOTER: "This system is run by department x"
|
# OVERLEAF_CUSTOM_EMAIL_FOOTER: "This system is run by department x"
|
||||||
|
|
||||||
# ENABLE_CRON_RESOURCE_DELETION: true
|
# ENABLE_CRON_RESOURCE_DELETION: true
|
||||||
|
|
||||||
|
@ -98,11 +98,11 @@ services:
|
||||||
# SHARELATEX_LDAP_LAST_NAME_ATT: 'sn'
|
# SHARELATEX_LDAP_LAST_NAME_ATT: 'sn'
|
||||||
# SHARELATEX_LDAP_UPDATE_USER_DETAILS_ON_LOGIN: 'true'
|
# SHARELATEX_LDAP_UPDATE_USER_DETAILS_ON_LOGIN: 'true'
|
||||||
|
|
||||||
# SHARELATEX_TEMPLATES_USER_ID: "578773160210479700917ee5"
|
# OVERLEAF_TEMPLATES_USER_ID: "578773160210479700917ee5"
|
||||||
# SHARELATEX_NEW_PROJECT_TEMPLATE_LINKS: '[ {"name":"All Templates","url":"/templates/all"}]'
|
# OVERLEAF_NEW_PROJECT_TEMPLATE_LINKS: '[ {"name":"All Templates","url":"/templates/all"}]'
|
||||||
|
|
||||||
|
|
||||||
# SHARELATEX_PROXY_LEARN: "true"
|
# OVERLEAF_PROXY_LEARN: "true"
|
||||||
|
|
||||||
mongo:
|
mongo:
|
||||||
restart: always
|
restart: always
|
||||||
|
|
|
@ -89,7 +89,7 @@ ENV OVERLEAF_CONFIG /etc/sharelatex/settings.js
|
||||||
ENV WEB_API_USER "overleaf"
|
ENV WEB_API_USER "overleaf"
|
||||||
ENV ADMIN_PRIVILEGE_AVAILABLE "true"
|
ENV ADMIN_PRIVILEGE_AVAILABLE "true"
|
||||||
|
|
||||||
ENV SHARELATEX_APP_NAME "Overleaf Community Edition"
|
ENV OVERLEAF_APP_NAME "Overleaf Community Edition"
|
||||||
|
|
||||||
ENV OPTIMISE_PDF "true"
|
ENV OPTIMISE_PDF "true"
|
||||||
|
|
||||||
|
|
|
@ -4,29 +4,29 @@
|
||||||
"databasePoolMin": "DATABASE_POOL_MIN",
|
"databasePoolMin": "DATABASE_POOL_MIN",
|
||||||
"databasePoolMax": "DATABASE_POOL_MAX",
|
"databasePoolMax": "DATABASE_POOL_MAX",
|
||||||
"persistor": {
|
"persistor": {
|
||||||
"backend": "SHARELATEX_HISTORY_BACKEND",
|
"backend": "OVERLEAF_HISTORY_BACKEND",
|
||||||
"s3": {
|
"s3": {
|
||||||
"key": "SHARELATEX_HISTORY_S3_ACCESS_KEY_ID",
|
"key": "OVERLEAF_HISTORY_S3_ACCESS_KEY_ID",
|
||||||
"secret": "SHARELATEX_HISTORY_S3_SECRET_ACCESS_KEY",
|
"secret": "OVERLEAF_HISTORY_S3_SECRET_ACCESS_KEY",
|
||||||
"maxRetries": "SHARELATEX_HISTORY_S3_MAX_RETRIES",
|
"maxRetries": "OVERLEAF_HISTORY_S3_MAX_RETRIES",
|
||||||
"endpoint": "SHARELATEX_HISTORY_S3_ENDPOINT",
|
"endpoint": "OVERLEAF_HISTORY_S3_ENDPOINT",
|
||||||
"pathStyle": "SHARELATEX_HISTORY_S3_PATH_STYLE",
|
"pathStyle": "OVERLEAF_HISTORY_S3_PATH_STYLE",
|
||||||
"region": "SHARELATEX_HISTORY_S3_REGION",
|
"region": "OVERLEAF_HISTORY_S3_REGION",
|
||||||
"httpOptions": {
|
"httpOptions": {
|
||||||
"timeout": "SHARELATEX_HISTORY_S3_TIMEOUT"
|
"timeout": "OVERLEAF_HISTORY_S3_TIMEOUT"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"blobStore": {
|
"blobStore": {
|
||||||
"globalBucket": "SHARELATEX_HISTORY_BLOBS_BUCKET",
|
"globalBucket": "OVERLEAF_HISTORY_BLOBS_BUCKET",
|
||||||
"projectBucket": "SHARELATEX_HISTORY_PROJECT_BLOBS_BUCKET"
|
"projectBucket": "OVERLEAF_HISTORY_PROJECT_BLOBS_BUCKET"
|
||||||
},
|
},
|
||||||
"chunkStore": {
|
"chunkStore": {
|
||||||
"historyStoreConcurrency": "HISTORY_STORE_CONCURRENCY",
|
"historyStoreConcurrency": "HISTORY_STORE_CONCURRENCY",
|
||||||
"bucket": "SHARELATEX_HISTORY_CHUNKS_BUCKET"
|
"bucket": "OVERLEAF_HISTORY_CHUNKS_BUCKET"
|
||||||
},
|
},
|
||||||
"zipStore": {
|
"zipStore": {
|
||||||
"bucket": "SHARELATEX_HISTORY_ZIPS_BUCKET",
|
"bucket": "OVERLEAF_HISTORY_ZIPS_BUCKET",
|
||||||
"zipTimeoutMs": "ZIP_STORE_ZIP_TIMEOUT_MS"
|
"zipTimeoutMs": "ZIP_STORE_ZIP_TIMEOUT_MS"
|
||||||
},
|
},
|
||||||
"mongo": {
|
"mongo": {
|
||||||
|
@ -44,5 +44,5 @@
|
||||||
"clusterWorkers": "CLUSTER_WORKERS",
|
"clusterWorkers": "CLUSTER_WORKERS",
|
||||||
"maxFileUploadSize": "MAX_FILE_UPLOAD_SIZE",
|
"maxFileUploadSize": "MAX_FILE_UPLOAD_SIZE",
|
||||||
"httpsOnly": "HTTPS_ONLY",
|
"httpsOnly": "HTTPS_ONLY",
|
||||||
"httpRequestTimeout": "SHARELATEX_HISTORY_V1_HTTP_REQUEST_TIMEOUT"
|
"httpRequestTimeout": "OVERLEAF_HISTORY_V1_HTTP_REQUEST_TIMEOUT"
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,7 +67,7 @@ const settings = {
|
||||||
//
|
//
|
||||||
// The following works out of the box with Mongo's default settings:
|
// The following works out of the box with Mongo's default settings:
|
||||||
mongo: {
|
mongo: {
|
||||||
url: process.env.SHARELATEX_MONGO_URL || 'mongodb://dockerhost/sharelatex',
|
url: process.env.OVERLEAF_MONGO_URL || 'mongodb://dockerhost/sharelatex',
|
||||||
},
|
},
|
||||||
|
|
||||||
// Redis is used in Overleaf Community Edition for high volume queries, like real-time
|
// Redis is used in Overleaf Community Edition for high volume queries, like real-time
|
||||||
|
@ -76,9 +76,9 @@ const settings = {
|
||||||
// The following config will work with Redis's default settings:
|
// The following config will work with Redis's default settings:
|
||||||
redis: {
|
redis: {
|
||||||
web: (redisConfig = {
|
web: (redisConfig = {
|
||||||
host: process.env.SHARELATEX_REDIS_HOST || 'dockerhost',
|
host: process.env.OVERLEAF_REDIS_HOST || 'dockerhost',
|
||||||
port: process.env.SHARELATEX_REDIS_PORT || '6379',
|
port: process.env.OVERLEAF_REDIS_PORT || '6379',
|
||||||
password: process.env.SHARELATEX_REDIS_PASS || undefined,
|
password: process.env.OVERLEAF_REDIS_PASS || undefined,
|
||||||
key_schema: {
|
key_schema: {
|
||||||
// document-updater
|
// document-updater
|
||||||
blockingKey({ doc_id }) {
|
blockingKey({ doc_id }) {
|
||||||
|
@ -179,33 +179,33 @@ const settings = {
|
||||||
|
|
||||||
// Where your instance of Overleaf Community Edition can be found publicly. This is used
|
// Where your instance of Overleaf Community Edition can be found publicly. This is used
|
||||||
// when emails are sent out and in generated links:
|
// when emails are sent out and in generated links:
|
||||||
siteUrl: (siteUrl = process.env.SHARELATEX_SITE_URL || 'http://localhost'),
|
siteUrl: (siteUrl = process.env.OVERLEAF_SITE_URL || 'http://localhost'),
|
||||||
|
|
||||||
// Status page URL as displayed on the maintenance/500 pages.
|
// Status page URL as displayed on the maintenance/500 pages.
|
||||||
statusPageUrl: process.env.SHARELATEX_STATUS_PAGE_URL,
|
statusPageUrl: process.env.OVERLEAF_STATUS_PAGE_URL,
|
||||||
|
|
||||||
// The name this is used to describe your Overleaf Community Edition Installation
|
// The name this is used to describe your Overleaf Community Edition Installation
|
||||||
appName: process.env.SHARELATEX_APP_NAME || 'Overleaf Community Edition',
|
appName: process.env.OVERLEAF_APP_NAME || 'Overleaf Community Edition',
|
||||||
|
|
||||||
restrictInvitesToExistingAccounts:
|
restrictInvitesToExistingAccounts:
|
||||||
process.env.SHARELATEX_RESTRICT_INVITES_TO_EXISTING_ACCOUNTS === 'true',
|
process.env.OVERLEAF_RESTRICT_INVITES_TO_EXISTING_ACCOUNTS === 'true',
|
||||||
|
|
||||||
nav: {
|
nav: {
|
||||||
title:
|
title:
|
||||||
process.env.SHARELATEX_NAV_TITLE ||
|
process.env.OVERLEAF_NAV_TITLE ||
|
||||||
process.env.SHARELATEX_APP_NAME ||
|
process.env.OVERLEAF_APP_NAME ||
|
||||||
'Overleaf Community Edition',
|
'Overleaf Community Edition',
|
||||||
},
|
},
|
||||||
|
|
||||||
// The email address which users will be directed to as the main point of
|
// The email address which users will be directed to as the main point of
|
||||||
// contact for this installation of Overleaf Community Edition.
|
// contact for this installation of Overleaf Community Edition.
|
||||||
adminEmail: process.env.SHARELATEX_ADMIN_EMAIL || 'placeholder@example.com',
|
adminEmail: process.env.OVERLEAF_ADMIN_EMAIL || 'placeholder@example.com',
|
||||||
|
|
||||||
// If provided, a sessionSecret is used to sign cookies so that they cannot be
|
// If provided, a sessionSecret is used to sign cookies so that they cannot be
|
||||||
// spoofed. This is recommended.
|
// spoofed. This is recommended.
|
||||||
security: {
|
security: {
|
||||||
sessionSecret:
|
sessionSecret:
|
||||||
process.env.SHARELATEX_SESSION_SECRET || process.env.CRYPTO_RANDOM,
|
process.env.OVERLEAF_SESSION_SECRET || process.env.CRYPTO_RANDOM,
|
||||||
},
|
},
|
||||||
|
|
||||||
// These credentials are used for authenticating api requests
|
// These credentials are used for authenticating api requests
|
||||||
|
@ -222,18 +222,18 @@ const settings = {
|
||||||
|
|
||||||
// If you are running Overleaf Community Edition over https, set this to true to send the
|
// If you are running Overleaf Community Edition over https, set this to true to send the
|
||||||
// cookie with a secure flag (recommended).
|
// cookie with a secure flag (recommended).
|
||||||
secureCookie: process.env.SHARELATEX_SECURE_COOKIE != null,
|
secureCookie: process.env.OVERLEAF_SECURE_COOKIE != null,
|
||||||
|
|
||||||
// If you are running Overleaf Community Edition behind a proxy (like Apache, Nginx, etc)
|
// If you are running Overleaf Community Edition behind a proxy (like Apache, Nginx, etc)
|
||||||
// then set this to true to allow it to correctly detect the forwarded IP
|
// then set this to true to allow it to correctly detect the forwarded IP
|
||||||
// address and http/https protocol information.
|
// address and http/https protocol information.
|
||||||
|
|
||||||
behindProxy: process.env.SHARELATEX_BEHIND_PROXY || false,
|
behindProxy: process.env.OVERLEAF_BEHIND_PROXY || false,
|
||||||
trustedProxyIps: process.env.SHARELATEX_TRUSTED_PROXY_IPS,
|
trustedProxyIps: process.env.SHARELATEX_TRUSTED_PROXY_IPS,
|
||||||
|
|
||||||
// The amount of time, in milliseconds, until the (rolling) cookie session expires
|
// The amount of time, in milliseconds, until the (rolling) cookie session expires
|
||||||
cookieSessionLength: parseInt(
|
cookieSessionLength: parseInt(
|
||||||
process.env.SHARELATEX_COOKIE_SESSION_LENGTH || 5 * 24 * 60 * 60 * 1000, // default 5 days
|
process.env.OVERLEAF_COOKIE_SESSION_LENGTH || 5 * 24 * 60 * 60 * 1000, // default 5 days
|
||||||
10
|
10
|
||||||
),
|
),
|
||||||
|
|
||||||
|
@ -269,7 +269,7 @@ const settings = {
|
||||||
user: 'staging',
|
user: 'staging',
|
||||||
pass: process.env.STAGING_PASSWORD,
|
pass: process.env.STAGING_PASSWORD,
|
||||||
requestTimeout: parseInt(
|
requestTimeout: parseInt(
|
||||||
process.env.SHARELATEX_HISTORY_V1_HTTP_REQUEST_TIMEOUT || '300000', // default is 5min
|
process.env.OVERLEAF_HISTORY_V1_HTTP_REQUEST_TIMEOUT || '300000', // default is 5min
|
||||||
10
|
10
|
||||||
),
|
),
|
||||||
},
|
},
|
||||||
|
@ -291,27 +291,27 @@ const settings = {
|
||||||
|
|
||||||
// # OPTIONAL CONFIGURABLE SETTINGS
|
// # OPTIONAL CONFIGURABLE SETTINGS
|
||||||
|
|
||||||
if (process.env.SHARELATEX_LEFT_FOOTER != null) {
|
if (process.env.OVERLEAF_LEFT_FOOTER != null) {
|
||||||
try {
|
try {
|
||||||
settings.nav.left_footer = JSON.parse(process.env.SHARELATEX_LEFT_FOOTER)
|
settings.nav.left_footer = JSON.parse(process.env.OVERLEAF_LEFT_FOOTER)
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
e = error
|
e = error
|
||||||
console.error('could not parse SHARELATEX_LEFT_FOOTER, not valid JSON')
|
console.error('could not parse OVERLEAF_LEFT_FOOTER, not valid JSON')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (process.env.SHARELATEX_RIGHT_FOOTER != null) {
|
if (process.env.OVERLEAF_RIGHT_FOOTER != null) {
|
||||||
settings.nav.right_footer = process.env.SHARELATEX_RIGHT_FOOTER
|
settings.nav.right_footer = process.env.OVERLEAF_RIGHT_FOOTER
|
||||||
try {
|
try {
|
||||||
settings.nav.right_footer = JSON.parse(process.env.SHARELATEX_RIGHT_FOOTER)
|
settings.nav.right_footer = JSON.parse(process.env.OVERLEAF_RIGHT_FOOTER)
|
||||||
} catch (error1) {
|
} catch (error1) {
|
||||||
e = error1
|
e = error1
|
||||||
console.error('could not parse SHARELATEX_RIGHT_FOOTER, not valid JSON')
|
console.error('could not parse OVERLEAF_RIGHT_FOOTER, not valid JSON')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (process.env.SHARELATEX_HEADER_IMAGE_URL != null) {
|
if (process.env.OVERLEAF_HEADER_IMAGE_URL != null) {
|
||||||
settings.nav.custom_logo = process.env.SHARELATEX_HEADER_IMAGE_URL
|
settings.nav.custom_logo = process.env.OVERLEAF_HEADER_IMAGE_URL
|
||||||
}
|
}
|
||||||
|
|
||||||
if (process.env.SHARELATEX_HEADER_NAV_LINKS != null) {
|
if (process.env.SHARELATEX_HEADER_NAV_LINKS != null) {
|
||||||
|
@ -325,14 +325,12 @@ if (process.env.SHARELATEX_HEADER_NAV_LINKS != null) {
|
||||||
`)
|
`)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (process.env.SHARELATEX_HEADER_EXTRAS != null) {
|
if (process.env.OVERLEAF_HEADER_EXTRAS != null) {
|
||||||
try {
|
try {
|
||||||
settings.nav.header_extras = JSON.parse(
|
settings.nav.header_extras = JSON.parse(process.env.OVERLEAF_HEADER_EXTRAS)
|
||||||
process.env.SHARELATEX_HEADER_EXTRAS
|
|
||||||
)
|
|
||||||
} catch (error2) {
|
} catch (error2) {
|
||||||
e = error2
|
e = error2
|
||||||
console.error('could not parse SHARELATEX_HEADER_EXTRAS, not valid JSON')
|
console.error('could not parse OVERLEAF_HEADER_EXTRAS, not valid JSON')
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -345,50 +343,49 @@ if (process.env.SHARELATEX_HEADER_EXTRAS != null) {
|
||||||
//
|
//
|
||||||
// http://www.nodemailer.com/docs/transports
|
// http://www.nodemailer.com/docs/transports
|
||||||
|
|
||||||
if (process.env.SHARELATEX_EMAIL_FROM_ADDRESS != null) {
|
if (process.env.OVERLEAF_EMAIL_FROM_ADDRESS != null) {
|
||||||
settings.email = {
|
settings.email = {
|
||||||
fromAddress: process.env.SHARELATEX_EMAIL_FROM_ADDRESS,
|
fromAddress: process.env.OVERLEAF_EMAIL_FROM_ADDRESS,
|
||||||
replyTo: process.env.SHARELATEX_EMAIL_REPLY_TO || '',
|
replyTo: process.env.OVERLEAF_EMAIL_REPLY_TO || '',
|
||||||
driver: process.env.SHARELATEX_EMAIL_DRIVER,
|
driver: process.env.OVERLEAF_EMAIL_DRIVER,
|
||||||
parameters: {
|
parameters: {
|
||||||
// AWS Creds
|
// AWS Creds
|
||||||
AWSAccessKeyID: process.env.SHARELATEX_EMAIL_AWS_SES_ACCESS_KEY_ID,
|
AWSAccessKeyID: process.env.OVERLEAF_EMAIL_AWS_SES_ACCESS_KEY_ID,
|
||||||
AWSSecretKey: process.env.SHARELATEX_EMAIL_AWS_SES_SECRET_KEY,
|
AWSSecretKey: process.env.OVERLEAF_EMAIL_AWS_SES_SECRET_KEY,
|
||||||
|
|
||||||
// SMTP Creds
|
// SMTP Creds
|
||||||
host: process.env.SHARELATEX_EMAIL_SMTP_HOST,
|
host: process.env.OVERLEAF_EMAIL_SMTP_HOST,
|
||||||
port: process.env.SHARELATEX_EMAIL_SMTP_PORT,
|
port: process.env.OVERLEAF_EMAIL_SMTP_PORT,
|
||||||
secure: parse(process.env.SHARELATEX_EMAIL_SMTP_SECURE),
|
secure: parse(process.env.OVERLEAF_EMAIL_SMTP_SECURE),
|
||||||
ignoreTLS: parse(process.env.SHARELATEX_EMAIL_SMTP_IGNORE_TLS),
|
ignoreTLS: parse(process.env.OVERLEAF_EMAIL_SMTP_IGNORE_TLS),
|
||||||
name: process.env.SHARELATEX_EMAIL_SMTP_NAME,
|
name: process.env.OVERLEAF_EMAIL_SMTP_NAME,
|
||||||
logger: process.env.SHARELATEX_EMAIL_SMTP_LOGGER === 'true',
|
logger: process.env.OVERLEAF_EMAIL_SMTP_LOGGER === 'true',
|
||||||
},
|
},
|
||||||
|
|
||||||
textEncoding: process.env.SHARELATEX_EMAIL_TEXT_ENCODING,
|
textEncoding: process.env.OVERLEAF_EMAIL_TEXT_ENCODING,
|
||||||
template: {
|
template: {
|
||||||
customFooter: process.env.SHARELATEX_CUSTOM_EMAIL_FOOTER,
|
customFooter: process.env.OVERLEAF_CUSTOM_EMAIL_FOOTER,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
if (process.env.SHARELATEX_EMAIL_AWS_SES_REGION != null) {
|
if (process.env.OVERLEAF_EMAIL_AWS_SES_REGION != null) {
|
||||||
settings.email.parameters.region =
|
settings.email.parameters.region = process.env.OVERLEAF_EMAIL_AWS_SES_REGION
|
||||||
process.env.SHARELATEX_EMAIL_AWS_SES_REGION
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (
|
if (
|
||||||
process.env.SHARELATEX_EMAIL_SMTP_USER != null ||
|
process.env.OVERLEAF_EMAIL_SMTP_USER != null ||
|
||||||
process.env.SHARELATEX_EMAIL_SMTP_PASS != null
|
process.env.OVERLEAF_EMAIL_SMTP_PASS != null
|
||||||
) {
|
) {
|
||||||
settings.email.parameters.auth = {
|
settings.email.parameters.auth = {
|
||||||
user: process.env.SHARELATEX_EMAIL_SMTP_USER,
|
user: process.env.OVERLEAF_EMAIL_SMTP_USER,
|
||||||
pass: process.env.SHARELATEX_EMAIL_SMTP_PASS,
|
pass: process.env.OVERLEAF_EMAIL_SMTP_PASS,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (process.env.SHARELATEX_EMAIL_SMTP_TLS_REJECT_UNAUTH != null) {
|
if (process.env.OVERLEAF_EMAIL_SMTP_TLS_REJECT_UNAUTH != null) {
|
||||||
settings.email.parameters.tls = {
|
settings.email.parameters.tls = {
|
||||||
rejectUnauthorized: parse(
|
rejectUnauthorized: parse(
|
||||||
process.env.SHARELATEX_EMAIL_SMTP_TLS_REJECT_UNAUTH
|
process.env.OVERLEAF_EMAIL_SMTP_TLS_REJECT_UNAUTH
|
||||||
),
|
),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -464,21 +461,21 @@ if (process.env.SANDBOXED_COMPILES === 'true') {
|
||||||
|
|
||||||
// Templates
|
// Templates
|
||||||
// ---------
|
// ---------
|
||||||
if (process.env.SHARELATEX_TEMPLATES_USER_ID) {
|
if (process.env.OVERLEAF_TEMPLATES_USER_ID) {
|
||||||
settings.templates = {
|
settings.templates = {
|
||||||
mountPointUrl: '/templates',
|
mountPointUrl: '/templates',
|
||||||
user_id: process.env.SHARELATEX_TEMPLATES_USER_ID,
|
user_id: process.env.OVERLEAF_TEMPLATES_USER_ID,
|
||||||
}
|
}
|
||||||
|
|
||||||
settings.templateLinks = parse(
|
settings.templateLinks = parse(
|
||||||
process.env.SHARELATEX_NEW_PROJECT_TEMPLATE_LINKS
|
process.env.OVERLEAF_NEW_PROJECT_TEMPLATE_LINKS
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
// /Learn
|
// /Learn
|
||||||
// -------
|
// -------
|
||||||
if (process.env.SHARELATEX_PROXY_LEARN != null) {
|
if (process.env.OVERLEAF_PROXY_LEARN != null) {
|
||||||
settings.proxyLearn = parse(process.env.SHARELATEX_PROXY_LEARN)
|
settings.proxyLearn = parse(process.env.OVERLEAF_PROXY_LEARN)
|
||||||
if (settings.proxyLearn) {
|
if (settings.proxyLearn) {
|
||||||
settings.nav.header_extras = [
|
settings.nav.header_extras = [
|
||||||
{
|
{
|
||||||
|
@ -498,26 +495,26 @@ if (process.env.SHARELATEX_ELASTICSEARCH_URL != null) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// filestore
|
// filestore
|
||||||
switch (process.env.SHARELATEX_FILESTORE_BACKEND) {
|
switch (process.env.OVERLEAF_FILESTORE_BACKEND) {
|
||||||
case 's3':
|
case 's3':
|
||||||
settings.filestore = {
|
settings.filestore = {
|
||||||
backend: 's3',
|
backend: 's3',
|
||||||
stores: {
|
stores: {
|
||||||
user_files: process.env.SHARELATEX_FILESTORE_USER_FILES_BUCKET_NAME,
|
user_files: process.env.OVERLEAF_FILESTORE_USER_FILES_BUCKET_NAME,
|
||||||
template_files:
|
template_files:
|
||||||
process.env.SHARELATEX_FILESTORE_TEMPLATE_FILES_BUCKET_NAME,
|
process.env.OVERLEAF_FILESTORE_TEMPLATE_FILES_BUCKET_NAME,
|
||||||
},
|
},
|
||||||
s3: {
|
s3: {
|
||||||
key:
|
key:
|
||||||
process.env.SHARELATEX_FILESTORE_S3_ACCESS_KEY_ID ||
|
process.env.OVERLEAF_FILESTORE_S3_ACCESS_KEY_ID ||
|
||||||
process.env.AWS_ACCESS_KEY_ID,
|
process.env.AWS_ACCESS_KEY_ID,
|
||||||
secret:
|
secret:
|
||||||
process.env.SHARELATEX_FILESTORE_S3_SECRET_ACCESS_KEY ||
|
process.env.OVERLEAF_FILESTORE_S3_SECRET_ACCESS_KEY ||
|
||||||
process.env.AWS_SECRET_ACCESS_KEY,
|
process.env.AWS_SECRET_ACCESS_KEY,
|
||||||
endpoint: process.env.SHARELATEX_FILESTORE_S3_ENDPOINT,
|
endpoint: process.env.OVERLEAF_FILESTORE_S3_ENDPOINT,
|
||||||
pathStyle: process.env.SHARELATEX_FILESTORE_S3_PATH_STYLE === 'true',
|
pathStyle: process.env.OVERLEAF_FILESTORE_S3_PATH_STYLE === 'true',
|
||||||
region:
|
region:
|
||||||
process.env.SHARELATEX_FILESTORE_S3_REGION ||
|
process.env.OVERLEAF_FILESTORE_S3_REGION ||
|
||||||
process.env.AWS_DEFAULT_REGION,
|
process.env.AWS_DEFAULT_REGION,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,4 +6,4 @@ if [ "$DEBUG_NODE" == "true" ]; then
|
||||||
NODE_PARAMS="--inspect=0.0.0.0:30640"
|
NODE_PARAMS="--inspect=0.0.0.0:30640"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
MONGO_CONNECTION_STRING=$SHARELATEX_MONGO_URL NODE_CONFIG_DIR=/overleaf/services/history-v1/config exec /sbin/setuser www-data /usr/bin/node $NODE_PARAMS /overleaf/services/history-v1/app.js >> /var/log/sharelatex/history-v1.log 2>&1
|
MONGO_CONNECTION_STRING=$OVERLEAF_MONGO_URL NODE_CONFIG_DIR=/overleaf/services/history-v1/config exec /sbin/setuser www-data /usr/bin/node $NODE_PARAMS /overleaf/services/history-v1/app.js >> /var/log/sharelatex/history-v1.log 2>&1
|
||||||
|
|
|
@ -14,9 +14,9 @@ services:
|
||||||
- mongo
|
- mongo
|
||||||
- redis
|
- redis
|
||||||
environment:
|
environment:
|
||||||
SHARELATEX_APP_NAME: Overleaf Community Edition
|
OVERLEAF_APP_NAME: Overleaf Community Edition
|
||||||
SHARELATEX_MONGO_URL: mongodb://mongo/sharelatex?directConnection=true
|
OVERLEAF_MONGO_URL: mongodb://mongo/sharelatex?directConnection=true
|
||||||
SHARELATEX_REDIS_HOST: redis
|
OVERLEAF_REDIS_HOST: redis
|
||||||
REDIS_HOST: redis
|
REDIS_HOST: redis
|
||||||
ENABLED_LINKED_FILE_TYPES: 'project_file,project_output_file'
|
ENABLED_LINKED_FILE_TYPES: 'project_file,project_output_file'
|
||||||
ENABLE_CONVERSIONS: 'true'
|
ENABLE_CONVERSIONS: 'true'
|
||||||
|
|
Loading…
Reference in a new issue