wildduck/lib/consts.js

85 lines
2.9 KiB
JavaScript
Raw Normal View History

'use strict';
module.exports = {
2017-11-15 21:59:37 +08:00
SCHEMA_VERSION: '1.0',
// how many modifications to cache before writing
BULK_BATCH_SIZE: 150,
// how often to clear expired messages
2017-11-23 17:51:37 +08:00
GC_INTERVAL: 15 * 60 * 1000,
// artificail delay between deleting next expired message in ms
2017-11-15 21:59:37 +08:00
// set to 0 to disable
2017-11-17 19:37:53 +08:00
GC_DELAY_DELETE: 0,
2017-07-17 21:32:31 +08:00
2017-11-17 19:37:53 +08:00
// default
2017-07-17 21:32:31 +08:00
MAX_STORAGE: 1 * (1024 * 1024 * 1024),
MAX_RECIPIENTS: 2000,
MAX_FORWARDS: 2000,
2017-07-18 16:17:36 +08:00
JUNK_RETENTION: 30 * 24 * 3600 * 1000,
2018-10-11 16:48:12 +08:00
// how long to keep messages of deleted users before deleting
DELETED_USER_MESSAGE_RETENTION: 14 * 24 * 3600 * 1000,
2017-07-21 02:33:41 +08:00
MAILBOX_COUNTER_TTL: 24 * 3600,
2017-11-08 22:22:07 +08:00
// how much plaintext to store in a full text indexed field
2017-11-15 21:59:37 +08:00
MAX_PLAINTEXT_INDEXED: 1 * 1024,
2017-11-08 22:22:07 +08:00
// how much plaintext to store before truncating
MAX_PLAINTEXT_CONTENT: 100 * 1024,
2017-07-21 02:33:41 +08:00
2017-11-15 21:59:37 +08:00
// how much HTML content to store before truncating. not indexed
2017-07-30 23:07:35 +08:00
MAX_HTML_CONTENT: 300 * 1024,
2018-01-12 16:16:16 +08:00
MAX_AUTOREPLY_INTERVAL: 4 * 3600 * 1000,
2017-07-30 23:07:35 +08:00
2017-08-05 20:39:31 +08:00
MAX_AUTOREPLIES: 2000,
DEFAULT_HASH_ALGO: 'pbkdf2', //either 'pbkdf2' or 'bcrypt'
2018-05-14 15:14:44 +08:00
BCRYPT_ROUNDS: 11, // bcrypt.js benchmark async in a VPS: 261.192ms, do not want to take it too long
PDKDF2_ITERATIONS: 25000,
PDKDF2_SALT_SIZE: 16,
PDKDF2_DIGEST: 'sha256', // 'sha512', 'sha256' or 'sha1'
// how many authentication failures per user to allow before blocking until the end of the auth window
2018-04-13 10:22:49 +08:00
USER_AUTH_FAILURES: 12,
// authentication window in seconds, starts counting from first invalid authentication
2018-04-13 10:22:49 +08:00
USER_AUTH_WINDOW: 120,
// how many authentication failures per ip to allow before blocking until the end of the auth window
2018-11-05 15:25:43 +08:00
//IP_AUTH_FAILURES: 10,
IP_AUTH_FAILURES: 0, // disable IP rate limiting for now as too many false positives occurred while scanners use unique IPs
2018-04-13 10:22:49 +08:00
// authentication window in seconds, starts counting from first invalid authentication
IP_AUTH_WINDOW: 300,
// how many TOTP failures per user to allow before blocking until the end of the auth window
TOTP_FAILURES: 6,
// TOTP authentication window in seconds, starts counting from first invalid authentication
2017-11-06 23:32:45 +08:00
TOTP_WINDOW: 180,
2017-11-10 21:04:58 +08:00
SCOPES: ['imap', 'pop3', 'smtp'],
// Refuse to process messages larger than 64 MB. Allowing larger messages might cause jumbo chunks in MongoDB
2018-12-04 20:45:41 +08:00
MAX_ALLOWED_MESSAGE_SIZE: 64 * 1024 * 1024,
2017-11-17 19:37:53 +08:00
// how long to keep deleted messages around before purgeing
2018-08-15 15:17:02 +08:00
ARCHIVE_TIME: 25 * 24 * 3600 * 1000,
// merge similar authlog events into 6 hour buckets instead of storing each separately
// this is mostly needed for IMAP clients that make crazy amout of connections and thus logins
2018-10-10 21:19:20 +08:00
AUTHLOG_BUCKET: 6 * 3600 * 1000,
// start processing tasks 5 minues after startup
TASK_STARTUP_INTERVAL: 1 * 60 * 1000,
// if no tasks were found, wait 1 minute
2018-10-11 16:48:12 +08:00
TASK_IDLE_INTERVAL: 1 * 60 * 1000,
TASK_LOCK_INTERVAL: 1 * 60 * 60 * 1000,
TASK_UPDATE_INTERVAL: 10 * 60 * 1000
};