actionhero
Version:
The reusable, scalable, and quick node.js API server for stateless and stateful applications
79 lines (70 loc) • 2.35 kB
text/typescript
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,
},
};
},
};