@feizk/logger 1.5.1 → 1.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +27 -0
- package/dist/index.d.mts +14 -1
- package/dist/index.d.ts +14 -1
- package/dist/index.js +47 -1
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +47 -1
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -31,6 +31,11 @@ const logger = new Logger({
|
|
|
31
31
|
formatTimestamp: undefined, // Custom timestamp formatter function, Default: ISO format
|
|
32
32
|
formatLog: undefined, // Custom log formatter function, Default: undefined
|
|
33
33
|
level: 'debug', // 'debug' | 'info' | 'warn' | 'error', Default: 'debug'
|
|
34
|
+
discord: {
|
|
35
|
+
enable: false, // Enable Discord transport
|
|
36
|
+
webhookURL: '', // Discord webhook URL
|
|
37
|
+
formatEmbed: undefined, // Custom embed formatter function
|
|
38
|
+
},
|
|
34
39
|
});
|
|
35
40
|
```
|
|
36
41
|
|
|
@@ -57,6 +62,28 @@ infoLogger.info('Logged'); // and higher
|
|
|
57
62
|
|
|
58
63
|
// Change level dynamically
|
|
59
64
|
logger.setLevel('error');
|
|
65
|
+
|
|
66
|
+
// Enable Discord transport
|
|
67
|
+
const discordLogger = new Logger({
|
|
68
|
+
discord: {
|
|
69
|
+
enable: true,
|
|
70
|
+
webhookURL: 'https://discord.com/api/webhooks/123456789/abcdef',
|
|
71
|
+
},
|
|
72
|
+
});
|
|
73
|
+
discordLogger.error('This will be sent to Discord');
|
|
74
|
+
|
|
75
|
+
// Custom embed formatting
|
|
76
|
+
const customDiscordLogger = new Logger({
|
|
77
|
+
discord: {
|
|
78
|
+
enable: true,
|
|
79
|
+
webhookURL: 'https://discord.com/api/webhooks/123456789/abcdef',
|
|
80
|
+
formatEmbed: (level, timestamp, message) => ({
|
|
81
|
+
title: `${level} - Custom`,
|
|
82
|
+
description: `**Timestamp:** ${timestamp}\n**Message:** ${message}`,
|
|
83
|
+
color: 0xff0000, // Red
|
|
84
|
+
}),
|
|
85
|
+
},
|
|
86
|
+
});
|
|
60
87
|
```
|
|
61
88
|
|
|
62
89
|
## API
|
package/dist/index.d.mts
CHANGED
|
@@ -5,11 +5,17 @@ interface TimestampTypes {
|
|
|
5
5
|
Locale: 'locale';
|
|
6
6
|
Custom: 'custom';
|
|
7
7
|
}
|
|
8
|
+
interface DiscordOptions {
|
|
9
|
+
enable: boolean;
|
|
10
|
+
webhookURL: string;
|
|
11
|
+
formatEmbed?: (level: LogLevel, timestamp: string, message: string) => Record<string, unknown>;
|
|
12
|
+
}
|
|
8
13
|
interface LoggerOptions {
|
|
9
14
|
enableColors?: boolean;
|
|
10
15
|
formatTimestamp?: (types: TimestampTypes, date?: Date) => [TimestampType, string];
|
|
11
16
|
formatLog?: (level: string, timestamp: string, args: unknown[]) => string;
|
|
12
17
|
level?: LogLevel;
|
|
18
|
+
discord?: DiscordOptions;
|
|
13
19
|
}
|
|
14
20
|
|
|
15
21
|
/**
|
|
@@ -24,6 +30,13 @@ declare class Logger {
|
|
|
24
30
|
* @param level - The log level to set.
|
|
25
31
|
*/
|
|
26
32
|
setLevel(level: LogLevel): void;
|
|
33
|
+
/**
|
|
34
|
+
* Sends a log message to Discord via webhook if configured.
|
|
35
|
+
* @param level - The log level.
|
|
36
|
+
* @param timestamp - The formatted timestamp.
|
|
37
|
+
* @param args - The log arguments.
|
|
38
|
+
*/
|
|
39
|
+
private sendToDiscord;
|
|
27
40
|
/**
|
|
28
41
|
* Checks if a log level should be output based on the current log level.
|
|
29
42
|
* @param level - The log level to check.
|
|
@@ -54,4 +67,4 @@ declare class Logger {
|
|
|
54
67
|
|
|
55
68
|
declare const TIMESTAMP_TYPES: TimestampTypes;
|
|
56
69
|
|
|
57
|
-
export { type LogLevel, Logger, type LoggerOptions, TIMESTAMP_TYPES, type TimestampType, type TimestampTypes };
|
|
70
|
+
export { type DiscordOptions, type LogLevel, Logger, type LoggerOptions, TIMESTAMP_TYPES, type TimestampType, type TimestampTypes };
|
package/dist/index.d.ts
CHANGED
|
@@ -5,11 +5,17 @@ interface TimestampTypes {
|
|
|
5
5
|
Locale: 'locale';
|
|
6
6
|
Custom: 'custom';
|
|
7
7
|
}
|
|
8
|
+
interface DiscordOptions {
|
|
9
|
+
enable: boolean;
|
|
10
|
+
webhookURL: string;
|
|
11
|
+
formatEmbed?: (level: LogLevel, timestamp: string, message: string) => Record<string, unknown>;
|
|
12
|
+
}
|
|
8
13
|
interface LoggerOptions {
|
|
9
14
|
enableColors?: boolean;
|
|
10
15
|
formatTimestamp?: (types: TimestampTypes, date?: Date) => [TimestampType, string];
|
|
11
16
|
formatLog?: (level: string, timestamp: string, args: unknown[]) => string;
|
|
12
17
|
level?: LogLevel;
|
|
18
|
+
discord?: DiscordOptions;
|
|
13
19
|
}
|
|
14
20
|
|
|
15
21
|
/**
|
|
@@ -24,6 +30,13 @@ declare class Logger {
|
|
|
24
30
|
* @param level - The log level to set.
|
|
25
31
|
*/
|
|
26
32
|
setLevel(level: LogLevel): void;
|
|
33
|
+
/**
|
|
34
|
+
* Sends a log message to Discord via webhook if configured.
|
|
35
|
+
* @param level - The log level.
|
|
36
|
+
* @param timestamp - The formatted timestamp.
|
|
37
|
+
* @param args - The log arguments.
|
|
38
|
+
*/
|
|
39
|
+
private sendToDiscord;
|
|
27
40
|
/**
|
|
28
41
|
* Checks if a log level should be output based on the current log level.
|
|
29
42
|
* @param level - The log level to check.
|
|
@@ -54,4 +67,4 @@ declare class Logger {
|
|
|
54
67
|
|
|
55
68
|
declare const TIMESTAMP_TYPES: TimestampTypes;
|
|
56
69
|
|
|
57
|
-
export { type LogLevel, Logger, type LoggerOptions, TIMESTAMP_TYPES, type TimestampType, type TimestampTypes };
|
|
70
|
+
export { type DiscordOptions, type LogLevel, Logger, type LoggerOptions, TIMESTAMP_TYPES, type TimestampType, type TimestampTypes };
|
package/dist/index.js
CHANGED
|
@@ -56,6 +56,18 @@ function getColor(level, enableColors) {
|
|
|
56
56
|
};
|
|
57
57
|
return colors[level] || level;
|
|
58
58
|
}
|
|
59
|
+
function getDiscordColor(level) {
|
|
60
|
+
const colors = {
|
|
61
|
+
debug: 9807270,
|
|
62
|
+
info: 3447003,
|
|
63
|
+
warn: 15965202,
|
|
64
|
+
error: 15158332
|
|
65
|
+
};
|
|
66
|
+
return colors[level];
|
|
67
|
+
}
|
|
68
|
+
function generateId() {
|
|
69
|
+
return Math.random().toString(36).substr(2, 8).toUpperCase();
|
|
70
|
+
}
|
|
59
71
|
function formatLog(level, timestamp, args, options) {
|
|
60
72
|
const { formatLog: formatLog2, enableColors = true } = options;
|
|
61
73
|
const coloredLevel = getColor(level, enableColors);
|
|
@@ -78,7 +90,8 @@ var Logger = class {
|
|
|
78
90
|
this.options = {
|
|
79
91
|
enableColors: options.enableColors ?? true,
|
|
80
92
|
formatTimestamp: options.formatTimestamp ?? defaultFormatTimestamp,
|
|
81
|
-
formatLog: options.formatLog
|
|
93
|
+
formatLog: options.formatLog,
|
|
94
|
+
discord: options.discord
|
|
82
95
|
};
|
|
83
96
|
this.level = options.level ?? "debug";
|
|
84
97
|
}
|
|
@@ -89,6 +102,35 @@ var Logger = class {
|
|
|
89
102
|
setLevel(level) {
|
|
90
103
|
this.level = level;
|
|
91
104
|
}
|
|
105
|
+
/**
|
|
106
|
+
* Sends a log message to Discord via webhook if configured.
|
|
107
|
+
* @param level - The log level.
|
|
108
|
+
* @param timestamp - The formatted timestamp.
|
|
109
|
+
* @param args - The log arguments.
|
|
110
|
+
*/
|
|
111
|
+
async sendToDiscord(level, timestamp, args) {
|
|
112
|
+
const discord = this.options.discord;
|
|
113
|
+
if (!discord?.enable) return;
|
|
114
|
+
try {
|
|
115
|
+
new URL(discord.webhookURL);
|
|
116
|
+
} catch {
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
const message = args.map((arg) => typeof arg === "string" ? arg : JSON.stringify(arg)).join(" ");
|
|
120
|
+
const title = `${level.toUpperCase()}-${generateId()}`;
|
|
121
|
+
const embed = discord.formatEmbed ? discord.formatEmbed(level, timestamp, message) : {
|
|
122
|
+
title,
|
|
123
|
+
description: message,
|
|
124
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
125
|
+
color: getDiscordColor(level)
|
|
126
|
+
};
|
|
127
|
+
await fetch(discord.webhookURL, {
|
|
128
|
+
method: "POST",
|
|
129
|
+
headers: { "Content-Type": "application/json" },
|
|
130
|
+
body: JSON.stringify({ embeds: [embed] })
|
|
131
|
+
}).catch(() => {
|
|
132
|
+
});
|
|
133
|
+
}
|
|
92
134
|
/**
|
|
93
135
|
* Checks if a log level should be output based on the current log level.
|
|
94
136
|
* @param level - The log level to check.
|
|
@@ -108,6 +150,7 @@ var Logger = class {
|
|
|
108
150
|
TIMESTAMP_TYPES
|
|
109
151
|
);
|
|
110
152
|
console.log(...formatLog("[INFO]", timestamp, args, this.options));
|
|
153
|
+
this.sendToDiscord("info", timestamp, args);
|
|
111
154
|
}
|
|
112
155
|
/**
|
|
113
156
|
* Logs a warning message.
|
|
@@ -120,6 +163,7 @@ var Logger = class {
|
|
|
120
163
|
TIMESTAMP_TYPES
|
|
121
164
|
);
|
|
122
165
|
console.log(...formatLog("[WARN]", timestamp, args, this.options));
|
|
166
|
+
this.sendToDiscord("warn", timestamp, args);
|
|
123
167
|
}
|
|
124
168
|
/**
|
|
125
169
|
* Logs an error message.
|
|
@@ -132,6 +176,7 @@ var Logger = class {
|
|
|
132
176
|
TIMESTAMP_TYPES
|
|
133
177
|
);
|
|
134
178
|
console.log(...formatLog("[ERROR]", timestamp, args, this.options));
|
|
179
|
+
this.sendToDiscord("error", timestamp, args);
|
|
135
180
|
}
|
|
136
181
|
/**
|
|
137
182
|
* Logs a debug message.
|
|
@@ -144,6 +189,7 @@ var Logger = class {
|
|
|
144
189
|
TIMESTAMP_TYPES
|
|
145
190
|
);
|
|
146
191
|
console.log(...formatLog("[DEBUG]", timestamp, args, this.options));
|
|
192
|
+
this.sendToDiscord("debug", timestamp, args);
|
|
147
193
|
}
|
|
148
194
|
};
|
|
149
195
|
// Annotate the CommonJS export names for ESM import in node:
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/utils.ts","../src/logger.ts"],"sourcesContent":["export { Logger } from './logger';\nexport { TIMESTAMP_TYPES } from './utils';\nexport type {\n LoggerOptions,\n LogLevel,\n TimestampTypes,\n TimestampType,\n} from './types';\n","import chalk from 'chalk';\nimport type { LoggerOptions, TimestampTypes } from './types';\n\nexport const TIMESTAMP_TYPES: TimestampTypes = {\n ISO: 'iso',\n Locale: 'locale',\n Custom: 'custom',\n};\n\nexport function formatTimestamp(\n formatTimestampFn: NonNullable<LoggerOptions['formatTimestamp']>,\n types: TimestampTypes,\n date: Date = new Date(),\n): string {\n const [, timestamp] = formatTimestampFn(types, date);\n return timestamp;\n}\n\nexport function getColor(level: string, enableColors: boolean): string {\n if (!enableColors) return level;\n const colors: Record<string, string> = {\n '[INFO]': chalk.blue(level),\n '[WARN]': chalk.yellow(level),\n '[ERROR]': chalk.red(level),\n '[DEBUG]': chalk.gray(level),\n };\n return colors[level] || level;\n}\n\nexport function formatLog(\n level: string,\n timestamp: string,\n args: unknown[],\n options: LoggerOptions,\n): [string, ...unknown[]] {\n const { formatLog, enableColors = true } = options;\n const coloredLevel = getColor(level, enableColors);\n if (formatLog) {\n return [formatLog(coloredLevel, timestamp, args)];\n }\n return [`${coloredLevel} ${timestamp}`, ...args];\n}\n","import type { LoggerOptions, LogLevel, TimestampTypes } from './types';\nimport {
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/utils.ts","../src/logger.ts"],"sourcesContent":["export { Logger } from './logger';\nexport { TIMESTAMP_TYPES } from './utils';\nexport type {\n LoggerOptions,\n LogLevel,\n TimestampTypes,\n TimestampType,\n DiscordOptions,\n} from './types';\n","import chalk from 'chalk';\nimport type { LoggerOptions, TimestampTypes, LogLevel } from './types';\n\nexport const TIMESTAMP_TYPES: TimestampTypes = {\n ISO: 'iso',\n Locale: 'locale',\n Custom: 'custom',\n};\n\nexport function formatTimestamp(\n formatTimestampFn: NonNullable<LoggerOptions['formatTimestamp']>,\n types: TimestampTypes,\n date: Date = new Date(),\n): string {\n const [, timestamp] = formatTimestampFn(types, date);\n return timestamp;\n}\n\nexport function getColor(level: string, enableColors: boolean): string {\n if (!enableColors) return level;\n const colors: Record<string, string> = {\n '[INFO]': chalk.blue(level),\n '[WARN]': chalk.yellow(level),\n '[ERROR]': chalk.red(level),\n '[DEBUG]': chalk.gray(level),\n };\n return colors[level] || level;\n}\n\nexport function getDiscordColor(level: LogLevel): number {\n const colors: Record<LogLevel, number> = {\n debug: 0x95a5a6,\n info: 0x3498db,\n warn: 0xf39c12,\n error: 0xe74c3c,\n };\n return colors[level];\n}\n\nexport function generateId(): string {\n return Math.random().toString(36).substr(2, 8).toUpperCase();\n}\n\nexport function formatLog(\n level: string,\n timestamp: string,\n args: unknown[],\n options: LoggerOptions,\n): [string, ...unknown[]] {\n const { formatLog, enableColors = true } = options;\n const coloredLevel = getColor(level, enableColors);\n if (formatLog) {\n return [formatLog(coloredLevel, timestamp, args)];\n }\n return [`${coloredLevel} ${timestamp}`, ...args];\n}\n","import type { LoggerOptions, LogLevel, TimestampTypes } from './types';\nimport {\n formatTimestamp,\n formatLog,\n TIMESTAMP_TYPES,\n getDiscordColor,\n generateId,\n} from './utils';\n\nimport type { TimestampType } from './types';\n\nconst defaultFormatTimestamp = (\n types: TimestampTypes,\n date: Date = new Date(),\n): [TimestampType, string] => [types.ISO, date.toISOString()];\n\nconst LOG_LEVEL_PRIORITIES: Record<LogLevel, number> = {\n debug: 0,\n info: 1,\n warn: 2,\n error: 3,\n};\n\n/**\n * A simple logger with colored outputs and timestamps.\n */\nexport class Logger {\n private options: LoggerOptions;\n private level: LogLevel;\n\n constructor(options: LoggerOptions = {}) {\n this.options = {\n enableColors: options.enableColors ?? true,\n formatTimestamp: options.formatTimestamp ?? defaultFormatTimestamp,\n formatLog: options.formatLog,\n discord: options.discord,\n };\n this.level = options.level ?? 'debug';\n }\n\n /**\n * Sets the minimum log level for filtering messages.\n * @param level - The log level to set.\n */\n setLevel(level: LogLevel): void {\n this.level = level;\n }\n\n /**\n * Sends a log message to Discord via webhook if configured.\n * @param level - The log level.\n * @param timestamp - The formatted timestamp.\n * @param args - The log arguments.\n */\n private async sendToDiscord(\n level: LogLevel,\n timestamp: string,\n args: unknown[],\n ): Promise<void> {\n const discord = this.options.discord;\n if (!discord?.enable) return;\n\n try {\n new URL(discord.webhookURL);\n } catch {\n return;\n }\n\n const message = args\n .map((arg) => (typeof arg === 'string' ? arg : JSON.stringify(arg)))\n .join(' ');\n\n const title = `${level.toUpperCase()}-${generateId()}`;\n\n const embed = discord.formatEmbed\n ? discord.formatEmbed(level, timestamp, message)\n : {\n title,\n description: message,\n timestamp: new Date().toISOString(),\n color: getDiscordColor(level),\n };\n\n await fetch(discord.webhookURL, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ embeds: [embed] }),\n }).catch(() => {});\n }\n\n /**\n * Checks if a log level should be output based on the current log level.\n * @param level - The log level to check.\n * @returns True if the message should be logged.\n */\n private shouldLog(level: LogLevel): boolean {\n return LOG_LEVEL_PRIORITIES[level] >= LOG_LEVEL_PRIORITIES[this.level];\n }\n\n /**\n * Logs an info message.\n * @param args - The arguments to log.\n */\n info(...args: unknown[]): void {\n if (!this.shouldLog('info')) return;\n const timestamp = formatTimestamp(\n this.options.formatTimestamp!,\n TIMESTAMP_TYPES,\n );\n console.log(...formatLog('[INFO]', timestamp, args, this.options));\n this.sendToDiscord('info', timestamp, args);\n }\n\n /**\n * Logs a warning message.\n * @param args - The arguments to log.\n */\n warn(...args: unknown[]): void {\n if (!this.shouldLog('warn')) return;\n const timestamp = formatTimestamp(\n this.options.formatTimestamp!,\n TIMESTAMP_TYPES,\n );\n console.log(...formatLog('[WARN]', timestamp, args, this.options));\n this.sendToDiscord('warn', timestamp, args);\n }\n\n /**\n * Logs an error message.\n * @param args - The arguments to log.\n */\n error(...args: unknown[]): void {\n if (!this.shouldLog('error')) return;\n const timestamp = formatTimestamp(\n this.options.formatTimestamp!,\n TIMESTAMP_TYPES,\n );\n console.log(...formatLog('[ERROR]', timestamp, args, this.options));\n this.sendToDiscord('error', timestamp, args);\n }\n\n /**\n * Logs a debug message.\n * @param args - The arguments to log.\n */\n debug(...args: unknown[]): void {\n if (!this.shouldLog('debug')) return;\n const timestamp = formatTimestamp(\n this.options.formatTimestamp!,\n TIMESTAMP_TYPES,\n );\n console.log(...formatLog('[DEBUG]', timestamp, args, this.options));\n this.sendToDiscord('debug', timestamp, args);\n }\n}\n"],"mappings":"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","names":["chalk","formatLog"]}
|
package/dist/index.mjs
CHANGED
|
@@ -19,6 +19,18 @@ function getColor(level, enableColors) {
|
|
|
19
19
|
};
|
|
20
20
|
return colors[level] || level;
|
|
21
21
|
}
|
|
22
|
+
function getDiscordColor(level) {
|
|
23
|
+
const colors = {
|
|
24
|
+
debug: 9807270,
|
|
25
|
+
info: 3447003,
|
|
26
|
+
warn: 15965202,
|
|
27
|
+
error: 15158332
|
|
28
|
+
};
|
|
29
|
+
return colors[level];
|
|
30
|
+
}
|
|
31
|
+
function generateId() {
|
|
32
|
+
return Math.random().toString(36).substr(2, 8).toUpperCase();
|
|
33
|
+
}
|
|
22
34
|
function formatLog(level, timestamp, args, options) {
|
|
23
35
|
const { formatLog: formatLog2, enableColors = true } = options;
|
|
24
36
|
const coloredLevel = getColor(level, enableColors);
|
|
@@ -41,7 +53,8 @@ var Logger = class {
|
|
|
41
53
|
this.options = {
|
|
42
54
|
enableColors: options.enableColors ?? true,
|
|
43
55
|
formatTimestamp: options.formatTimestamp ?? defaultFormatTimestamp,
|
|
44
|
-
formatLog: options.formatLog
|
|
56
|
+
formatLog: options.formatLog,
|
|
57
|
+
discord: options.discord
|
|
45
58
|
};
|
|
46
59
|
this.level = options.level ?? "debug";
|
|
47
60
|
}
|
|
@@ -52,6 +65,35 @@ var Logger = class {
|
|
|
52
65
|
setLevel(level) {
|
|
53
66
|
this.level = level;
|
|
54
67
|
}
|
|
68
|
+
/**
|
|
69
|
+
* Sends a log message to Discord via webhook if configured.
|
|
70
|
+
* @param level - The log level.
|
|
71
|
+
* @param timestamp - The formatted timestamp.
|
|
72
|
+
* @param args - The log arguments.
|
|
73
|
+
*/
|
|
74
|
+
async sendToDiscord(level, timestamp, args) {
|
|
75
|
+
const discord = this.options.discord;
|
|
76
|
+
if (!discord?.enable) return;
|
|
77
|
+
try {
|
|
78
|
+
new URL(discord.webhookURL);
|
|
79
|
+
} catch {
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
const message = args.map((arg) => typeof arg === "string" ? arg : JSON.stringify(arg)).join(" ");
|
|
83
|
+
const title = `${level.toUpperCase()}-${generateId()}`;
|
|
84
|
+
const embed = discord.formatEmbed ? discord.formatEmbed(level, timestamp, message) : {
|
|
85
|
+
title,
|
|
86
|
+
description: message,
|
|
87
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
88
|
+
color: getDiscordColor(level)
|
|
89
|
+
};
|
|
90
|
+
await fetch(discord.webhookURL, {
|
|
91
|
+
method: "POST",
|
|
92
|
+
headers: { "Content-Type": "application/json" },
|
|
93
|
+
body: JSON.stringify({ embeds: [embed] })
|
|
94
|
+
}).catch(() => {
|
|
95
|
+
});
|
|
96
|
+
}
|
|
55
97
|
/**
|
|
56
98
|
* Checks if a log level should be output based on the current log level.
|
|
57
99
|
* @param level - The log level to check.
|
|
@@ -71,6 +113,7 @@ var Logger = class {
|
|
|
71
113
|
TIMESTAMP_TYPES
|
|
72
114
|
);
|
|
73
115
|
console.log(...formatLog("[INFO]", timestamp, args, this.options));
|
|
116
|
+
this.sendToDiscord("info", timestamp, args);
|
|
74
117
|
}
|
|
75
118
|
/**
|
|
76
119
|
* Logs a warning message.
|
|
@@ -83,6 +126,7 @@ var Logger = class {
|
|
|
83
126
|
TIMESTAMP_TYPES
|
|
84
127
|
);
|
|
85
128
|
console.log(...formatLog("[WARN]", timestamp, args, this.options));
|
|
129
|
+
this.sendToDiscord("warn", timestamp, args);
|
|
86
130
|
}
|
|
87
131
|
/**
|
|
88
132
|
* Logs an error message.
|
|
@@ -95,6 +139,7 @@ var Logger = class {
|
|
|
95
139
|
TIMESTAMP_TYPES
|
|
96
140
|
);
|
|
97
141
|
console.log(...formatLog("[ERROR]", timestamp, args, this.options));
|
|
142
|
+
this.sendToDiscord("error", timestamp, args);
|
|
98
143
|
}
|
|
99
144
|
/**
|
|
100
145
|
* Logs a debug message.
|
|
@@ -107,6 +152,7 @@ var Logger = class {
|
|
|
107
152
|
TIMESTAMP_TYPES
|
|
108
153
|
);
|
|
109
154
|
console.log(...formatLog("[DEBUG]", timestamp, args, this.options));
|
|
155
|
+
this.sendToDiscord("debug", timestamp, args);
|
|
110
156
|
}
|
|
111
157
|
};
|
|
112
158
|
export {
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/utils.ts","../src/logger.ts"],"sourcesContent":["import chalk from 'chalk';\nimport type { LoggerOptions, TimestampTypes } from './types';\n\nexport const TIMESTAMP_TYPES: TimestampTypes = {\n ISO: 'iso',\n Locale: 'locale',\n Custom: 'custom',\n};\n\nexport function formatTimestamp(\n formatTimestampFn: NonNullable<LoggerOptions['formatTimestamp']>,\n types: TimestampTypes,\n date: Date = new Date(),\n): string {\n const [, timestamp] = formatTimestampFn(types, date);\n return timestamp;\n}\n\nexport function getColor(level: string, enableColors: boolean): string {\n if (!enableColors) return level;\n const colors: Record<string, string> = {\n '[INFO]': chalk.blue(level),\n '[WARN]': chalk.yellow(level),\n '[ERROR]': chalk.red(level),\n '[DEBUG]': chalk.gray(level),\n };\n return colors[level] || level;\n}\n\nexport function formatLog(\n level: string,\n timestamp: string,\n args: unknown[],\n options: LoggerOptions,\n): [string, ...unknown[]] {\n const { formatLog, enableColors = true } = options;\n const coloredLevel = getColor(level, enableColors);\n if (formatLog) {\n return [formatLog(coloredLevel, timestamp, args)];\n }\n return [`${coloredLevel} ${timestamp}`, ...args];\n}\n","import type { LoggerOptions, LogLevel, TimestampTypes } from './types';\nimport {
|
|
1
|
+
{"version":3,"sources":["../src/utils.ts","../src/logger.ts"],"sourcesContent":["import chalk from 'chalk';\nimport type { LoggerOptions, TimestampTypes, LogLevel } from './types';\n\nexport const TIMESTAMP_TYPES: TimestampTypes = {\n ISO: 'iso',\n Locale: 'locale',\n Custom: 'custom',\n};\n\nexport function formatTimestamp(\n formatTimestampFn: NonNullable<LoggerOptions['formatTimestamp']>,\n types: TimestampTypes,\n date: Date = new Date(),\n): string {\n const [, timestamp] = formatTimestampFn(types, date);\n return timestamp;\n}\n\nexport function getColor(level: string, enableColors: boolean): string {\n if (!enableColors) return level;\n const colors: Record<string, string> = {\n '[INFO]': chalk.blue(level),\n '[WARN]': chalk.yellow(level),\n '[ERROR]': chalk.red(level),\n '[DEBUG]': chalk.gray(level),\n };\n return colors[level] || level;\n}\n\nexport function getDiscordColor(level: LogLevel): number {\n const colors: Record<LogLevel, number> = {\n debug: 0x95a5a6,\n info: 0x3498db,\n warn: 0xf39c12,\n error: 0xe74c3c,\n };\n return colors[level];\n}\n\nexport function generateId(): string {\n return Math.random().toString(36).substr(2, 8).toUpperCase();\n}\n\nexport function formatLog(\n level: string,\n timestamp: string,\n args: unknown[],\n options: LoggerOptions,\n): [string, ...unknown[]] {\n const { formatLog, enableColors = true } = options;\n const coloredLevel = getColor(level, enableColors);\n if (formatLog) {\n return [formatLog(coloredLevel, timestamp, args)];\n }\n return [`${coloredLevel} ${timestamp}`, ...args];\n}\n","import type { LoggerOptions, LogLevel, TimestampTypes } from './types';\nimport {\n formatTimestamp,\n formatLog,\n TIMESTAMP_TYPES,\n getDiscordColor,\n generateId,\n} from './utils';\n\nimport type { TimestampType } from './types';\n\nconst defaultFormatTimestamp = (\n types: TimestampTypes,\n date: Date = new Date(),\n): [TimestampType, string] => [types.ISO, date.toISOString()];\n\nconst LOG_LEVEL_PRIORITIES: Record<LogLevel, number> = {\n debug: 0,\n info: 1,\n warn: 2,\n error: 3,\n};\n\n/**\n * A simple logger with colored outputs and timestamps.\n */\nexport class Logger {\n private options: LoggerOptions;\n private level: LogLevel;\n\n constructor(options: LoggerOptions = {}) {\n this.options = {\n enableColors: options.enableColors ?? true,\n formatTimestamp: options.formatTimestamp ?? defaultFormatTimestamp,\n formatLog: options.formatLog,\n discord: options.discord,\n };\n this.level = options.level ?? 'debug';\n }\n\n /**\n * Sets the minimum log level for filtering messages.\n * @param level - The log level to set.\n */\n setLevel(level: LogLevel): void {\n this.level = level;\n }\n\n /**\n * Sends a log message to Discord via webhook if configured.\n * @param level - The log level.\n * @param timestamp - The formatted timestamp.\n * @param args - The log arguments.\n */\n private async sendToDiscord(\n level: LogLevel,\n timestamp: string,\n args: unknown[],\n ): Promise<void> {\n const discord = this.options.discord;\n if (!discord?.enable) return;\n\n try {\n new URL(discord.webhookURL);\n } catch {\n return;\n }\n\n const message = args\n .map((arg) => (typeof arg === 'string' ? arg : JSON.stringify(arg)))\n .join(' ');\n\n const title = `${level.toUpperCase()}-${generateId()}`;\n\n const embed = discord.formatEmbed\n ? discord.formatEmbed(level, timestamp, message)\n : {\n title,\n description: message,\n timestamp: new Date().toISOString(),\n color: getDiscordColor(level),\n };\n\n await fetch(discord.webhookURL, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ embeds: [embed] }),\n }).catch(() => {});\n }\n\n /**\n * Checks if a log level should be output based on the current log level.\n * @param level - The log level to check.\n * @returns True if the message should be logged.\n */\n private shouldLog(level: LogLevel): boolean {\n return LOG_LEVEL_PRIORITIES[level] >= LOG_LEVEL_PRIORITIES[this.level];\n }\n\n /**\n * Logs an info message.\n * @param args - The arguments to log.\n */\n info(...args: unknown[]): void {\n if (!this.shouldLog('info')) return;\n const timestamp = formatTimestamp(\n this.options.formatTimestamp!,\n TIMESTAMP_TYPES,\n );\n console.log(...formatLog('[INFO]', timestamp, args, this.options));\n this.sendToDiscord('info', timestamp, args);\n }\n\n /**\n * Logs a warning message.\n * @param args - The arguments to log.\n */\n warn(...args: unknown[]): void {\n if (!this.shouldLog('warn')) return;\n const timestamp = formatTimestamp(\n this.options.formatTimestamp!,\n TIMESTAMP_TYPES,\n );\n console.log(...formatLog('[WARN]', timestamp, args, this.options));\n this.sendToDiscord('warn', timestamp, args);\n }\n\n /**\n * Logs an error message.\n * @param args - The arguments to log.\n */\n error(...args: unknown[]): void {\n if (!this.shouldLog('error')) return;\n const timestamp = formatTimestamp(\n this.options.formatTimestamp!,\n TIMESTAMP_TYPES,\n );\n console.log(...formatLog('[ERROR]', timestamp, args, this.options));\n this.sendToDiscord('error', timestamp, args);\n }\n\n /**\n * Logs a debug message.\n * @param args - The arguments to log.\n */\n debug(...args: unknown[]): void {\n if (!this.shouldLog('debug')) return;\n const timestamp = formatTimestamp(\n this.options.formatTimestamp!,\n TIMESTAMP_TYPES,\n );\n console.log(...formatLog('[DEBUG]', timestamp, args, this.options));\n this.sendToDiscord('debug', timestamp, args);\n }\n}\n"],"mappings":"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","names":["formatLog"]}
|