mirror of
https://github.com/yu-i-i/overleaf-cep.git
synced 2026-05-23 17:19:37 +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
136 lines
4.3 KiB
Markdown
136 lines
4.3 KiB
Markdown
# writelatex-git-bridge
|
|
|
|
## Docker
|
|
|
|
The `Dockerfile` contains all the requirements for building and running the
|
|
writelatex-git-bridge.
|
|
|
|
```bash
|
|
# build the image
|
|
docker build -t writelatex-git-bridge .
|
|
|
|
# run it with the demo config
|
|
docker run -v `pwd`/conf/local.json:/conf/runtime.json writelatex-git-bridge
|
|
```
|
|
|
|
## Native install
|
|
|
|
### Required packages
|
|
|
|
- `maven` (for building, running tests and packaging)
|
|
- `jdk-8` (for compiling and running)
|
|
|
|
### Commands
|
|
|
|
To be run from the base directory:
|
|
|
|
**Build jar**:
|
|
`mvn package`
|
|
|
|
**Run tests**:
|
|
`mvn test`
|
|
|
|
**Clean**:
|
|
`mvn clean`
|
|
|
|
To be run from the dev-environment:
|
|
|
|
**Build jar**:
|
|
`bin/run git-bridge make package`
|
|
|
|
**Run tests**:
|
|
`bin/run git-bridge make test`
|
|
|
|
**Clean**:
|
|
`bin/run git-bridge make clean`
|
|
|
|
### Installation
|
|
|
|
Install dependencies:
|
|
|
|
```
|
|
sudo apt-get update
|
|
sudo apt-get install -y maven
|
|
sudo apt-get install -y openjdk-8-jdk
|
|
sudo update-alternatives --set java /usr/lib/jvm/java-8-openjdk-amd64/jre/bin/java
|
|
sudo update-alternatives --set javac /usr/lib/jvm/java-8-openjdk-amd64/jre/bin/javac
|
|
```
|
|
|
|
Create a config file according to the format below.
|
|
|
|
Run `mvn package` to build, test, and package it into a jar at `target/writelatex-git-bridge-1.0-SNAPSHOT-jar-with-dependencies.jar`.
|
|
|
|
Use `java -jar <path_to_jar> <path_to_config_file>` to run the server.
|
|
|
|
## Runtime Configuration
|
|
|
|
The configuration file is in `.json` format.
|
|
|
|
{
|
|
"port" (int): the port number,
|
|
"rootGitDirectory" (string): the directory in which to store
|
|
git repos and the db/atts,
|
|
"apiBaseUrl" (string): base url for the snapshot api,
|
|
"username" (string, optional): username for http basic auth,
|
|
"password" (string, optional): password for http basic auth,
|
|
"postbackBaseUrl" (string): the postback url,
|
|
"serviceName" (string): current name of writeLaTeX
|
|
in case it ever changes,
|
|
"oauth2Server" (string): oauth2 server,
|
|
with protocol and
|
|
without trailing slash,
|
|
null or missing if oauth2 shouldn't be used
|
|
},
|
|
"repoStore" (object, optional): { configure the repo store
|
|
"maxFileSize" (long, optional): maximum size of a file, inclusive
|
|
},
|
|
"swapStore" (object, optional): { the place to swap projects to.
|
|
if null, type defaults to
|
|
"noop"
|
|
"type" (string): "s3", "memory", "noop" (not recommended),
|
|
"awsAccessKey" (string, optional): only for s3,
|
|
"awsSecret" (string, optional): only for s3,
|
|
"s3BucketName" (string, optional): only for s3
|
|
},
|
|
"swapJob" (object, optional): { configure the project
|
|
swapping job.
|
|
if null, defaults to no-op
|
|
"minProjects" (int64): lower bound on number of projects
|
|
present. The swap job will never go
|
|
below this, regardless of what the
|
|
watermark shows. Regardless, if
|
|
minProjects prevents an eviction,
|
|
the swap job will WARN,
|
|
"lowGiB" (int32): the low watermark for swapping,
|
|
i.e. swap until disk usage is below this,
|
|
"highGiB" (int32): the high watermark for swapping,
|
|
i.e. start swapping when
|
|
disk usage becomes this,
|
|
"intervalMillis" (int64): amount of time in between running
|
|
swap job and checking watermarks.
|
|
3600000 is 1 hour
|
|
}
|
|
}
|
|
|
|
You have to restart the server for configuration changes to take effect.
|
|
|
|
## Creating OAuth app
|
|
|
|
In dev-env, run the following command in mongo to create the oauth application
|
|
for git-bridge.
|
|
|
|
```
|
|
db.oauthApplications.insert({
|
|
"clientSecret" : "v1.G5HHTXfxsJMmfFhSar9QhJLg/u4KpGpYOdPGwoKdZXk=",
|
|
"grants" : [
|
|
"password"
|
|
],
|
|
"id" : "264c723c925c13590880751f861f13084934030c13b4452901e73bdfab226edc",
|
|
"name" : "Overleaf Git Bridge",
|
|
"redirectUris" : [],
|
|
"scopes" : [
|
|
"git_bridge"
|
|
]
|
|
})
|
|
```
|