UNPKG

@kotori-bot/logger

Version:
80 lines (77 loc) 3.13 kB
/** * @Package @kotori-bot/logger * @Version 1.3.3 * @Author Hotaru <me@hotaru.icu> * @Copyright 2024 Hotaru. All rights reserved. * @License GPL-3.0 * @Link https://github.com/kotorijs/kotori * @Date 2025/2/15 18:31:34 */ "use strict"; var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var file_exports = {}; __export(file_exports, { FileTransport: () => FileTransport, default: () => file_default }); module.exports = __toCommonJS(file_exports); var import_fast_safe_stringify = __toESM(require("fast-safe-stringify")); var import_dayjs = __toESM(require("dayjs")); var import_node_fs = require("node:fs"); var import_node_path = require("node:path"); var import_transport = __toESM(require("../utils/transport")); const DEFAULT_OPTIONS = { filename: "default", time: "YY-M-D", ext: ".log", maxLen: 500 }; class FileTransport extends import_transport.default { constructor(options) { super({ ...DEFAULT_OPTIONS, ...options }); } list = /* @__PURE__ */ new Set(); filename() { return (0, import_dayjs.default)().format(this.options.time); } handle(data) { const filename = this.options.filename instanceof Function ? this.options.filename() : this.filename(); const dir = (0, import_node_path.resolve)(this.options.dir, `${filename}${this.options.ext}`); const d = data; d.msg = d.msg.length > this.options.maxLen ? `${d.msg.slice(0, this.options.maxLen)}...` : d.msg; const content = (0, import_fast_safe_stringify.default)(d); (0, import_node_fs.writeFileSync)(dir, (0, import_node_fs.existsSync)(dir) ? `${(0, import_node_fs.readFileSync)(dir).toString()} ${content}` : content); } } var file_default = FileTransport; // Annotate the CommonJS export names for ESM import in node: 0 && (module.exports = { FileTransport });