Compare commits
45 Commits
0.1.0+ngin
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| 36ee3451a3 | |||
| 06d98da6db | |||
| aa8e1d3488 | |||
| 9c18c176c5 | |||
| 96df5bda68 | |||
| e2cbecdc89 | |||
| 7a66942dd9 | |||
| bb655259c0 | |||
| 6d047f5987 | |||
| 081c196078 | |||
| a9f451a177 | |||
| 81119b2eea | |||
| 38393e1fd1 | |||
| a72a5c78db | |||
| 9922390ce3 | |||
| c1ee1d9817 | |||
| d3b1bb4f29 | |||
| 800e8426ce | |||
| 97209123e0 | |||
| 899f9d9da0 | |||
| f31c12299d | |||
| b8f074e0a7 | |||
| bd2488ffea | |||
| 61b41e2866 | |||
| db049838e9 | |||
| 694e6b1a72 | |||
| 3d92f35437 | |||
| 738f1af43e | |||
| 157f439441 | |||
| cfa170509c | |||
| 2128cc5b6d | |||
| 97ab3f4012 | |||
| ff217b4086 | |||
| 3b80a4c4b1 | |||
| 99bf8922ab | |||
| 2e7f9a374b | |||
| cb2a47fbc8 | |||
| 08f58b5921 | |||
| 49617c1570 | |||
| a2f881996c | |||
| e0c8cea282 | |||
| 9293e560e7 | |||
| 53b40190c9 | |||
| 4223ba3dc9 | |||
| 26ee1500d0 |
39
.drone.yml
Normal file
39
.drone.yml
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
---
|
||||||
|
kind: pipeline
|
||||||
|
name: deploy to swarm-test.autonomic.zone
|
||||||
|
steps:
|
||||||
|
- name: deployment
|
||||||
|
image: git.coopcloud.tech/coop-cloud/stack-ssh-deploy:latest
|
||||||
|
settings:
|
||||||
|
host: swarm-test.autonomic.zone
|
||||||
|
stack: cryptpad
|
||||||
|
generate_secrets: true
|
||||||
|
purge: true
|
||||||
|
deploy_key:
|
||||||
|
from_secret: drone_ssh_swarm_test
|
||||||
|
networks:
|
||||||
|
- proxy
|
||||||
|
environment:
|
||||||
|
DOMAIN: cryptpad.swarm-test.autonomic.zone
|
||||||
|
STACK_NAME: cryptpad
|
||||||
|
LETS_ENCRYPT_ENV: production
|
||||||
|
CONFIG_VERSION: v1
|
||||||
|
trigger:
|
||||||
|
branch:
|
||||||
|
- main
|
||||||
|
---
|
||||||
|
kind: pipeline
|
||||||
|
name: generate recipe catalogue
|
||||||
|
steps:
|
||||||
|
- name: release a new version
|
||||||
|
image: plugins/downstream
|
||||||
|
settings:
|
||||||
|
server: https://build.coopcloud.tech
|
||||||
|
token:
|
||||||
|
from_secret: drone_abra-bot_token
|
||||||
|
fork: true
|
||||||
|
repositories:
|
||||||
|
- toolshed/auto-recipes-catalogue-json
|
||||||
|
|
||||||
|
trigger:
|
||||||
|
event: tag
|
||||||
33
.env.sample
33
.env.sample
@ -1,7 +1,40 @@
|
|||||||
TYPE=cryptpad
|
TYPE=cryptpad
|
||||||
|
|
||||||
|
COMPOSE_FILE="compose.yml"
|
||||||
|
|
||||||
DOMAIN=cryptpad.example.com
|
DOMAIN=cryptpad.example.com
|
||||||
|
|
||||||
|
# This is a separate domain for the secure side of Cryptpad. It can be any other domain (subdomain or separate domain)
|
||||||
|
SANDBOX_DOMAIN=sandbox.cryptpad.example.com
|
||||||
|
|
||||||
|
# CRYPTPAD_ADMIN_KEYS
|
||||||
|
## here is an example of the format for one single key
|
||||||
|
# CRYPTPAD_ADMIN_KEYS= '"[user1@cryptpad.cctest.autonomic.zone/zew-WaKZimxhNSL3iiVL8SCzVzPB8KhIxZNrRKn+uRo=]",'
|
||||||
|
## here is an example of the format for multiple keys (including here because it was confusing to me)
|
||||||
|
# CRYPTPAD_ADMIN_KEYS='"[user1@cryptpad.cctest.autonomic.zone/zew-WaKZimxhNSL3iiVL8SCzVzPB8KhIxZNrRKn+uRo=]","[user2@cryptpad.cctest.autonomic.zone/Z7agNvwPXHm9xuEYOYV2YY53fSofgzum86xvhUxJ4nU=]",'
|
||||||
|
|
||||||
|
|
||||||
## Domain aliases
|
## Domain aliases
|
||||||
#EXTRA_DOMAINS=', `www.cryptpad.example.com`'
|
#EXTRA_DOMAINS=', `www.cryptpad.example.com`'
|
||||||
LETS_ENCRYPT_ENV=production
|
LETS_ENCRYPT_ENV=production
|
||||||
|
|
||||||
|
## Set to true to block unregistered users from accessing any CryptPad applications
|
||||||
|
## See https://docs.cryptpad.org/en/admin_guide/customization.html#restricting-guest-access
|
||||||
|
#RESTRICT_GUEST_ACCESS=false
|
||||||
|
|
||||||
|
## SSO / OIDC (optional — uncomment below and add compose.sso.yml to COMPOSE_FILE to enable)
|
||||||
|
# COMPOSE_FILE="$COMPOSE_FILE:compose.sso.yml"
|
||||||
|
#SSO_ENABLED=true
|
||||||
|
#SSO_ENFORCED=false
|
||||||
|
#SSO_PROVIDER_NAME=Authentik
|
||||||
|
#SSO_OIDC_URL=https://authentik.example.com/application/o/cryptpad
|
||||||
|
#SSO_CLIENT_ID=cryptpad
|
||||||
|
#SSO_CLIENT_SECRET_VERSION=v1
|
||||||
|
#SSO_JWT_ALG=RS256
|
||||||
|
#SSO_PLUGIN_VERSION=0.4.0
|
||||||
|
|
||||||
|
## Adding OnlyOffice to cryptpad
|
||||||
|
#COMPOSE_FILE="$COMPOSE_FILE:compose.onlyoffice.yaml"
|
||||||
|
## Enables installation of older onlyoffice versions so that older documents
|
||||||
|
## can also be loaded and converted.
|
||||||
|
#ONLYOFFICE_OLDEST=v6
|
||||||
|
|||||||
1
.gitignore
vendored
1
.gitignore
vendored
@ -1 +1,2 @@
|
|||||||
.envrc
|
.envrc
|
||||||
|
.idea
|
||||||
|
|||||||
78
README.md
78
README.md
@ -1,17 +1,17 @@
|
|||||||
# cryptpad
|
# cryptpad
|
||||||
|
|
||||||
TODO
|
[](https://build.coopcloud.tech/coop-cloud/cryptpad)
|
||||||
|
|
||||||
<!-- metadata -->
|
<!-- metadata -->
|
||||||
|
|
||||||
* **Category**: Apps
|
* **Category**: Apps
|
||||||
* **Status**:
|
* **Status**: 3
|
||||||
* **Image**:
|
* **Image**: cryptpad/cryptpad
|
||||||
* **Healthcheck**:
|
* **Healthcheck**: Yes
|
||||||
* **Backups**:
|
* **Backups**: Yes
|
||||||
* **Email**:
|
* **Email**: No
|
||||||
* **Tests**:
|
* **Tests**: No
|
||||||
* **SSO**:
|
* **SSO**: Yes
|
||||||
|
|
||||||
<!-- endmetadata -->
|
<!-- endmetadata -->
|
||||||
|
|
||||||
@ -21,10 +21,68 @@ TODO
|
|||||||
2. Deploy [`coop-cloud/traefik`]
|
2. Deploy [`coop-cloud/traefik`]
|
||||||
3. `abra app new cryptpad --secrets` (optionally with `--pass` if you'd like
|
3. `abra app new cryptpad --secrets` (optionally with `--pass` if you'd like
|
||||||
to save secrets in `pass`)
|
to save secrets in `pass`)
|
||||||
4. `abra app YOURAPPDOMAIN config` - be sure to change `$DOMAIN` to something that resolves to
|
4. `abra app config YOURAPPDOMAIN` - be sure to change `$DOMAIN` to something that resolves to
|
||||||
your Docker swarm box
|
your Docker swarm box
|
||||||
5. `abra app YOURAPPDOMAIN deploy`
|
5. `abra app deploy YOURAPPDOMAIN`
|
||||||
6. Open the configured domain in your browser to finish set-up
|
6. Open the configured domain in your browser to finish set-up
|
||||||
|
|
||||||
|
At this point, anyone with this domain can register new users with this cryptpad instance.
|
||||||
|
|
||||||
|
After you have registered a first user, here is how you can make this user into an admin.
|
||||||
|
After logging in as your user, go to: https://cryptpad.cctest.autonomic.zone/profile/
|
||||||
|
|
||||||
|
Click "Copy Public Key". This will copy your public key into your clipboard.
|
||||||
|
Then run `abra app config YOURAPPDOMAIN` and set the value of CRYPTPAD_ADMIN_KEYS
|
||||||
|
to include your public key. The example in .env.sample shows the required format.
|
||||||
|
|
||||||
|
Then redeploy with `abra app deploy YOURAPPDOMAIN --force`.
|
||||||
|
|
||||||
|
Now when you login as your user, and visit https://cryptpad.cctest.autonomic.zone/admin/,
|
||||||
|
you should be able to access the admin interface for this cryptpad instance.
|
||||||
|
|
||||||
|
## SSO
|
||||||
|
|
||||||
|
SSO support is provided by `compose.sso.yml`. To enable it, add the SSO compose file and set the SSO variables in your app config:
|
||||||
|
|
||||||
|
```
|
||||||
|
COMPOSE_FILE="compose.yml:compose.sso.yml"
|
||||||
|
SSO_ENABLED=true
|
||||||
|
```
|
||||||
|
|
||||||
|
On the next deploy, the [CryptPad SSO plugin](https://github.com/cryptpad/sso) will be installed automatically.
|
||||||
|
|
||||||
|
You also need to configure the remaining SSO environment variables for your OIDC provider:
|
||||||
|
|
||||||
|
- `SSO_PROVIDER_NAME` — display name shown on the login button (e.g. `Keycloak`, `Authentik`)
|
||||||
|
- `SSO_OIDC_URL` — OIDC discovery URL for your provider
|
||||||
|
- `SSO_CLIENT_ID` — OAuth2 client ID
|
||||||
|
- `SSO_JWT_ALG` — JWT signing algorithm (e.g. `RS256`)
|
||||||
|
|
||||||
|
The client secret is stored as a Docker secret. Insert it with:
|
||||||
|
|
||||||
|
```
|
||||||
|
abra app secret insert YOURAPPDOMAIN sso_client_s v1 YOUR_CLIENT_SECRET
|
||||||
|
```
|
||||||
|
|
||||||
|
Then deploy (or redeploy) to apply: `abra app deploy YOURAPPDOMAIN --force`.
|
||||||
|
|
||||||
|
## OnlyOffice
|
||||||
|
|
||||||
|
OnlyOffice support is provided by `compose.onlyoffice.yaml`. Enable it by adding the compose file to your app config:
|
||||||
|
|
||||||
|
```
|
||||||
|
COMPOSE_FILE="compose.yml:compose.onlyoffice.yaml"
|
||||||
|
```
|
||||||
|
|
||||||
|
On the next deploy, an entrypoint wrapper (`onlyoffice-entrypoint.sh`) prepares the OnlyOffice config volume **before** CryptPad starts, then the app container runs `install-onlyoffice.sh` to download the OnlyOffice assets. Running the prep work inside the app container (rather than a separate init service) is necessary because Docker Swarm ignores `depends_on` at runtime — a sidecar init container would race the app.
|
||||||
|
|
||||||
|
To support opening documents created with older OnlyOffice versions, set `ONLYOFFICE_OLDEST` in your app config. This writes (or updates) `oldest_needed_version` in `onlyoffice-conf/onlyoffice.properties`, which `install-onlyoffice.sh` reads to fetch older versions in addition to the latest:
|
||||||
|
|
||||||
|
```
|
||||||
|
ONLYOFFICE_OLDEST=v6
|
||||||
|
```
|
||||||
|
|
||||||
|
If `ONLYOFFICE_OLDEST` is unset, `onlyoffice.properties` is left untouched (CryptPad's own default applies). Only the `oldest_needed_version` key is touched on each deploy, so any other entries in `onlyoffice.properties` are preserved. If you change `ONLYOFFICE_OLDEST` after the assets have already been downloaded, you may need to drop the `cryptpad_oo_dist` volume so `install-onlyoffice.sh` re-runs and pulls the additional versions.
|
||||||
|
|
||||||
[`abra`]: https://git.coopcloud.tech/coop-cloud/abra
|
[`abra`]: https://git.coopcloud.tech/coop-cloud/abra
|
||||||
[`coop-cloud/traefik`]: https://git.coopcloud.tech/coop-cloud/traefik
|
[`coop-cloud/traefik`]: https://git.coopcloud.tech/coop-cloud/traefik
|
||||||
7
abra.sh
Normal file
7
abra.sh
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
export CONFIG_VERSION=v2
|
||||||
|
export CONFIG_JS_VERSION=v2
|
||||||
|
export NGINX_CONF_VERSION=v1
|
||||||
|
export SSO_ENTRYPOINT_VERSION=v6
|
||||||
|
export SSO_JS_VERSION=v3
|
||||||
|
export APP_CONFIG_JS_VERSION=v1
|
||||||
|
export ONLYOFFICE_ENTRYPOINT_VERSION=v1
|
||||||
24
application_config.js.tmpl
Normal file
24
application_config.js.tmpl
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
// CryptPad application customization — generated from environment variables
|
||||||
|
// See https://docs.cryptpad.org/en/admin_guide/customization.html
|
||||||
|
// For default file, see: https://github.com/cryptpad/cryptpad/blob/main/customize.dist/application_config.js
|
||||||
|
|
||||||
|
(() => {
|
||||||
|
const factory = (AppConfig) => {
|
||||||
|
{{ if eq (env "RESTRICT_GUEST_ACCESS") "true" }}
|
||||||
|
// Block unregistered users from accessing any applications
|
||||||
|
AppConfig.registeredOnlyTypes = AppConfig.availablePadTypes.slice();
|
||||||
|
{{ end }}
|
||||||
|
|
||||||
|
return AppConfig;
|
||||||
|
};
|
||||||
|
|
||||||
|
// Do not change code below
|
||||||
|
if (typeof(module) !== 'undefined' && module.exports) {
|
||||||
|
module.exports = factory(
|
||||||
|
require('../www/common/application_config_internal.js')
|
||||||
|
);
|
||||||
|
} else if ((typeof(define) !== 'undefined' && define !== null) && (define.amd !== null)) {
|
||||||
|
define(['/common/application_config_internal.js'], factory);
|
||||||
|
}
|
||||||
|
|
||||||
|
})();
|
||||||
48
compose.onlyoffice.yaml
Normal file
48
compose.onlyoffice.yaml
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
version: "3.8"
|
||||||
|
|
||||||
|
services:
|
||||||
|
init-onlyoffice-dirs:
|
||||||
|
image: busybox
|
||||||
|
user: root
|
||||||
|
command:
|
||||||
|
- sh
|
||||||
|
- -eu
|
||||||
|
- -c
|
||||||
|
- |
|
||||||
|
mkdir -p /cryptpad/www/common/onlyoffice/dist /cryptpad/onlyoffice-conf
|
||||||
|
chown -R 4001:4001 \
|
||||||
|
/cryptpad/www/common/onlyoffice/dist \
|
||||||
|
/cryptpad/onlyoffice-conf
|
||||||
|
exec tail -f /dev/null
|
||||||
|
volumes:
|
||||||
|
- cryptpad_oo_dist:/cryptpad/www/common/onlyoffice/dist
|
||||||
|
- cryptpad_oo_conf:/cryptpad/onlyoffice-conf/
|
||||||
|
|
||||||
|
app:
|
||||||
|
# onlyoffice-entrypoint.sh auto-chains through /sso-entrypoint.sh if
|
||||||
|
# compose.sso.yml is also loaded, so order of COMPOSE_FILE doesn't matter.
|
||||||
|
entrypoint:
|
||||||
|
- /onlyoffice-entrypoint.sh
|
||||||
|
- /cryptpad/docker-entrypoint.sh
|
||||||
|
environment:
|
||||||
|
- "CPAD_INSTALL_ONLYOFFICE=yes"
|
||||||
|
- ONLYOFFICE_OLDEST
|
||||||
|
volumes:
|
||||||
|
- cryptpad_oo_dist:/cryptpad/www/common/onlyoffice/dist
|
||||||
|
- cryptpad_oo_conf:/cryptpad/onlyoffice-conf/
|
||||||
|
configs:
|
||||||
|
- source: onlyoffice_entrypoint
|
||||||
|
target: /onlyoffice-entrypoint.sh
|
||||||
|
mode: 0755
|
||||||
|
deploy:
|
||||||
|
labels:
|
||||||
|
- "backupbot.backup.volumes.cryptpad_oo_dist=false"
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
cryptpad_oo_dist:
|
||||||
|
cryptpad_oo_conf:
|
||||||
|
|
||||||
|
configs:
|
||||||
|
onlyoffice_entrypoint:
|
||||||
|
name: ${STACK_NAME}_onlyoffice_entrypoint_${ONLYOFFICE_ENTRYPOINT_VERSION}
|
||||||
|
file: onlyoffice-entrypoint.sh
|
||||||
41
compose.sso.yml
Normal file
41
compose.sso.yml
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
---
|
||||||
|
version: "3.8"
|
||||||
|
|
||||||
|
services:
|
||||||
|
app:
|
||||||
|
entrypoint: ["/sso-entrypoint.sh", "/cryptpad/docker-entrypoint.sh"]
|
||||||
|
environment:
|
||||||
|
- SSO_PLUGIN_VERSION
|
||||||
|
- "SSO_ENABLED=${SSO_ENABLED:-false}"
|
||||||
|
- SSO_ENFORCED
|
||||||
|
- SSO_PROVIDER_NAME
|
||||||
|
- SSO_OIDC_URL
|
||||||
|
- SSO_CLIENT_ID
|
||||||
|
- SSO_JWT_ALG
|
||||||
|
secrets:
|
||||||
|
- sso_client_s
|
||||||
|
volumes:
|
||||||
|
- cryptpad_plugins:/cryptpad/lib/plugins
|
||||||
|
configs:
|
||||||
|
- source: sso_entrypoint
|
||||||
|
target: /sso-entrypoint.sh
|
||||||
|
mode: 0755
|
||||||
|
- source: sso_js
|
||||||
|
target: /sso.js
|
||||||
|
|
||||||
|
volumes:
|
||||||
|
cryptpad_plugins:
|
||||||
|
|
||||||
|
secrets:
|
||||||
|
sso_client_s:
|
||||||
|
external: true
|
||||||
|
name: ${STACK_NAME}_sso_client_s_${SSO_CLIENT_SECRET_VERSION}
|
||||||
|
|
||||||
|
configs:
|
||||||
|
sso_entrypoint:
|
||||||
|
name: ${STACK_NAME}_sso_entrypoint_${SSO_ENTRYPOINT_VERSION}
|
||||||
|
file: sso-entrypoint.sh
|
||||||
|
sso_js:
|
||||||
|
name: ${STACK_NAME}_sso_js_${SSO_JS_VERSION}
|
||||||
|
file: sso.js.tmpl
|
||||||
|
template_driver: golang
|
||||||
82
compose.yml
82
compose.yml
@ -3,16 +3,20 @@ version: "3.8"
|
|||||||
|
|
||||||
services:
|
services:
|
||||||
app:
|
app:
|
||||||
image: promasu/cryptpad:nginx
|
image: cryptpad/cryptpad:version-2026.5.1
|
||||||
|
command: ["npm", "start"]
|
||||||
networks:
|
networks:
|
||||||
- proxy
|
- backend
|
||||||
environment:
|
environment:
|
||||||
|
- CRYPTPAD_ADMIN_KEYS
|
||||||
- "CPAD_MAIN_DOMAIN=${DOMAIN}"
|
- "CPAD_MAIN_DOMAIN=${DOMAIN}"
|
||||||
- "CPAD_SANDBOX_DOMAIN=sandbox.${DOMAIN}"
|
- "CPAD_SANDBOX_DOMAIN=${SANDBOX_DOMAIN}"
|
||||||
# Traefik can't use HTTP2 to communicate with cryptpat_websocket
|
# Traefik can't use HTTP2 to communicate with cryptpad_websocket
|
||||||
# A workaroung is disabling HTTP2 in Nginx
|
# A workaroung is disabling HTTP2 in Nginx
|
||||||
- CPAD_HTTP2_DISABLE=true
|
- "CPAD_HTTP2_DISABLE=true"
|
||||||
|
- "CPAD_TRUST_PROXY=1"
|
||||||
|
- "CPAD_CONF=/cryptpad/config/config.js"
|
||||||
|
- "RESTRICT_GUEST_ACCESS=${RESTRICT_GUEST_ACCESS:-false}"
|
||||||
volumes:
|
volumes:
|
||||||
- cryptpad_blob:/cryptpad/blob
|
- cryptpad_blob:/cryptpad/blob
|
||||||
- cryptpad_block:/cryptpad/block
|
- cryptpad_block:/cryptpad/block
|
||||||
@ -20,33 +24,53 @@ services:
|
|||||||
- cryptpad_data:/cryptpad/data
|
- cryptpad_data:/cryptpad/data
|
||||||
- cryptpad_files:/cryptpad/datastore
|
- cryptpad_files:/cryptpad/datastore
|
||||||
- cryptpad_config:/cryptpad/config/
|
- cryptpad_config:/cryptpad/config/
|
||||||
|
configs:
|
||||||
|
- source: config_js
|
||||||
|
target: /cryptpad/config/config.js
|
||||||
|
- source: app_config_js
|
||||||
|
target: /cryptpad/customize/application_config.js
|
||||||
|
|
||||||
deploy:
|
deploy:
|
||||||
restart_policy:
|
restart_policy:
|
||||||
condition: on-failure
|
condition: on-failure
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=false"
|
||||||
|
- "coop-cloud.${STACK_NAME}.timeout=${TIMEOUT:-120}"
|
||||||
|
- "coop-cloud.${STACK_NAME}.version=0.6.0+v2026.5.1"
|
||||||
|
- "backupbot.backup=true"
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD", "curl", "-f", "http://localhost:3000"]
|
||||||
|
interval: 30s
|
||||||
|
timeout: 10s
|
||||||
|
retries: 10
|
||||||
|
start_period: 1m
|
||||||
|
|
||||||
|
web:
|
||||||
|
image: nginx:1.31
|
||||||
|
configs:
|
||||||
|
- source: nginx_conf
|
||||||
|
target: /etc/nginx/conf.d/default.conf
|
||||||
|
networks:
|
||||||
|
proxy:
|
||||||
|
backend:
|
||||||
|
depends_on:
|
||||||
|
- app
|
||||||
|
environment:
|
||||||
|
- STACK_NAME
|
||||||
|
deploy:
|
||||||
labels:
|
labels:
|
||||||
- "traefik.enable=true"
|
- "traefik.enable=true"
|
||||||
- "traefik.http.services.${STACK_NAME}.loadbalancer.server.port=80"
|
- "traefik.docker.network=proxy"
|
||||||
- "traefik.http.routers.${STACK_NAME}.rule=Host(`${DOMAIN}`, `sandbox.${DOMAIN}`${EXTRA_DOMAINS})"
|
- "traefik.http.routers.${STACK_NAME}.tls=true"
|
||||||
- "traefik.http.routers.${STACK_NAME}.entrypoints=web-secure"
|
- "traefik.http.services.${STACK_NAME}.loadbalancer.server.port=8083"
|
||||||
|
- "traefik.http.routers.${STACK_NAME}.rule=Host(`${DOMAIN}`, `${SANDBOX_DOMAIN}` ${EXTRA_DOMAINS})"
|
||||||
- "traefik.http.routers.${STACK_NAME}.tls.certresolver=${LETS_ENCRYPT_ENV}"
|
- "traefik.http.routers.${STACK_NAME}.tls.certresolver=${LETS_ENCRYPT_ENV}"
|
||||||
- "traefik.http.routers.${STACK_NAME}.tls.domains[0].main=${DOMAIN}"
|
- "traefik.http.routers.${STACK_NAME}.entrypoints=web-secure"
|
||||||
- "traefik.http.routers.${STACK_NAME}.tls.domains[0].sans=sandbox.${DOMAIN}"
|
|
||||||
## Redirect from EXTRA_DOMAINS to DOMAIN
|
|
||||||
#- "traefik.http.routers.${STACK_NAME}.middlewares=${STACK_NAME}-redirect"
|
|
||||||
#- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLForceHost=true"
|
|
||||||
#- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLHost=${DOMAIN}"
|
|
||||||
- "coop-cloud.${STACK_NAME}.version=0.1.0+nginx"
|
|
||||||
# healthcheck:
|
|
||||||
# test: ["CMD", "curl", "-f", "http://localhost"]
|
|
||||||
# interval: 30s
|
|
||||||
# timeout: 10s
|
|
||||||
# retries: 10
|
|
||||||
# start_period: 1m
|
|
||||||
|
|
||||||
networks:
|
networks:
|
||||||
proxy:
|
proxy:
|
||||||
external: true
|
external: true
|
||||||
|
backend:
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
cryptpad_blob:
|
cryptpad_blob:
|
||||||
@ -55,3 +79,17 @@ volumes:
|
|||||||
cryptpad_data:
|
cryptpad_data:
|
||||||
cryptpad_files:
|
cryptpad_files:
|
||||||
cryptpad_config:
|
cryptpad_config:
|
||||||
|
|
||||||
|
configs:
|
||||||
|
config_js:
|
||||||
|
name: ${STACK_NAME}_config_${CONFIG_VERSION}
|
||||||
|
file: config.js.tmpl
|
||||||
|
template_driver: golang
|
||||||
|
nginx_conf:
|
||||||
|
name: ${STACK_NAME}_nginx_conf_${NGINX_CONF_VERSION}
|
||||||
|
file: nginx.conf.tmpl
|
||||||
|
template_driver: golang
|
||||||
|
app_config_js:
|
||||||
|
name: ${STACK_NAME}_app_config_js_${APP_CONFIG_JS_VERSION}
|
||||||
|
file: application_config.js.tmpl
|
||||||
|
template_driver: golang
|
||||||
|
|||||||
282
config.js.tmpl
Normal file
282
config.js.tmpl
Normal file
@ -0,0 +1,282 @@
|
|||||||
|
/* globals module */
|
||||||
|
|
||||||
|
/* DISCLAIMER:
|
||||||
|
|
||||||
|
There are two recommended methods of running a CryptPad instance:
|
||||||
|
|
||||||
|
1. Using a standalone nodejs server without HTTPS (suitable for local development)
|
||||||
|
2. Using NGINX to serve static assets and to handle HTTPS for API server's websocket traffic
|
||||||
|
|
||||||
|
We do not officially recommend or support Apache, Docker, Kubernetes, Traefik, or any other configuration.
|
||||||
|
Support requests for such setups should be directed to their authors.
|
||||||
|
|
||||||
|
If you're having difficulty difficulty configuring your instance
|
||||||
|
we suggest that you join the project's Matrix channel.
|
||||||
|
|
||||||
|
If you don't have any difficulty configuring your instance and you'd like to
|
||||||
|
support us for the work that went into making it pain-free we are quite happy
|
||||||
|
to accept donations via our opencollective page: https://opencollective.com/cryptpad
|
||||||
|
|
||||||
|
*/
|
||||||
|
module.exports = {
|
||||||
|
/* CryptPad is designed to serve its content over two domains.
|
||||||
|
* Account passwords and cryptographic content is handled on the 'main' domain,
|
||||||
|
* while the user interface is loaded on a 'sandbox' domain
|
||||||
|
* which can only access information which the main domain willingly shares.
|
||||||
|
*
|
||||||
|
* In the event of an XSS vulnerability in the UI (that's bad)
|
||||||
|
* this system prevents attackers from gaining access to your account (that's good).
|
||||||
|
*
|
||||||
|
* Most problems with new instances are related to this system blocking access
|
||||||
|
* because of incorrectly configured sandboxes. If you only see a white screen
|
||||||
|
* when you try to load CryptPad, this is probably the cause.
|
||||||
|
*
|
||||||
|
* PLEASE READ THE FOLLOWING COMMENTS CAREFULLY.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* httpUnsafeOrigin is the URL that clients will enter to load your instance.
|
||||||
|
* Any other URL that somehow points to your instance is supposed to be blocked.
|
||||||
|
* The default provided below assumes you are loading CryptPad from a server
|
||||||
|
* which is running on the same machine, using port 3000.
|
||||||
|
*
|
||||||
|
* In a production instance this should be available ONLY over HTTPS
|
||||||
|
* using the default port for HTTPS (443) ie. https://cryptpad.fr
|
||||||
|
* In such a case this should be also handled by NGINX, as documented in
|
||||||
|
* cryptpad/docs/example.nginx.conf (see the $main_domain variable)
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
httpUnsafeOrigin: 'https://{{ env "CPAD_MAIN_DOMAIN" }}',
|
||||||
|
|
||||||
|
/* httpSafeOrigin is the URL that is used for the 'sandbox' described above.
|
||||||
|
* If you're testing or developing with CryptPad on your local machine then
|
||||||
|
* it is appropriate to leave this blank. The default behaviour is to serve
|
||||||
|
* the main domain over port 3000 and to serve the sandbox content over port 3001.
|
||||||
|
*
|
||||||
|
* This is not appropriate in a production environment where invasive networks
|
||||||
|
* may filter traffic going over abnormal ports.
|
||||||
|
* To correctly configure your production instance you must provide a URL
|
||||||
|
* with a different domain (a subdomain is sufficient).
|
||||||
|
* It will be used to load the UI in our 'sandbox' system.
|
||||||
|
*
|
||||||
|
* This value corresponds to the $sandbox_domain variable
|
||||||
|
* in the example nginx file.
|
||||||
|
*
|
||||||
|
* Note that in order for the sandboxing system to be effective
|
||||||
|
* httpSafeOrigin must be different from httpUnsafeOrigin.
|
||||||
|
*
|
||||||
|
* CUSTOMIZE AND UNCOMMENT THIS FOR PRODUCTION INSTALLATIONS.
|
||||||
|
*/
|
||||||
|
httpSafeOrigin: 'https://{{ env "CPAD_SANDBOX_DOMAIN" }}',
|
||||||
|
|
||||||
|
/* httpAddress specifies the address on which the nodejs server
|
||||||
|
* should be accessible. By default it will listen on 127.0.0.1
|
||||||
|
* (IPv4 localhost on most systems). If you want it to listen on
|
||||||
|
* all addresses, including IPv6, set this to '::'.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
httpAddress: '::',
|
||||||
|
|
||||||
|
/* httpPort specifies on which port the nodejs server should listen.
|
||||||
|
* By default it will serve content over port 3000, which is suitable
|
||||||
|
* for both local development and for use with the provided nginx example,
|
||||||
|
* which will proxy websocket traffic to your node server.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
//httpPort: 3000,
|
||||||
|
|
||||||
|
/* httpSafePort allows you to specify an alternative port from which
|
||||||
|
* the node process should serve sandboxed assets. The default value is
|
||||||
|
* that of your httpPort + 1. You probably don't need to change this.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
//httpSafePort: 3001,
|
||||||
|
|
||||||
|
/* CryptPad will launch a child process for every core available
|
||||||
|
* in order to perform CPU-intensive tasks in parallel.
|
||||||
|
* Some host environments may have a very large number of cores available
|
||||||
|
* or you may want to limit how much computing power CryptPad can take.
|
||||||
|
* If so, set 'maxWorkers' to a positive integer.
|
||||||
|
*/
|
||||||
|
// maxWorkers: 4,
|
||||||
|
|
||||||
|
/* =====================
|
||||||
|
* Admin
|
||||||
|
* ===================== */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* CryptPad contains an administration panel. Its access is restricted to specific
|
||||||
|
* users using the following list.
|
||||||
|
* To give access to the admin panel to a user account, just add their public signing
|
||||||
|
* key, which can be found on the settings page for registered users.
|
||||||
|
* Entries should be strings separated by a comma.
|
||||||
|
*/
|
||||||
|
adminKeys: [
|
||||||
|
{{ env "CRYPTPAD_ADMIN_KEYS" }}
|
||||||
|
],
|
||||||
|
|
||||||
|
/* =====================
|
||||||
|
* STORAGE
|
||||||
|
* ===================== */
|
||||||
|
|
||||||
|
/* Pads that are not 'pinned' by any registered user can be set to expire
|
||||||
|
* after a configurable number of days of inactivity (default 90 days).
|
||||||
|
* The value can be changed or set to false to remove expiration.
|
||||||
|
* Expired pads can then be removed using a cron job calling the
|
||||||
|
* `evict-inactive.js` script with node
|
||||||
|
*
|
||||||
|
* defaults to 90 days if nothing is provided
|
||||||
|
*/
|
||||||
|
//inactiveTime: 90, // days
|
||||||
|
|
||||||
|
/* CryptPad archives some data instead of deleting it outright.
|
||||||
|
* This archived data still takes up space and so you'll probably still want to
|
||||||
|
* remove these files after a brief period.
|
||||||
|
*
|
||||||
|
* cryptpad/scripts/evict-inactive.js is intended to be run daily
|
||||||
|
* from a crontab or similar scheduling service.
|
||||||
|
*
|
||||||
|
* The intent with this feature is to provide a safety net in case of accidental
|
||||||
|
* deletion. Set this value to the number of days you'd like to retain
|
||||||
|
* archived data before it's removed permanently.
|
||||||
|
*
|
||||||
|
* defaults to 15 days if nothing is provided
|
||||||
|
*/
|
||||||
|
//archiveRetentionTime: 15,
|
||||||
|
|
||||||
|
/* It's possible to configure your instance to remove data
|
||||||
|
* stored on behalf of inactive accounts. Set 'accountRetentionTime'
|
||||||
|
* to the number of days an account can remain idle before its
|
||||||
|
* documents and other account data is removed.
|
||||||
|
*
|
||||||
|
* Leave this value commented out to preserve all data stored
|
||||||
|
* by user accounts regardless of inactivity.
|
||||||
|
*/
|
||||||
|
//accountRetentionTime: 365,
|
||||||
|
|
||||||
|
/* Starting with CryptPad 3.23.0, the server automatically runs
|
||||||
|
* the script responsible for removing inactive data according to
|
||||||
|
* your configured definition of inactivity. Set this value to `true`
|
||||||
|
* if you prefer not to remove inactive data, or if you prefer to
|
||||||
|
* do so manually using `scripts/evict-inactive.js`.
|
||||||
|
*/
|
||||||
|
//disableIntegratedEviction: true,
|
||||||
|
|
||||||
|
|
||||||
|
/* Max Upload Size (bytes)
|
||||||
|
* this sets the maximum size of any one file uploaded to the server.
|
||||||
|
* anything larger than this size will be rejected
|
||||||
|
* defaults to 20MB if no value is provided
|
||||||
|
*/
|
||||||
|
//maxUploadSize: 20 * 1024 * 1024,
|
||||||
|
|
||||||
|
/* Users with premium accounts (those with a plan included in their customLimit)
|
||||||
|
* can benefit from an increased upload size limit. By default they are restricted to the same
|
||||||
|
* upload size as any other registered user.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
//premiumUploadSize: 100 * 1024 * 1024,
|
||||||
|
|
||||||
|
/* =====================
|
||||||
|
* DATABASE VOLUMES
|
||||||
|
* ===================== */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* CryptPad stores each document in an individual file on your hard drive.
|
||||||
|
* Specify a directory where files should be stored.
|
||||||
|
* It will be created automatically if it does not already exist.
|
||||||
|
*/
|
||||||
|
filePath: './datastore/',
|
||||||
|
|
||||||
|
/* CryptPad offers the ability to archive data for a configurable period
|
||||||
|
* before deleting it, allowing a means of recovering data in the event
|
||||||
|
* that it was deleted accidentally.
|
||||||
|
*
|
||||||
|
* To set the location of this archive directory to a custom value, change
|
||||||
|
* the path below:
|
||||||
|
*/
|
||||||
|
archivePath: './data/archive',
|
||||||
|
|
||||||
|
/* CryptPad allows logged in users to request that particular documents be
|
||||||
|
* stored by the server indefinitely. This is called 'pinning'.
|
||||||
|
* Pin requests are stored in a pin-store. The location of this store is
|
||||||
|
* defined here.
|
||||||
|
*/
|
||||||
|
pinPath: './data/pins',
|
||||||
|
|
||||||
|
/* if you would like the list of scheduled tasks to be stored in
|
||||||
|
a custom location, change the path below:
|
||||||
|
*/
|
||||||
|
taskPath: './data/tasks',
|
||||||
|
|
||||||
|
/* if you would like users' authenticated blocks to be stored in
|
||||||
|
a custom location, change the path below:
|
||||||
|
*/
|
||||||
|
blockPath: './block',
|
||||||
|
|
||||||
|
/* CryptPad allows logged in users to upload encrypted files. Files/blobs
|
||||||
|
* are stored in a 'blob-store'. Set its location here.
|
||||||
|
*/
|
||||||
|
blobPath: './blob',
|
||||||
|
|
||||||
|
/* CryptPad stores incomplete blobs in a 'staging' area until they are
|
||||||
|
* fully uploaded. Set its location here.
|
||||||
|
*/
|
||||||
|
blobStagingPath: './data/blobstage',
|
||||||
|
|
||||||
|
decreePath: './data/decrees',
|
||||||
|
|
||||||
|
/* CryptPad supports logging events directly to the disk in a 'logs' directory
|
||||||
|
* Set its location here, or set it to false (or nothing) if you'd rather not log
|
||||||
|
*/
|
||||||
|
logPath: './data/logs',
|
||||||
|
|
||||||
|
/* =====================
|
||||||
|
* Debugging
|
||||||
|
* ===================== */
|
||||||
|
|
||||||
|
/* CryptPad can log activity to stdout
|
||||||
|
* This may be useful for debugging
|
||||||
|
*/
|
||||||
|
logToStdout: true,
|
||||||
|
|
||||||
|
/* CryptPad can be configured to log more or less
|
||||||
|
* the various settings are listed below by order of importance
|
||||||
|
*
|
||||||
|
* silly, verbose, debug, feedback, info, warn, error
|
||||||
|
*
|
||||||
|
* Choose the least important level of logging you wish to see.
|
||||||
|
* For example, a 'silly' logLevel will display everything,
|
||||||
|
* while 'info' will display 'info', 'warn', and 'error' logs
|
||||||
|
*
|
||||||
|
* This will affect both logging to the console and the disk.
|
||||||
|
*/
|
||||||
|
logLevel: 'info',
|
||||||
|
|
||||||
|
/* clients can use the /settings/ app to opt out of usage feedback
|
||||||
|
* which informs the server of things like how much each app is being
|
||||||
|
* used, and whether certain clientside features are supported by
|
||||||
|
* the client's browser. The intent is to provide feedback to the admin
|
||||||
|
* such that the service can be improved. Enable this with `true`
|
||||||
|
* and ignore feedback with `false` or by commenting the attribute
|
||||||
|
*
|
||||||
|
* You will need to set your logLevel to include 'feedback'. Set this
|
||||||
|
* to false if you'd like to exclude feedback from your logs.
|
||||||
|
*/
|
||||||
|
logFeedback: false,
|
||||||
|
|
||||||
|
/* CryptPad supports verbose logging
|
||||||
|
* (false by default)
|
||||||
|
*/
|
||||||
|
verbose: false,
|
||||||
|
|
||||||
|
/* Surplus information:
|
||||||
|
*
|
||||||
|
* 'installMethod' is included in server telemetry to voluntarily
|
||||||
|
* indicate how many instances are using unofficial installation methods
|
||||||
|
* such as Docker.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
installMethod: 'unspecified',
|
||||||
|
};
|
||||||
|
|
||||||
39
nginx.conf.tmpl
Normal file
39
nginx.conf.tmpl
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
server {
|
||||||
|
listen 8083;
|
||||||
|
server_name localhost;
|
||||||
|
|
||||||
|
access_log /var/log/cpad.log;
|
||||||
|
error_log /var/log/cpad-error.log;
|
||||||
|
#access_log /dev/null;
|
||||||
|
#error_log /dev/null emerg;
|
||||||
|
|
||||||
|
# Main CryptPad app
|
||||||
|
location / {
|
||||||
|
proxy_pass http://{{ env "STACK_NAME" }}_app:3000;
|
||||||
|
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
proxy_set_header X-Real-IP $remote_addr;
|
||||||
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||||
|
proxy_set_header X-Forwarded-Proto $scheme;
|
||||||
|
|
||||||
|
client_max_body_size 150m;
|
||||||
|
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection upgrade;
|
||||||
|
}
|
||||||
|
|
||||||
|
# WebSocket endpoint
|
||||||
|
location ^~ /cryptpad_websocket {
|
||||||
|
proxy_pass http://{{ env "STACK_NAME" }}_app:3003;
|
||||||
|
|
||||||
|
proxy_set_header Host $host;
|
||||||
|
proxy_set_header X-Real-IP $remote_addr;
|
||||||
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||||
|
proxy_set_header X-Forwarded-Proto $scheme;
|
||||||
|
|
||||||
|
proxy_http_version 1.1;
|
||||||
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
proxy_set_header Connection upgrade;
|
||||||
|
}
|
||||||
|
}
|
||||||
42
onlyoffice-entrypoint.sh
Normal file
42
onlyoffice-entrypoint.sh
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# OnlyOffice init — runs before the original CryptPad entrypoint.
|
||||||
|
# Ensures oldest_needed_version in onlyoffice.properties matches
|
||||||
|
# ONLYOFFICE_OLDEST before install-onlyoffice.sh / CryptPad reads it.
|
||||||
|
|
||||||
|
CONF_DIR="/cryptpad/onlyoffice-conf"
|
||||||
|
PROPS="${CONF_DIR}/onlyoffice.properties"
|
||||||
|
|
||||||
|
# Wait for init-onlyoffice-dirs to chown the volumes. Swarm ignores
|
||||||
|
# depends_on, so the init sidecar and this container start in parallel.
|
||||||
|
waited=0
|
||||||
|
while [ ! -w "${CONF_DIR}" ]; do
|
||||||
|
if [ "${waited}" -ge 60 ]; then
|
||||||
|
echo "[onlyoffice-entrypoint] timed out waiting for ${CONF_DIR} to become writable" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
echo "[onlyoffice-entrypoint] waiting for ${CONF_DIR} to be writable (${waited}s)"
|
||||||
|
sleep 1
|
||||||
|
waited=$((waited + 1))
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ -n "${ONLYOFFICE_OLDEST:-}" ]; then
|
||||||
|
mkdir -p "${CONF_DIR}"
|
||||||
|
touch "${PROPS}"
|
||||||
|
if grep -q '^oldest_needed_version=' "${PROPS}"; then
|
||||||
|
sed -i "s|^oldest_needed_version=.*|oldest_needed_version=${ONLYOFFICE_OLDEST}|" "${PROPS}"
|
||||||
|
else
|
||||||
|
echo "oldest_needed_version=${ONLYOFFICE_OLDEST}" >> "${PROPS}"
|
||||||
|
fi
|
||||||
|
echo "[onlyoffice-entrypoint] oldest_needed_version=${ONLYOFFICE_OLDEST}"
|
||||||
|
else
|
||||||
|
echo "[onlyoffice-entrypoint] ONLYOFFICE_OLDEST unset, leaving ${PROPS} untouched"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Chain through the SSO entrypoint if compose.sso.yml mounted it.
|
||||||
|
if [ -x /sso-entrypoint.sh ]; then
|
||||||
|
exec /sso-entrypoint.sh "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec "$@"
|
||||||
6
renovate.json
Normal file
6
renovate.json
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"$schema": "https://docs.renovatebot.com/renovate-schema.json",
|
||||||
|
"extends": [
|
||||||
|
"config:recommended"
|
||||||
|
]
|
||||||
|
}
|
||||||
37
sso-entrypoint.sh
Normal file
37
sso-entrypoint.sh
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
set -e
|
||||||
|
|
||||||
|
# SSO plugin installer — runs before the original CryptPad entrypoint.
|
||||||
|
# Clones the cryptpad/sso plugin into the plugins volume if not already present
|
||||||
|
# or if the version has changed.
|
||||||
|
|
||||||
|
# Skips SSO setup entirely when SSO_ENABLED is not "true".
|
||||||
|
if [ "${SSO_ENABLED}" != "true" ]; then
|
||||||
|
echo "[sso-entrypoint] SSO not enabled, skipping plugin install"
|
||||||
|
exec "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
PLUGIN_DIR="/cryptpad/lib/plugins/sso"
|
||||||
|
VERSION_FILE="${PLUGIN_DIR}/.version"
|
||||||
|
SSO_PLUGIN_VERSION="${SSO_PLUGIN_VERSION:-0.4.0}"
|
||||||
|
|
||||||
|
# Copy SSO config template into place (mounted as Docker config)
|
||||||
|
if [ -f /sso.js ]; then
|
||||||
|
cp /sso.js /cryptpad/config/sso.js
|
||||||
|
echo "[sso-entrypoint] Copied sso.js config into /cryptpad/config/sso.js"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Install/update the SSO plugin
|
||||||
|
if [ -f "${VERSION_FILE}" ] && [ "$(cat "${VERSION_FILE}")" = "${SSO_PLUGIN_VERSION}" ]; then
|
||||||
|
echo "[sso-entrypoint] SSO plugin ${SSO_PLUGIN_VERSION} already installed"
|
||||||
|
else
|
||||||
|
echo "[sso-entrypoint] Installing SSO plugin ${SSO_PLUGIN_VERSION} ..."
|
||||||
|
rm -rf "${PLUGIN_DIR}"
|
||||||
|
git clone --depth 1 --branch "${SSO_PLUGIN_VERSION}" \
|
||||||
|
https://github.com/cryptpad/sso.git "${PLUGIN_DIR}"
|
||||||
|
echo "${SSO_PLUGIN_VERSION}" > "${VERSION_FILE}"
|
||||||
|
echo "[sso-entrypoint] SSO plugin installed"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Hand off to the original CryptPad entrypoint
|
||||||
|
exec "$@"
|
||||||
21
sso.js.tmpl
Normal file
21
sso.js.tmpl
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
// CryptPad SSO configuration — generated from environment variables
|
||||||
|
// See https://github.com/cryptpad/sso for documentation
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
enabled: "{{ env "SSO_ENABLED" }}" === "true",
|
||||||
|
enforced: "{{ env "SSO_ENFORCED" }}" === "true",
|
||||||
|
cpPassword: true,
|
||||||
|
forceCpPassword: false,
|
||||||
|
list: [
|
||||||
|
{
|
||||||
|
name: "{{ env "SSO_PROVIDER_NAME" }}",
|
||||||
|
type: "oidc",
|
||||||
|
url: "{{ env "SSO_OIDC_URL" }}",
|
||||||
|
client_id: "{{ env "SSO_CLIENT_ID" }}",
|
||||||
|
client_secret: "{{ secret "sso_client_s" }}",
|
||||||
|
id_token_alg: "{{ env "SSO_JWT_ALG" }}",
|
||||||
|
use_pkce: true,
|
||||||
|
use_nonce: true
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user