UNPKG

@ar.io/sdk

Version:

[![codecov](https://codecov.io/gh/ar-io/ar-io-sdk/graph/badge.svg?token=7dXKcT7dJy)](https://codecov.io/gh/ar-io/ar-io-sdk)

78 lines (77 loc) 2.42 kB
/** * Copyright (C) 2022-2024 Permanent Data Solutions, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import { createLogger, format, transports, } from 'winston'; import { version } from '../version.js'; export class Logger { logger; silent = false; static default = new Logger(); constructor({ level = 'info', } = {}) { if (level === 'none') { this.silent = true; } // eslint-disable-next-line @typescript-eslint/ban-ts-comment // @ts-ignore if (typeof window !== 'undefined') { this.logger = console; } else { this.logger = createLogger({ level, silent: this.silent, defaultMeta: { name: 'ar-io-sdk', version, }, format: format.combine(format.timestamp(), format.json()), transports: [ new transports.Console({ format: format.combine(format.timestamp(), format.json()), }), ], }); } } info(message, ...args) { if (this.silent) return; this.logger.info(message, ...args); } warn(message, ...args) { if (this.silent) return; this.logger.warn(message, ...args); } error(message, ...args) { if (this.silent) return; this.logger.error(message, ...args); } debug(message, ...args) { if (this.silent) return; this.logger.debug(message, ...args); } setLogLevel(level) { this.silent = level === 'none'; if ('silent' in this.logger) { this.logger.silent = level === 'none'; } if ('level' in this.logger) { this.logger.level = level; } } }