mirror of
https://github.com/yu-i-i/overleaf-cep.git
synced 2026-05-23 09:09:36 +02:00
* Merge all .prettierignore files into top-level config * Merge all .prettierrc files into top-level config * Replace service-specific glob patterns in package.json format scripts with `prettier .` * Add template files with Jinja2, Go template, envsubst, and Handlebars syntax to .prettierignore * Ignore GitHub templates * Ignore PUG templates to format them separately with `format:pug` * Encourage double quotes for YAML, YML files * Move prettier for PUG source format script to the root * Move prettier for styles source format script to the root * Remove prettier for jenkins files from web * Remove prettier source format script from all services * Make .prettierrc more readable * Update format scripts by file type * Organise `.prettierignore` * Add `--cache` flag to prettier scripts for faster runs * Format all files with prettier * Format all or format services * Remove `format`/`format:fix` scripts from services since now it runs from root `package.json` * Avoid conlficts with yamllint configuration * Remove `--cache` flag from prettier scripts * Update all service Makefiles to use root-level prettier configuration * Update all Jenkinsfile to use root-level prettier configuration * Ignore auto-generated files by build_scripts * Update package-lock.json * Update root Makefile format targets * Update SP Jenkinsfile format target * Update E2E Makefile format script * Udpate `format_js` to work in both local and CI env * Add docker-mailtrap to .prettierignore docker-mailtrap is a third-party git-ignored directory used for testing * Added Docker env detection to prevent nested Docker spawning * Ignore handlebars templates * Add cryptographic files and test output to `.prettierignore` * Add terraform modules to `.gitignore` * Remove prettier-plugin-groovy * Use npx directly instead of Docker for local formatting for faster formatting * Auto-generate Makefiles * Revert "Remove prettier-plugin-groovy" This reverts commit 194a33589a2e1e4d2225d10c67e9f025e4222025. * Mount monorepo root in RUN_LINT_FORMAT for prettier config access * Prettier ignores all `node_modules` by default regardless of location * Show only changed files in format output * Ignore LICENSE files * Enable prettier on rendered build_scripts outputs * Ignoring all the template folders by prettier * Remove the public/minjs entry since it does not exist * Remove all non-existent paths * Sync `.prettierignore` with ignored files by `.gitignore` and `.dockerignore` files * Revert "Auto-generate Makefiles" This reverts commit c0233e490de1bc95fe437219d65e0b66e0331ec9. * Revert "Use npx directly instead of Docker for local formatting for faster formatting" This reverts commit 1d2b2cf1a6c6974c76885852a90dd55e84167e41. * Ignore dashboard JSON files * Ignore files generated by bin/update_build_scripts * Remove unsupported file types from `.prettierignore` * Ignore test fixture generated files * Ignore README file types by prettier * Ignore generate snapshots by prettier * Allow to format generated bin/update_build_scripts by prettier * Ensure build script outputs prettier-compatible tsconfig.json * Fix build script output to match prettier formatting - Fix Jinja2 whitespace in docker-compose templates - Change YAML quotes from single to double * Don't read cryptographic files by prettier * Ignore google verification files by prettier * Revert npx prettier formatting * Ignore domain verification files * Show only changed files in format output * Make `.github` prettier * Allow all files to be formatted in jobs by prettier * Allow server-ce/server-pro files to be formatted by prettier * Ignore more folders in clsi, filestory, git-bridge by prettier * Update build script with `RUN_LINTING_CI_MONOREPO` * Ignore docker-mailtrap and downloads in server-ce by prettier * Restore prettier configs and prettierignore for V1 since it has its own prettier (an older version) * Source format GitOrigin-RevId: 637adc3cc422d1f20c86d6ebc8ec514d60758287
150 lines
5.7 KiB
YAML
150 lines
5.7 KiB
YAML
services:
|
|
sharelatex:
|
|
restart: always
|
|
# Server Pro users:
|
|
# image: quay.io/sharelatex/sharelatex-pro
|
|
image: sharelatex/sharelatex
|
|
container_name: sharelatex
|
|
depends_on:
|
|
mongo:
|
|
condition: service_healthy
|
|
redis:
|
|
condition: service_started
|
|
ports:
|
|
- 80:80
|
|
stop_grace_period: 60s
|
|
volumes:
|
|
- ~/sharelatex_data:/var/lib/overleaf
|
|
########################################################################
|
|
#### Server Pro: Uncomment the following line to mount the docker ####
|
|
#### socket, required for Sibling Containers to work ####
|
|
########################################################################
|
|
# - /var/run/docker.sock:/var/run/docker.sock
|
|
environment:
|
|
OVERLEAF_APP_NAME: Overleaf Community Edition
|
|
|
|
OVERLEAF_MONGO_URL: mongodb://mongo/sharelatex
|
|
|
|
# Same property, unfortunately with different names in
|
|
# different locations
|
|
OVERLEAF_REDIS_HOST: redis
|
|
REDIS_HOST: redis
|
|
|
|
ENABLED_LINKED_FILE_TYPES: "project_file,project_output_file"
|
|
|
|
# Enables Thumbnail generation using ImageMagick
|
|
ENABLE_CONVERSIONS: "true"
|
|
|
|
# Disables email confirmation requirement
|
|
EMAIL_CONFIRMATION_DISABLED: "true"
|
|
|
|
## Set for SSL via nginx-proxy
|
|
#VIRTUAL_HOST: 103.112.212.22
|
|
|
|
# OVERLEAF_SITE_URL: http://overleaf.example.com
|
|
# OVERLEAF_NAV_TITLE: Overleaf Community Edition
|
|
# OVERLEAF_HEADER_IMAGE_URL: http://example.com/mylogo.png
|
|
# OVERLEAF_ADMIN_EMAIL: support@it.com
|
|
|
|
# OVERLEAF_LEFT_FOOTER: '[{"text": "Another page I want to link to can be found <a href=\"here\">here</a>"} ]'
|
|
# OVERLEAF_RIGHT_FOOTER: '[{"text": "Hello I am on the Right"} ]'
|
|
|
|
# OVERLEAF_EMAIL_FROM_ADDRESS: "hello@example.com"
|
|
|
|
# OVERLEAF_EMAIL_AWS_SES_ACCESS_KEY_ID:
|
|
# OVERLEAF_EMAIL_AWS_SES_SECRET_KEY:
|
|
|
|
# OVERLEAF_EMAIL_SMTP_HOST: smtp.example.com
|
|
# OVERLEAF_EMAIL_SMTP_PORT: 587
|
|
# OVERLEAF_EMAIL_SMTP_SECURE: false
|
|
# OVERLEAF_EMAIL_SMTP_USER:
|
|
# OVERLEAF_EMAIL_SMTP_PASS:
|
|
# OVERLEAF_EMAIL_SMTP_TLS_REJECT_UNAUTH: true
|
|
# OVERLEAF_EMAIL_SMTP_IGNORE_TLS: false
|
|
# OVERLEAF_EMAIL_SMTP_NAME: '127.0.0.1'
|
|
# OVERLEAF_EMAIL_SMTP_LOGGER: true
|
|
# OVERLEAF_CUSTOM_EMAIL_FOOTER: "This system is run by department x"
|
|
|
|
# ENABLE_CRON_RESOURCE_DELETION: true
|
|
|
|
################
|
|
## Server Pro ##
|
|
################
|
|
|
|
## The Community Edition is intended for use in environments where all users are trusted and is not appropriate for
|
|
## scenarios where isolation of users is required. Sandboxed Compiles are not available in the Community Edition,
|
|
## so the following environment variables must be commented out to avoid compile issues.
|
|
##
|
|
## Sandboxed Compiles: https://docs.overleaf.com/on-premises/configuration/overleaf-toolkit/server-pro-only-configuration/sandboxed-compiles
|
|
SANDBOXED_COMPILES: "true"
|
|
### Bind-mount source for /var/lib/overleaf/data/compiles inside the container.
|
|
SANDBOXED_COMPILES_HOST_DIR_COMPILES: "/home/user/sharelatex_data/data/compiles"
|
|
### Bind-mount source for /var/lib/overleaf/data/output inside the container.
|
|
SANDBOXED_COMPILES_HOST_DIR_OUTPUT: "/home/user/sharelatex_data/data/output"
|
|
### Backwards compatibility (before Server Pro 5.5)
|
|
DOCKER_RUNNER: "true"
|
|
SANDBOXED_COMPILES_SIBLING_CONTAINERS: "true"
|
|
|
|
## Works with test LDAP server shown at bottom of docker compose
|
|
# OVERLEAF_LDAP_URL: 'ldap://ldap:389'
|
|
# OVERLEAF_LDAP_SEARCH_BASE: 'ou=people,dc=planetexpress,dc=com'
|
|
# OVERLEAF_LDAP_SEARCH_FILTER: '(uid={{username}})'
|
|
# OVERLEAF_LDAP_BIND_DN: 'cn=admin,dc=planetexpress,dc=com'
|
|
# OVERLEAF_LDAP_BIND_CREDENTIALS: 'GoodNewsEveryone'
|
|
# OVERLEAF_LDAP_EMAIL_ATT: 'mail'
|
|
# OVERLEAF_LDAP_NAME_ATT: 'cn'
|
|
# OVERLEAF_LDAP_LAST_NAME_ATT: 'sn'
|
|
# OVERLEAF_LDAP_UPDATE_USER_DETAILS_ON_LOGIN: 'true'
|
|
|
|
# OVERLEAF_TEMPLATES_USER_ID: "578773160210479700917ee5"
|
|
# OVERLEAF_NEW_PROJECT_TEMPLATE_LINKS: '[ {"name":"All Templates","url":"/templates/all"}]'
|
|
|
|
# OVERLEAF_PROXY_LEARN: "true"
|
|
|
|
mongo:
|
|
restart: always
|
|
image: mongo:6.0
|
|
container_name: mongo
|
|
command: "--replSet overleaf"
|
|
volumes:
|
|
- ~/mongo_data:/data/db
|
|
- ./bin/shared/mongodb-init-replica-set.js:/docker-entrypoint-initdb.d/mongodb-init-replica-set.js
|
|
environment:
|
|
MONGO_INITDB_DATABASE: sharelatex
|
|
extra_hosts:
|
|
# Required when using the automatic database setup for initializing the replica set.
|
|
# This override is not needed when running the setup after starting up mongo.
|
|
- mongo:127.0.0.1
|
|
healthcheck:
|
|
test: echo 'db.stats().ok' | mongosh localhost:27017/test --quiet
|
|
interval: 10s
|
|
timeout: 10s
|
|
retries: 5
|
|
|
|
redis:
|
|
restart: always
|
|
image: redis:6.2
|
|
container_name: redis
|
|
volumes:
|
|
- ~/redis_data:/data
|
|
|
|
# ldap:
|
|
# restart: always
|
|
# image: rroemhild/test-openldap
|
|
# container_name: ldap
|
|
|
|
# See https://github.com/jwilder/nginx-proxy for documentation on how to configure the nginx-proxy container,
|
|
# and https://github.com/overleaf/overleaf/wiki/HTTPS-reverse-proxy-using-Nginx for an example of some recommended
|
|
# settings. We recommend using a properly managed nginx instance outside of the Overleaf Server Pro setup,
|
|
# but the example here can be used if you'd prefer to run everything with docker-compose
|
|
|
|
# nginx-proxy:
|
|
# image: jwilder/nginx-proxy
|
|
# container_name: nginx-proxy
|
|
# ports:
|
|
# - "80:80"
|
|
# - "443:443"
|
|
# volumes:
|
|
# - /var/run/docker.sock:/tmp/docker.sock:ro
|
|
# - /home/overleaf/tmp:/etc/nginx/certs
|