2023-10-20 22:35:26 +08:00
|
|
|
// SPDX-FileCopyrightText: 2023 XWiki CryptPad Team <contact@cryptpad.org> and contributors
|
|
|
|
//
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
|
2020-02-29 03:24:03 +08:00
|
|
|
/* 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.
|
2016-01-29 18:35:44 +08:00
|
|
|
|
2020-02-29 03:24:03 +08:00
|
|
|
If you're having difficulty difficulty configuring your instance
|
2022-05-20 23:28:41 +08:00
|
|
|
we suggest that you join the project's Matrix channel.
|
2019-01-28 19:18:18 +08:00
|
|
|
|
2020-02-29 03:24:03 +08:00
|
|
|
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
|
2020-12-15 16:07:13 +08:00
|
|
|
* In such a case this should be also handled by NGINX, as documented in
|
2020-02-29 03:24:03 +08:00
|
|
|
* cryptpad/docs/example.nginx.conf (see the $main_domain variable)
|
|
|
|
*
|
|
|
|
*/
|
2021-03-22 16:42:14 +08:00
|
|
|
httpUnsafeOrigin: 'http://localhost:3000',
|
2020-02-29 03:24:03 +08:00
|
|
|
|
|
|
|
/* 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
|
2022-04-07 17:44:06 +08:00
|
|
|
* the main domain over port 3000 and to serve the sandbox content over port 3001.
|
2020-02-29 03:24:03 +08:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
2022-04-07 17:44:06 +08:00
|
|
|
* Note that in order for the sandboxing system to be effective
|
|
|
|
* httpSafeOrigin must be different from httpUnsafeOrigin.
|
|
|
|
*
|
2020-02-29 03:24:03 +08:00
|
|
|
* CUSTOMIZE AND UNCOMMENT THIS FOR PRODUCTION INSTALLATIONS.
|
|
|
|
*/
|
|
|
|
// httpSafeOrigin: "https://some-other-domain.xyz",
|
2020-02-28 02:24:19 +08:00
|
|
|
|
2020-02-29 03:24:03 +08:00
|
|
|
/* httpAddress specifies the address on which the nodejs server
|
2023-12-18 22:47:10 +08:00
|
|
|
* should be accessible. By default it will listen on localhost
|
|
|
|
* (IPv4 & IPv6 if enabled). If you want it to listen on
|
|
|
|
* a specific address, specify it here. e.g '192.168.0.1'
|
2020-02-29 03:24:03 +08:00
|
|
|
*
|
|
|
|
*/
|
2023-12-18 22:47:10 +08:00
|
|
|
//httpAddress: 'localhost',
|
2020-02-28 02:24:19 +08:00
|
|
|
|
2020-02-29 03:24:03 +08:00
|
|
|
/* 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.
|
|
|
|
*
|
|
|
|
*/
|
2020-02-29 02:17:02 +08:00
|
|
|
//httpPort: 3000,
|
2020-02-28 02:24:19 +08:00
|
|
|
|
2024-06-21 22:12:00 +08:00
|
|
|
/* httpSafePort purpose is to emulate another origin for the sandbox when
|
|
|
|
* you don't have two domains at hand (i.e. when httpSafeOrigin not defined).
|
|
|
|
* It is meant to be used only in case where you are working on a local
|
|
|
|
* development instance. The default value is your httpPort + 1.
|
2020-02-29 03:24:03 +08:00
|
|
|
*
|
|
|
|
*/
|
|
|
|
//httpSafePort: 3001,
|
2020-02-28 02:24:19 +08:00
|
|
|
|
2022-12-20 18:59:38 +08:00
|
|
|
/* Websockets need to be exposed on a separate port from the rest of
|
|
|
|
* the platform's HTTP traffic. Port 3003 is used by default.
|
|
|
|
* You can change this to a different port if it is in use by a
|
|
|
|
* different service, but under most circumstances you can leave this
|
|
|
|
* commented and it will work.
|
|
|
|
*
|
|
|
|
* In production environments, your reverse proxy (usually NGINX)
|
|
|
|
* will need to forward websocket traffic (/cryptpad_websocket)
|
|
|
|
* to this port.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
// websocketPort: 3003,
|
|
|
|
|
2020-04-17 01:53:45 +08:00
|
|
|
/* 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,
|
|
|
|
|
2023-11-08 22:58:28 +08:00
|
|
|
/* =====================
|
|
|
|
* Sessions
|
|
|
|
* ===================== */
|
|
|
|
|
|
|
|
/* Accounts can be protected with an OTP (One Time Password) system
|
|
|
|
* to add a second authentication layer. Such accounts use a session
|
|
|
|
* with a given lifetime after which they are logged out and need
|
|
|
|
* to be re-authenticated. You can configure the lifetime of these
|
|
|
|
* sessions here.
|
|
|
|
*
|
|
|
|
* defaults to 7 days
|
|
|
|
*/
|
|
|
|
//otpSessionExpiration: 7*24, // hours
|
|
|
|
|
2023-11-09 22:35:56 +08:00
|
|
|
/* Registered users can be forced to protect their account
|
|
|
|
* with a Multi-factor Authentication (MFA) tool like a TOTP
|
|
|
|
* authenticator application.
|
|
|
|
*
|
|
|
|
* defaults to false
|
|
|
|
*/
|
|
|
|
//enforceMFA: false,
|
|
|
|
|
2024-02-20 01:15:05 +08:00
|
|
|
/* =====================
|
|
|
|
* Privacy
|
|
|
|
* ===================== */
|
|
|
|
|
|
|
|
/* Depending on where your instance is hosted, you may be required to log IP
|
|
|
|
* addresses of the users who make a change to a document. This setting allows you
|
|
|
|
* to do so. You can configure the logging system below in this config file.
|
|
|
|
* Setting this value to true will include a log for each websocket connection
|
|
|
|
* including this connection's unique ID, the user public key and the IP.
|
|
|
|
* NOTE: this option requires a log level of "info" or below.
|
|
|
|
*
|
|
|
|
* defaults to false
|
|
|
|
*/
|
|
|
|
//logIP: false,
|
|
|
|
|
2019-03-28 00:00:28 +08:00
|
|
|
/* =====================
|
|
|
|
* Admin
|
|
|
|
* ===================== */
|
|
|
|
|
|
|
|
/*
|
2020-02-29 03:24:03 +08:00
|
|
|
* CryptPad contains an administration panel. Its access is restricted to specific
|
2019-03-28 00:00:28 +08:00
|
|
|
* users using the following list.
|
2020-10-21 18:24:59 +08:00
|
|
|
* 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.
|
2019-03-28 00:00:28 +08:00
|
|
|
* Entries should be strings separated by a comma.
|
2022-09-20 19:11:08 +08:00
|
|
|
* adminKeys: [
|
|
|
|
* "[cryptpad-user1@my.awesome.website/YZgXQxKR0Rcb6r6CmxHPdAGLVludrAF2lEnkbx1vVOo=]",
|
|
|
|
* "[cryptpad-user2@my.awesome.website/jA-9c5iNuG7SyxzGCjwJXVnk5NPfAOO8fQuQ0dC83RE=]",
|
|
|
|
* ]
|
|
|
|
*
|
2019-03-28 00:00:28 +08:00
|
|
|
*/
|
|
|
|
adminKeys: [
|
2022-09-20 19:11:08 +08:00
|
|
|
|
2019-03-28 00:00:28 +08:00
|
|
|
],
|
2019-01-28 19:18:18 +08:00
|
|
|
|
2019-03-01 00:08:19 +08:00
|
|
|
/* =====================
|
|
|
|
* 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
|
2020-02-29 02:17:02 +08:00
|
|
|
* `evict-inactive.js` script with node
|
|
|
|
*
|
|
|
|
* defaults to 90 days if nothing is provided
|
2019-03-01 00:08:19 +08:00
|
|
|
*/
|
2020-02-29 02:17:02 +08:00
|
|
|
//inactiveTime: 90, // days
|
2019-03-01 00:08:19 +08:00
|
|
|
|
2020-01-24 04:13:19 +08:00
|
|
|
/* 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.
|
|
|
|
*
|
2024-04-18 17:26:13 +08:00
|
|
|
* cryptpad/scripts/evict-archived.js is intended to be run daily
|
2020-01-24 04:13:19 +08:00
|
|
|
* from a crontab or similar scheduling service.
|
2019-06-12 22:33:14 +08:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
2020-02-29 02:17:02 +08:00
|
|
|
* defaults to 15 days if nothing is provided
|
2019-06-12 22:33:14 +08:00
|
|
|
*/
|
2020-02-29 02:17:02 +08:00
|
|
|
//archiveRetentionTime: 15,
|
2019-06-12 22:33:14 +08:00
|
|
|
|
2020-09-28 20:18:58 +08:00
|
|
|
/* 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.
|
2020-09-24 21:32:22 +08:00
|
|
|
*
|
2020-09-28 20:18:58 +08:00
|
|
|
* Leave this value commented out to preserve all data stored
|
|
|
|
* by user accounts regardless of inactivity.
|
2020-09-24 21:32:22 +08:00
|
|
|
*/
|
|
|
|
//accountRetentionTime: 365,
|
|
|
|
|
2020-10-12 17:31:48 +08:00
|
|
|
/* 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,
|
|
|
|
|
|
|
|
|
2019-03-01 00:08:19 +08:00
|
|
|
/* 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
|
2020-02-29 02:17:02 +08:00
|
|
|
* defaults to 20MB if no value is provided
|
2017-05-11 22:12:44 +08:00
|
|
|
*/
|
2020-02-29 02:17:02 +08:00
|
|
|
//maxUploadSize: 20 * 1024 * 1024,
|
2017-05-27 00:09:31 +08:00
|
|
|
|
2020-02-29 03:24:03 +08:00
|
|
|
/* 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,
|
2020-02-27 02:09:11 +08:00
|
|
|
|
2019-03-01 00:08:19 +08:00
|
|
|
/* =====================
|
|
|
|
* DATABASE VOLUMES
|
|
|
|
* ===================== */
|
2016-01-29 18:35:44 +08:00
|
|
|
|
2016-10-12 16:52:27 +08:00
|
|
|
/*
|
2019-06-12 22:33:14 +08:00
|
|
|
* 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.
|
|
|
|
*/
|
2016-10-12 16:52:27 +08:00
|
|
|
filePath: './datastore/',
|
|
|
|
|
2019-06-12 22:33:14 +08:00
|
|
|
/* 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',
|
|
|
|
|
2017-04-28 18:48:36 +08:00
|
|
|
/* 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.
|
|
|
|
*/
|
2019-12-31 01:11:44 +08:00
|
|
|
pinPath: './data/pins',
|
2017-04-28 18:48:36 +08:00
|
|
|
|
2019-03-01 00:08:19 +08:00
|
|
|
/* if you would like the list of scheduled tasks to be stored in
|
|
|
|
a custom location, change the path below:
|
|
|
|
*/
|
2019-12-31 01:11:44 +08:00
|
|
|
taskPath: './data/tasks',
|
2019-03-01 00:08:19 +08:00
|
|
|
|
|
|
|
/* if you would like users' authenticated blocks to be stored in
|
|
|
|
a custom location, change the path below:
|
|
|
|
*/
|
|
|
|
blockPath: './block',
|
2018-02-27 01:23:12 +08:00
|
|
|
|
2017-04-28 18:48:36 +08:00
|
|
|
/* 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.
|
|
|
|
*/
|
2019-12-31 01:11:44 +08:00
|
|
|
blobStagingPath: './data/blobstage',
|
2017-04-28 18:48:36 +08:00
|
|
|
|
2020-12-01 08:51:05 +08:00
|
|
|
decreePath: './data/decrees',
|
|
|
|
|
2019-04-09 20:29:02 +08:00
|
|
|
/* CryptPad supports logging events directly to the disk in a 'logs' directory
|
2019-04-12 23:17:10 +08:00
|
|
|
* Set its location here, or set it to false (or nothing) if you'd rather not log
|
2019-04-09 20:29:02 +08:00
|
|
|
*/
|
|
|
|
logPath: './data/logs',
|
|
|
|
|
2019-03-01 00:08:19 +08:00
|
|
|
/* =====================
|
|
|
|
* Debugging
|
|
|
|
* ===================== */
|
2016-10-12 16:52:27 +08:00
|
|
|
|
2019-03-01 00:08:19 +08:00
|
|
|
/* CryptPad can log activity to stdout
|
|
|
|
* This may be useful for debugging
|
2016-10-12 16:52:27 +08:00
|
|
|
*/
|
2019-03-01 00:08:19 +08:00
|
|
|
logToStdout: false,
|
2016-10-12 16:52:27 +08:00
|
|
|
|
2019-04-09 20:29:02 +08:00
|
|
|
/* CryptPad can be configured to log more or less
|
|
|
|
* the various settings are listed below by order of importance
|
|
|
|
*
|
2019-04-12 23:17:10 +08:00
|
|
|
* silly, verbose, debug, feedback, info, warn, error
|
2019-04-09 20:29:02 +08:00
|
|
|
*
|
|
|
|
* 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.
|
2017-03-11 01:03:15 +08:00
|
|
|
*/
|
2019-04-09 20:29:02 +08:00
|
|
|
logLevel: 'info',
|
2017-03-11 01:03:15 +08:00
|
|
|
|
2017-05-13 18:32:26 +08:00
|
|
|
/* 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
|
2019-04-09 20:29:02 +08:00
|
|
|
*
|
|
|
|
* You will need to set your logLevel to include 'feedback'. Set this
|
|
|
|
* to false if you'd like to exclude feedback from your logs.
|
2017-05-13 18:32:26 +08:00
|
|
|
*/
|
2019-03-01 00:08:19 +08:00
|
|
|
logFeedback: false,
|
2017-05-13 18:32:26 +08:00
|
|
|
|
2019-04-09 20:29:02 +08:00
|
|
|
/* CryptPad supports verbose logging
|
|
|
|
* (false by default)
|
|
|
|
*/
|
|
|
|
verbose: false,
|
2021-06-22 18:46:32 +08:00
|
|
|
|
|
|
|
/* Surplus information:
|
|
|
|
*
|
|
|
|
* 'installMethod' is included in server telemetry to voluntarily
|
|
|
|
* indicate how many instances are using unofficial installation methods
|
|
|
|
* such as Docker.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
installMethod: 'unspecified',
|
2014-11-01 00:48:17 +08:00
|
|
|
};
|