UNPKG

actionhero

Version:

The reusable, scalable, and quick node.js API server for stateless and stateful applications

79 lines (70 loc) 2.35 kB
import { URL } from "url"; const namespace = "redis"; declare module ".." { export interface ActionheroConfigInterface { [namespace]: ReturnType<(typeof DEFAULT)[typeof namespace]>; } } /** * This is the standard redis config for Actionhero. * This will use a redis server to persist cache, share chat message between processes, etc. */ export const DEFAULT = { [namespace]: () => { const konstructor = require("ioredis"); // or konstructor = require("ioredis-mock") if you don't need real redis; let protocol = process.env.REDIS_SSL ? "rediss" : "redis"; let host = process.env.REDIS_HOST || "127.0.0.1"; let port = process.env.REDIS_PORT || 6379; let db = process.env.REDIS_DB || process.env.JEST_WORKER_ID || "0"; let password = process.env.REDIS_PASSWORD || null; if (process.env.REDIS_URL) { const parsed = new URL(process.env.REDIS_URL); if (parsed.protocol) protocol = parsed.protocol.split(":")[0]; if (parsed.password) password = parsed.password; if (parsed.hostname) host = parsed.hostname; if (parsed.port) port = parsed.port; if (parsed.pathname) db = parsed.pathname.substring(1); } const maxBackoff = 1000; const commonArgs = { port, host, password, db: parseInt(db), // ssl options tls: protocol === "rediss" ? { rejectUnauthorized: false } : undefined, // you can learn more about retryStrategy @ https://github.com/luin/ioredis#auto-reconnect retryStrategy: (times: number) => { if (times === 1) { console.error( "Unable to connect to Redis - please check your Redis config!", ); return 5000; } return Math.min(times * 50, maxBackoff); }, }; return { // how many items should be fetched in a batch at once? scanCount: 1000, // how many ms should we wait when disconnecting after sending server-side disconnect message to the cluster stopTimeout: 100, _toExpand: false, client: { konstructor, args: [commonArgs], buildNew: true, }, subscriber: { konstructor, args: [commonArgs], buildNew: true, }, tasks: { konstructor, args: [commonArgs], buildNew: true, }, }; }, };