aboutsummaryrefslogtreecommitdiff
path: root/src/util/config.ts
blob: c155e64cb954cd9e9df709fde934faf02a9726c7 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import winston from "winston";
import { MongoClient } from "mongodb";
import { Server } from "http";

import logger_config from "./logger";

const logger = winston.createLogger(logger_config("ROOT"));

export const config_or_error = (var_name: string) => {
  if (!process.env[var_name]) {
    logger.error("%s must be defined", var_name);
    process.exit(1);
    return "";
  } else {
    return process.env[var_name] || "";
  }
};

export const handle_shutdown = (mongo: MongoClient, server: Server) => (
  signal: NodeJS.Signals
) => {
  logger.warn("%s signal received. Closing shop.", signal);

  mongo
    .close()
    .then(() => {
      logger.info("MongoDB client connection closed.");
      return new Promise((res, rej) =>
        server.close(err => {
          logger.info("Express down.");
          (err ? rej : res)(err);
        })
      );
    })
    .finally(() => {
      process.exit(0);
    });
};