// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import noop from 'lodash/noop'; import type { LogFunction } from '../types/Logging'; import { LogLevel } from '../types/Logging'; type LogAtLevelFnType = ( level: LogLevel, ...args: ReadonlyArray ) => void; let logAtLevel: LogAtLevelFnType = noop; let hasInitialized = false; export const fatal: LogFunction = (...args) => logAtLevel(LogLevel.Fatal, ...args); export const error: LogFunction = (...args) => logAtLevel(LogLevel.Error, ...args); export const warn: LogFunction = (...args) => logAtLevel(LogLevel.Warn, ...args); export const info: LogFunction = (...args) => logAtLevel(LogLevel.Info, ...args); export const debug: LogFunction = (...args) => logAtLevel(LogLevel.Debug, ...args); export const trace: LogFunction = (...args) => logAtLevel(LogLevel.Trace, ...args); /** * Sets the low-level logging interface. Should be called early in a process's life, and * can only be called once. */ export function setLogAtLevel(log: LogAtLevelFnType): void { if (hasInitialized) { throw new Error('Logger has already been initialized'); } logAtLevel = log; hasInitialized = true; }