@degel_lc/logger 0.1.6 → 0.1.8

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.
@@ -0,0 +1,59 @@
1
+ 'use strict';
2
+
3
+ var chunk3QE5XQOJ_cjs = require('./chunk-3QE5XQOJ.cjs');
4
+
5
+ // src/client.ts
6
+ function shouldLog(logLevel, minLevel) {
7
+ return chunk3QE5XQOJ_cjs.LOG_LEVEL_PRIORITY[logLevel] >= chunk3QE5XQOJ_cjs.LOG_LEVEL_PRIORITY[minLevel];
8
+ }
9
+ function createClientLogger(config = {}) {
10
+ const { timezoneOffset = 540, enableConsole = true, level = "debug" } = config;
11
+ const minLevel = chunk3QE5XQOJ_cjs.VALID_LOG_LEVELS.includes(level) ? level : "debug";
12
+ const logToConsole = (logLevel, displayLevel, consoleMethod, ctxOrMessage, messageOrLocation, errorOrOriginal) => {
13
+ if (!enableConsole) return;
14
+ if (!shouldLog(logLevel, minLevel)) return;
15
+ let formattedMessage;
16
+ if (chunk3QE5XQOJ_cjs.isLogContext(ctxOrMessage)) {
17
+ formattedMessage = chunk3QE5XQOJ_cjs.formatLogMessageWithContext(
18
+ displayLevel,
19
+ messageOrLocation ?? "",
20
+ ctxOrMessage,
21
+ errorOrOriginal,
22
+ timezoneOffset
23
+ );
24
+ } else {
25
+ formattedMessage = chunk3QE5XQOJ_cjs.formatLogMessage(
26
+ displayLevel,
27
+ ctxOrMessage,
28
+ messageOrLocation ?? null,
29
+ errorOrOriginal ?? null,
30
+ timezoneOffset
31
+ );
32
+ }
33
+ consoleMethod(formattedMessage);
34
+ };
35
+ return {
36
+ debug: (ctxOrMessage, messageOrLocation, originalError) => {
37
+ logToConsole("debug", "debug", console.debug, ctxOrMessage, messageOrLocation, originalError);
38
+ },
39
+ info: (ctxOrMessage, messageOrLocation, originalError) => {
40
+ logToConsole("info", "info", console.info, ctxOrMessage, messageOrLocation, originalError);
41
+ },
42
+ warn: (ctxOrMessage, messageOrLocation, originalError) => {
43
+ logToConsole("warn", "warn", console.warn, ctxOrMessage, messageOrLocation, originalError);
44
+ },
45
+ error: (ctxOrMessage, messageOrLocation, originalError) => {
46
+ logToConsole("error", "error", console.error, ctxOrMessage, messageOrLocation, originalError);
47
+ },
48
+ fatal: (ctxOrMessage, messageOrLocation, originalError) => {
49
+ logToConsole("fatal", "fatal", console.error, ctxOrMessage, messageOrLocation, originalError);
50
+ },
51
+ sqlError: (message, location, originalError) => {
52
+ logToConsole("error", "sql_error", console.error, message, location, originalError);
53
+ }
54
+ };
55
+ }
56
+
57
+ exports.createClientLogger = createClientLogger;
58
+ //# sourceMappingURL=chunk-UDIZDVDO.cjs.map
59
+ //# sourceMappingURL=chunk-UDIZDVDO.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/client.ts"],"names":["LOG_LEVEL_PRIORITY","VALID_LOG_LEVELS","isLogContext","formatLogMessageWithContext","formatLogMessage"],"mappings":";;;;;AAOA,SAAS,SAAA,CAAU,UAAoB,QAAA,EAA6B;AAClE,EAAA,OAAOA,oCAAA,CAAmB,QAAQ,CAAA,IAAKA,oCAAA,CAAmB,QAAQ,CAAA;AACpE;AAKO,SAAS,kBAAA,CAAmB,MAAA,GAAuB,EAAC,EAAW;AACpE,EAAA,MAAM,EAAE,cAAA,GAAiB,GAAA,EAAK,gBAAgB,IAAA,EAAM,KAAA,GAAQ,SAAQ,GAAI,MAAA;AAGxE,EAAA,MAAM,QAAA,GAAqBC,kCAAA,CAAiB,QAAA,CAAS,KAAK,IAAI,KAAA,GAAQ,OAAA;AAEtE,EAAA,MAAM,eAAe,CACnB,QAAA,EACA,cACA,aAAA,EACA,YAAA,EACA,mBACA,eAAA,KACS;AACT,IAAA,IAAI,CAAC,aAAA,EAAe;AACpB,IAAA,IAAI,CAAC,SAAA,CAAU,QAAA,EAAU,QAAQ,CAAA,EAAG;AAEpC,IAAA,IAAI,gBAAA;AAEJ,IAAA,IAAIC,8BAAA,CAAa,YAAY,CAAA,EAAG;AAE9B,MAAA,gBAAA,GAAmBC,6CAAA;AAAA,QACjB,YAAA;AAAA,QACA,iBAAA,IAAqB,EAAA;AAAA,QACrB,YAAA;AAAA,QACA,eAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF,CAAA,MAAO;AAEL,MAAA,gBAAA,GAAmBC,kCAAA;AAAA,QACjB,YAAA;AAAA,QACA,YAAA;AAAA,QACC,iBAAA,IAAgC,IAAA;AAAA,QAChC,eAAA,IAAsC,IAAA;AAAA,QACvC;AAAA,OACF;AAAA,IACF;AAEA,IAAA,aAAA,CAAc,gBAAgB,CAAA;AAAA,EAChC,CAAA;AAEA,EAAA,OAAO;AAAA,IACL,KAAA,EAAO,CACL,YAAA,EACA,iBAAA,EACA,aAAA,KACG;AACH,MAAA,YAAA,CAAa,SAAS,OAAA,EAAS,OAAA,CAAQ,KAAA,EAAO,YAAA,EAAc,mBAAmB,aAAa,CAAA;AAAA,IAC9F,CAAA;AAAA,IACA,IAAA,EAAM,CACJ,YAAA,EACA,iBAAA,EACA,aAAA,KACG;AACH,MAAA,YAAA,CAAa,QAAQ,MAAA,EAAQ,OAAA,CAAQ,IAAA,EAAM,YAAA,EAAc,mBAAmB,aAAa,CAAA;AAAA,IAC3F,CAAA;AAAA,IACA,IAAA,EAAM,CACJ,YAAA,EACA,iBAAA,EACA,aAAA,KACG;AACH,MAAA,YAAA,CAAa,QAAQ,MAAA,EAAQ,OAAA,CAAQ,IAAA,EAAM,YAAA,EAAc,mBAAmB,aAAa,CAAA;AAAA,IAC3F,CAAA;AAAA,IACA,KAAA,EAAO,CACL,YAAA,EACA,iBAAA,EACA,aAAA,KACG;AACH,MAAA,YAAA,CAAa,SAAS,OAAA,EAAS,OAAA,CAAQ,KAAA,EAAO,YAAA,EAAc,mBAAmB,aAAa,CAAA;AAAA,IAC9F,CAAA;AAAA,IACA,KAAA,EAAO,CACL,YAAA,EACA,iBAAA,EACA,aAAA,KACG;AACH,MAAA,YAAA,CAAa,SAAS,OAAA,EAAS,OAAA,CAAQ,KAAA,EAAO,YAAA,EAAc,mBAAmB,aAAa,CAAA;AAAA,IAC9F,CAAA;AAAA,IACA,QAAA,EAAU,CACR,OAAA,EACA,QAAA,EACA,aAAA,KACG;AAEH,MAAA,YAAA,CAAa,SAAS,WAAA,EAAa,OAAA,CAAQ,KAAA,EAAO,OAAA,EAAS,UAAU,aAAa,CAAA;AAAA,IACpF;AAAA,GACF;AACF","file":"chunk-UDIZDVDO.cjs","sourcesContent":["import { LOG_LEVEL_PRIORITY, VALID_LOG_LEVELS } from './constants.js';\nimport type { LogContext, LogLevel, Logger, LoggerConfig } from './types.js';\nimport { formatLogMessage, formatLogMessageWithContext, isLogContext } from './utils.js';\n\n/**\n * 指定されたログレベルが最小レベル以上かどうかを判定\n */\nfunction shouldLog(logLevel: LogLevel, minLevel: LogLevel): boolean {\n return LOG_LEVEL_PRIORITY[logLevel] >= LOG_LEVEL_PRIORITY[minLevel];\n}\n\n/**\n * クライアントサイド用ロガーを作成\n */\nexport function createClientLogger(config: LoggerConfig = {}): Logger {\n const { timezoneOffset = 540, enableConsole = true, level = 'debug' } = config;\n\n // 有効なログレベルかどうかを検証\n const minLevel: LogLevel = VALID_LOG_LEVELS.includes(level) ? level : 'debug';\n\n const logToConsole = (\n logLevel: LogLevel,\n displayLevel: string,\n consoleMethod: (...args: unknown[]) => void,\n ctxOrMessage: LogContext | string,\n messageOrLocation?: string | null,\n errorOrOriginal?: unknown\n ): void => {\n if (!enableConsole) return;\n if (!shouldLog(logLevel, minLevel)) return;\n\n let formattedMessage: string;\n\n if (isLogContext(ctxOrMessage)) {\n // 構造化コンテキスト形式: (ctx, message, error?)\n formattedMessage = formatLogMessageWithContext(\n displayLevel,\n messageOrLocation ?? '',\n ctxOrMessage,\n errorOrOriginal,\n timezoneOffset\n );\n } else {\n // レガシー形式: (message, location?, originalError?)\n formattedMessage = formatLogMessage(\n displayLevel,\n ctxOrMessage,\n (messageOrLocation as string) ?? null,\n (errorOrOriginal as Error | string) ?? null,\n timezoneOffset\n );\n }\n\n consoleMethod(formattedMessage);\n };\n\n return {\n debug: (\n ctxOrMessage: LogContext | string,\n messageOrLocation?: string | null,\n originalError?: unknown\n ) => {\n logToConsole('debug', 'debug', console.debug, ctxOrMessage, messageOrLocation, originalError);\n },\n info: (\n ctxOrMessage: LogContext | string,\n messageOrLocation?: string | null,\n originalError?: unknown\n ) => {\n logToConsole('info', 'info', console.info, ctxOrMessage, messageOrLocation, originalError);\n },\n warn: (\n ctxOrMessage: LogContext | string,\n messageOrLocation?: string | null,\n originalError?: unknown\n ) => {\n logToConsole('warn', 'warn', console.warn, ctxOrMessage, messageOrLocation, originalError);\n },\n error: (\n ctxOrMessage: LogContext | string,\n messageOrLocation?: string | null,\n originalError?: unknown\n ) => {\n logToConsole('error', 'error', console.error, ctxOrMessage, messageOrLocation, originalError);\n },\n fatal: (\n ctxOrMessage: LogContext | string,\n messageOrLocation?: string | null,\n originalError?: unknown\n ) => {\n logToConsole('fatal', 'fatal', console.error, ctxOrMessage, messageOrLocation, originalError);\n },\n sqlError: (\n message: string,\n location?: string | null,\n originalError?: Error | string | null\n ) => {\n // sqlErrorはerrorレベルとしてフィルタリング、表示はsql_error\n logToConsole('error', 'sql_error', console.error, message, location, originalError);\n },\n } as Logger;\n}\n"]}
@@ -0,0 +1,165 @@
1
+ import { Level } from 'pino';
2
+
3
+ /**
4
+ * ログコンテキスト(構造化ログ用)
5
+ */
6
+ interface LogContext {
7
+ /** APIパス */
8
+ path?: string;
9
+ /** HTTPメソッド */
10
+ method?: string;
11
+ /** ユーザーID */
12
+ userId?: string;
13
+ /** テナントID */
14
+ tenantId?: string;
15
+ /** ファイル位置(レガシー互換) */
16
+ location?: string;
17
+ /** その他の任意データ */
18
+ [key: string]: unknown;
19
+ }
20
+ /**
21
+ * ログメソッドのシグネチャ(レガシー形式)
22
+ */
23
+ type LogMethod = (message: string, location?: string | null, originalError?: Error | string | null) => void;
24
+ /**
25
+ * ログメソッドのシグネチャ(構造化コンテキスト形式)
26
+ */
27
+ type LogMethodWithContext = (ctx: LogContext, message: string, error?: unknown) => void;
28
+ /**
29
+ * Loggerインターフェース(オーバーロード対応)
30
+ */
31
+ interface Logger {
32
+ debug(ctx: LogContext, message: string): void;
33
+ info(ctx: LogContext, message: string): void;
34
+ warn(ctx: LogContext, message: string): void;
35
+ error(ctx: LogContext, message: string, error?: unknown): void;
36
+ fatal(ctx: LogContext, message: string, error?: unknown): void;
37
+ debug(message: string, location?: string | null, originalError?: Error | string | null): void;
38
+ info(message: string, location?: string | null, originalError?: Error | string | null): void;
39
+ warn(message: string, location?: string | null, originalError?: Error | string | null): void;
40
+ error(message: string, location?: string | null, originalError?: Error | string | null): void;
41
+ fatal(message: string, location?: string | null, originalError?: Error | string | null): void;
42
+ sqlError(message: string, location?: string | null, originalError?: Error | string | null): void;
43
+ }
44
+ /**
45
+ * ログレベル
46
+ */
47
+ type LogLevel = 'debug' | 'info' | 'warn' | 'error' | 'fatal';
48
+ /**
49
+ * ログタイプの設定
50
+ */
51
+ interface LogTypeConfig {
52
+ fileNamePrefix: string;
53
+ level: Level;
54
+ }
55
+ /**
56
+ * Sentryモジュールの型
57
+ * @sentry/node と @sentry/nextjs の両方で使用可能
58
+ * メソッド構文を使用して双変(bivariant)にし、型互換性を確保
59
+ */
60
+ interface SentryModule {
61
+ /**
62
+ * 例外をSentryに送信
63
+ */
64
+ captureException(error: unknown, hint?: {
65
+ extra?: Record<string, unknown>;
66
+ }): string;
67
+ /**
68
+ * メッセージをSentryに送信
69
+ */
70
+ captureMessage(message: string, captureContext?: unknown): string;
71
+ }
72
+ /**
73
+ * ロガー設定オプション
74
+ */
75
+ interface LoggerConfig {
76
+ /**
77
+ * ログ出力ディレクトリ(サーバーサイドのみ)
78
+ * デフォルト: process.cwd() + '/logs'
79
+ */
80
+ logDir?: string;
81
+ /**
82
+ * 最小ログレベル
83
+ * デフォルト: 'debug'
84
+ */
85
+ level?: LogLevel;
86
+ /**
87
+ * ログローテーションのチェック間隔(ミリ秒)
88
+ * デフォルト: 3600000 (1時間)
89
+ */
90
+ rotationCheckInterval?: number;
91
+ /**
92
+ * タイムゾーンオフセット(分)
93
+ * デフォルト: 540 (JST = UTC+9)
94
+ */
95
+ timezoneOffset?: number;
96
+ /**
97
+ * クライアントサイドでコンソール出力を有効化
98
+ * デフォルト: true
99
+ */
100
+ enableConsole?: boolean;
101
+ /**
102
+ * Sentry連携を有効化
103
+ * @default false
104
+ */
105
+ enableSentry?: boolean;
106
+ }
107
+
108
+ /**
109
+ * クライアントサイド用ロガーを作成
110
+ */
111
+ declare function createClientLogger(config?: LoggerConfig): Logger;
112
+
113
+ /**
114
+ * Sentry連携ヘルパー
115
+ */
116
+
117
+ /**
118
+ * Sentryモジュールを設定
119
+ */
120
+ declare function setSentryModule(sentry: SentryModule): void;
121
+ /**
122
+ * Sentryが有効かどうか
123
+ */
124
+ declare function isSentryEnabled(): boolean;
125
+
126
+ /**
127
+ * ログレベル関連の定数
128
+ */
129
+
130
+ /**
131
+ * 有効なログレベル一覧
132
+ * LogLevel型と同期した配列
133
+ */
134
+ declare const VALID_LOG_LEVELS: readonly LogLevel[];
135
+ /**
136
+ * ログレベルの優先度マップ
137
+ * 数値が大きいほど優先度が高い
138
+ */
139
+ declare const LOG_LEVEL_PRIORITY: Record<LogLevel, number>;
140
+ /**
141
+ * タイムゾーン関連
142
+ */
143
+ declare const TIMEZONE: {
144
+ /** 日本標準時(JST)のUTCオフセット(分) */
145
+ JST_OFFSET_MINUTES: number;
146
+ };
147
+ /**
148
+ * ログローテーション関連
149
+ */
150
+ declare const LOG_ROTATION: {
151
+ /** デフォルトのローテーションチェック間隔(ミリ秒): 1時間 */
152
+ readonly DEFAULT_CHECK_INTERVAL_MS: number;
153
+ };
154
+ /**
155
+ * ログファイル名プレフィックス
156
+ */
157
+ declare const LOG_FILE_PREFIX: {
158
+ readonly DEBUG: "debug_log";
159
+ readonly INFO: "info_log";
160
+ readonly ERROR: "error_log";
161
+ readonly FATAL: "fatal_log";
162
+ readonly SQL_ERROR: "sql_error_log";
163
+ };
164
+
165
+ export { type Logger as L, type SentryModule as S, TIMEZONE as T, VALID_LOG_LEVELS as V, type LoggerConfig as a, type LogContext as b, type LogLevel as c, type LogMethod as d, type LogMethodWithContext as e, type LogTypeConfig as f, createClientLogger as g, LOG_FILE_PREFIX as h, isSentryEnabled as i, LOG_LEVEL_PRIORITY as j, LOG_ROTATION as k, setSentryModule as s };
@@ -0,0 +1,165 @@
1
+ import { Level } from 'pino';
2
+
3
+ /**
4
+ * ログコンテキスト(構造化ログ用)
5
+ */
6
+ interface LogContext {
7
+ /** APIパス */
8
+ path?: string;
9
+ /** HTTPメソッド */
10
+ method?: string;
11
+ /** ユーザーID */
12
+ userId?: string;
13
+ /** テナントID */
14
+ tenantId?: string;
15
+ /** ファイル位置(レガシー互換) */
16
+ location?: string;
17
+ /** その他の任意データ */
18
+ [key: string]: unknown;
19
+ }
20
+ /**
21
+ * ログメソッドのシグネチャ(レガシー形式)
22
+ */
23
+ type LogMethod = (message: string, location?: string | null, originalError?: Error | string | null) => void;
24
+ /**
25
+ * ログメソッドのシグネチャ(構造化コンテキスト形式)
26
+ */
27
+ type LogMethodWithContext = (ctx: LogContext, message: string, error?: unknown) => void;
28
+ /**
29
+ * Loggerインターフェース(オーバーロード対応)
30
+ */
31
+ interface Logger {
32
+ debug(ctx: LogContext, message: string): void;
33
+ info(ctx: LogContext, message: string): void;
34
+ warn(ctx: LogContext, message: string): void;
35
+ error(ctx: LogContext, message: string, error?: unknown): void;
36
+ fatal(ctx: LogContext, message: string, error?: unknown): void;
37
+ debug(message: string, location?: string | null, originalError?: Error | string | null): void;
38
+ info(message: string, location?: string | null, originalError?: Error | string | null): void;
39
+ warn(message: string, location?: string | null, originalError?: Error | string | null): void;
40
+ error(message: string, location?: string | null, originalError?: Error | string | null): void;
41
+ fatal(message: string, location?: string | null, originalError?: Error | string | null): void;
42
+ sqlError(message: string, location?: string | null, originalError?: Error | string | null): void;
43
+ }
44
+ /**
45
+ * ログレベル
46
+ */
47
+ type LogLevel = 'debug' | 'info' | 'warn' | 'error' | 'fatal';
48
+ /**
49
+ * ログタイプの設定
50
+ */
51
+ interface LogTypeConfig {
52
+ fileNamePrefix: string;
53
+ level: Level;
54
+ }
55
+ /**
56
+ * Sentryモジュールの型
57
+ * @sentry/node と @sentry/nextjs の両方で使用可能
58
+ * メソッド構文を使用して双変(bivariant)にし、型互換性を確保
59
+ */
60
+ interface SentryModule {
61
+ /**
62
+ * 例外をSentryに送信
63
+ */
64
+ captureException(error: unknown, hint?: {
65
+ extra?: Record<string, unknown>;
66
+ }): string;
67
+ /**
68
+ * メッセージをSentryに送信
69
+ */
70
+ captureMessage(message: string, captureContext?: unknown): string;
71
+ }
72
+ /**
73
+ * ロガー設定オプション
74
+ */
75
+ interface LoggerConfig {
76
+ /**
77
+ * ログ出力ディレクトリ(サーバーサイドのみ)
78
+ * デフォルト: process.cwd() + '/logs'
79
+ */
80
+ logDir?: string;
81
+ /**
82
+ * 最小ログレベル
83
+ * デフォルト: 'debug'
84
+ */
85
+ level?: LogLevel;
86
+ /**
87
+ * ログローテーションのチェック間隔(ミリ秒)
88
+ * デフォルト: 3600000 (1時間)
89
+ */
90
+ rotationCheckInterval?: number;
91
+ /**
92
+ * タイムゾーンオフセット(分)
93
+ * デフォルト: 540 (JST = UTC+9)
94
+ */
95
+ timezoneOffset?: number;
96
+ /**
97
+ * クライアントサイドでコンソール出力を有効化
98
+ * デフォルト: true
99
+ */
100
+ enableConsole?: boolean;
101
+ /**
102
+ * Sentry連携を有効化
103
+ * @default false
104
+ */
105
+ enableSentry?: boolean;
106
+ }
107
+
108
+ /**
109
+ * クライアントサイド用ロガーを作成
110
+ */
111
+ declare function createClientLogger(config?: LoggerConfig): Logger;
112
+
113
+ /**
114
+ * Sentry連携ヘルパー
115
+ */
116
+
117
+ /**
118
+ * Sentryモジュールを設定
119
+ */
120
+ declare function setSentryModule(sentry: SentryModule): void;
121
+ /**
122
+ * Sentryが有効かどうか
123
+ */
124
+ declare function isSentryEnabled(): boolean;
125
+
126
+ /**
127
+ * ログレベル関連の定数
128
+ */
129
+
130
+ /**
131
+ * 有効なログレベル一覧
132
+ * LogLevel型と同期した配列
133
+ */
134
+ declare const VALID_LOG_LEVELS: readonly LogLevel[];
135
+ /**
136
+ * ログレベルの優先度マップ
137
+ * 数値が大きいほど優先度が高い
138
+ */
139
+ declare const LOG_LEVEL_PRIORITY: Record<LogLevel, number>;
140
+ /**
141
+ * タイムゾーン関連
142
+ */
143
+ declare const TIMEZONE: {
144
+ /** 日本標準時(JST)のUTCオフセット(分) */
145
+ JST_OFFSET_MINUTES: number;
146
+ };
147
+ /**
148
+ * ログローテーション関連
149
+ */
150
+ declare const LOG_ROTATION: {
151
+ /** デフォルトのローテーションチェック間隔(ミリ秒): 1時間 */
152
+ readonly DEFAULT_CHECK_INTERVAL_MS: number;
153
+ };
154
+ /**
155
+ * ログファイル名プレフィックス
156
+ */
157
+ declare const LOG_FILE_PREFIX: {
158
+ readonly DEBUG: "debug_log";
159
+ readonly INFO: "info_log";
160
+ readonly ERROR: "error_log";
161
+ readonly FATAL: "fatal_log";
162
+ readonly SQL_ERROR: "sql_error_log";
163
+ };
164
+
165
+ export { type Logger as L, type SentryModule as S, TIMEZONE as T, VALID_LOG_LEVELS as V, type LoggerConfig as a, type LogContext as b, type LogLevel as c, type LogMethod as d, type LogMethodWithContext as e, type LogTypeConfig as f, createClientLogger as g, LOG_FILE_PREFIX as h, isSentryEnabled as i, LOG_LEVEL_PRIORITY as j, LOG_ROTATION as k, setSentryModule as s };
package/dist/index.cjs ADDED
@@ -0,0 +1,94 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var chunkUDIZDVDO_cjs = require('./chunk-UDIZDVDO.cjs');
6
+ var chunk3QE5XQOJ_cjs = require('./chunk-3QE5XQOJ.cjs');
7
+
8
+ // src/index.ts
9
+ async function createServerLogger(config) {
10
+ const { createServerLogger: create } = await import('./server-E7QYW63S.cjs');
11
+ return create(config);
12
+ }
13
+ function getLogger() {
14
+ if (globalThis.__DEGEL_LOGGER__) {
15
+ return globalThis.__DEGEL_LOGGER__;
16
+ }
17
+ if (typeof window !== "undefined") {
18
+ globalThis.__DEGEL_LOGGER__ = chunkUDIZDVDO_cjs.createClientLogger();
19
+ return globalThis.__DEGEL_LOGGER__;
20
+ }
21
+ if (!globalThis.__DEGEL_LOGGER_INITIALIZED__) {
22
+ return chunkUDIZDVDO_cjs.createClientLogger();
23
+ }
24
+ return globalThis.__DEGEL_LOGGER__ ?? chunkUDIZDVDO_cjs.createClientLogger();
25
+ }
26
+ async function initializeLogger(config) {
27
+ if (globalThis.__DEGEL_LOGGER__ && globalThis.__DEGEL_LOGGER_INITIALIZED__) {
28
+ return globalThis.__DEGEL_LOGGER__;
29
+ }
30
+ if (typeof window !== "undefined") {
31
+ globalThis.__DEGEL_LOGGER__ = chunkUDIZDVDO_cjs.createClientLogger(config);
32
+ } else {
33
+ globalThis.__DEGEL_LOGGER__ = await createServerLogger(config);
34
+ }
35
+ globalThis.__DEGEL_LOGGER_INITIALIZED__ = true;
36
+ return globalThis.__DEGEL_LOGGER__;
37
+ }
38
+ var logger = {
39
+ debug: (ctxOrMessage, messageOrLocation, originalError) => getLogger().debug(ctxOrMessage, messageOrLocation, originalError),
40
+ info: (ctxOrMessage, messageOrLocation, originalError) => getLogger().info(ctxOrMessage, messageOrLocation, originalError),
41
+ warn: (ctxOrMessage, messageOrLocation, originalError) => getLogger().warn(ctxOrMessage, messageOrLocation, originalError),
42
+ error: (ctxOrMessage, messageOrLocation, originalError) => getLogger().error(
43
+ ctxOrMessage,
44
+ messageOrLocation,
45
+ originalError
46
+ ),
47
+ fatal: (ctxOrMessage, messageOrLocation, originalError) => getLogger().fatal(
48
+ ctxOrMessage,
49
+ messageOrLocation,
50
+ originalError
51
+ ),
52
+ sqlError: (message, location, originalError) => getLogger().sqlError(message, location, originalError)
53
+ };
54
+ var index_default = logger;
55
+
56
+ Object.defineProperty(exports, "createClientLogger", {
57
+ enumerable: true,
58
+ get: function () { return chunkUDIZDVDO_cjs.createClientLogger; }
59
+ });
60
+ Object.defineProperty(exports, "LOG_FILE_PREFIX", {
61
+ enumerable: true,
62
+ get: function () { return chunk3QE5XQOJ_cjs.LOG_FILE_PREFIX; }
63
+ });
64
+ Object.defineProperty(exports, "LOG_LEVEL_PRIORITY", {
65
+ enumerable: true,
66
+ get: function () { return chunk3QE5XQOJ_cjs.LOG_LEVEL_PRIORITY; }
67
+ });
68
+ Object.defineProperty(exports, "LOG_ROTATION", {
69
+ enumerable: true,
70
+ get: function () { return chunk3QE5XQOJ_cjs.LOG_ROTATION; }
71
+ });
72
+ Object.defineProperty(exports, "TIMEZONE", {
73
+ enumerable: true,
74
+ get: function () { return chunk3QE5XQOJ_cjs.TIMEZONE; }
75
+ });
76
+ Object.defineProperty(exports, "VALID_LOG_LEVELS", {
77
+ enumerable: true,
78
+ get: function () { return chunk3QE5XQOJ_cjs.VALID_LOG_LEVELS; }
79
+ });
80
+ Object.defineProperty(exports, "isSentryEnabled", {
81
+ enumerable: true,
82
+ get: function () { return chunk3QE5XQOJ_cjs.isSentryEnabled; }
83
+ });
84
+ Object.defineProperty(exports, "setSentryModule", {
85
+ enumerable: true,
86
+ get: function () { return chunk3QE5XQOJ_cjs.setSentryModule; }
87
+ });
88
+ exports.createServerLogger = createServerLogger;
89
+ exports.default = index_default;
90
+ exports.getLogger = getLogger;
91
+ exports.initializeLogger = initializeLogger;
92
+ exports.logger = logger;
93
+ //# sourceMappingURL=index.cjs.map
94
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/index.ts"],"names":["createClientLogger"],"mappings":";;;;;;;;AAwCA,eAAsB,mBAAmB,MAAA,EAAwC;AAC/E,EAAA,MAAM,EAAE,kBAAA,EAAoB,MAAA,EAAO,GAAI,MAAM,OAAO,uBAAa,CAAA;AACjE,EAAA,OAAO,OAAO,MAAM,CAAA;AACtB;AAkBO,SAAS,SAAA,GAAoB;AAElC,EAAA,IAAI,WAAW,gBAAA,EAAkB;AAC/B,IAAA,OAAO,UAAA,CAAW,gBAAA;AAAA,EACpB;AAGA,EAAA,IAAI,OAAO,WAAW,WAAA,EAAa;AACjC,IAAA,UAAA,CAAW,mBAAmBA,oCAAA,EAAmB;AACjD,IAAA,OAAO,UAAA,CAAW,gBAAA;AAAA,EACpB;AAIA,EAAA,IAAI,CAAC,WAAW,4BAAA,EAA8B;AAC5C,IAAA,OAAOA,oCAAA,EAAmB;AAAA,EAC5B;AAEA,EAAA,OAAO,UAAA,CAAW,oBAAoBA,oCAAA,EAAmB;AAC3D;AAMA,eAAsB,iBAAiB,MAAA,EAAwC;AAE7E,EAAA,IAAI,UAAA,CAAW,gBAAA,IAAoB,UAAA,CAAW,4BAAA,EAA8B;AAC1E,IAAA,OAAO,UAAA,CAAW,gBAAA;AAAA,EACpB;AAEA,EAAA,IAAI,OAAO,WAAW,WAAA,EAAa;AACjC,IAAA,UAAA,CAAW,gBAAA,GAAmBA,qCAAmB,MAAM,CAAA;AAAA,EACzD,CAAA,MAAO;AACL,IAAA,UAAA,CAAW,gBAAA,GAAmB,MAAM,kBAAA,CAAmB,MAAM,CAAA;AAAA,EAC/D;AACA,EAAA,UAAA,CAAW,4BAAA,GAA+B,IAAA;AAC1C,EAAA,OAAO,UAAA,CAAW,gBAAA;AACpB;AAMO,IAAM,MAAA,GAAiB;AAAA,EAC5B,KAAA,EAAO,CAAC,YAAA,EAAc,iBAAA,EAAmB,aAAA,KACvC,WAAU,CAAE,KAAA,CAAM,YAAA,EAAwB,iBAAA,EAAmB,aAAa,CAAA;AAAA,EAC5E,IAAA,EAAM,CAAC,YAAA,EAAc,iBAAA,EAAmB,aAAA,KACtC,WAAU,CAAE,IAAA,CAAK,YAAA,EAAwB,iBAAA,EAAmB,aAAa,CAAA;AAAA,EAC3E,IAAA,EAAM,CAAC,YAAA,EAAc,iBAAA,EAAmB,aAAA,KACtC,WAAU,CAAE,IAAA,CAAK,YAAA,EAAwB,iBAAA,EAAmB,aAAa,CAAA;AAAA,EAC3E,OAAO,CAAC,YAAA,EAAc,iBAAA,EAAmB,aAAA,KACvC,WAAU,CAAE,KAAA;AAAA,IACV,YAAA;AAAA,IACA,iBAAA;AAAA,IACA;AAAA,GACF;AAAA,EACF,OAAO,CAAC,YAAA,EAAc,iBAAA,EAAmB,aAAA,KACvC,WAAU,CAAE,KAAA;AAAA,IACV,YAAA;AAAA,IACA,iBAAA;AAAA,IACA;AAAA,GACF;AAAA,EACF,QAAA,EAAU,CAAC,OAAA,EAAS,QAAA,EAAU,aAAA,KAC5B,WAAU,CAAE,QAAA,CAAS,OAAA,EAAS,QAAA,EAAU,aAAa;AACzD;AAEA,IAAO,aAAA,GAAQ","file":"index.cjs","sourcesContent":["import { createClientLogger } from './client.js';\nimport type {\n LogContext,\n LogLevel,\n LogMethod,\n LogMethodWithContext,\n LogTypeConfig,\n Logger,\n LoggerConfig,\n SentryModule,\n} from './types.js';\n\nexport type {\n LogContext,\n Logger,\n LoggerConfig,\n LogLevel,\n LogMethod,\n LogMethodWithContext,\n LogTypeConfig,\n SentryModule,\n};\n\nexport { createClientLogger };\nexport { isSentryEnabled, setSentryModule } from './sentry.js';\n\n// Constants\nexport {\n LOG_FILE_PREFIX,\n LOG_LEVEL_PRIORITY,\n LOG_ROTATION,\n TIMEZONE,\n VALID_LOG_LEVELS,\n} from './constants.js';\n\n/**\n * サーバーサイド用ロガー作成関数(動的import)\n * Next.jsなどのバンドラーでクライアント用にバンドルされる際に\n * fsモジュールの解決エラーを防ぐため、動的importで提供\n */\nexport async function createServerLogger(config?: LoggerConfig): Promise<Logger> {\n const { createServerLogger: create } = await import('./server.js');\n return create(config);\n}\n\n/**\n * グローバルシングルトン用の型定義\n * Next.js開発モードでのモジュール分離問題を解決するため、\n * globalThisを使用してロガーインスタンスを共有する\n */\ndeclare global {\n // eslint-disable-next-line no-var\n var __DEGEL_LOGGER__: Logger | undefined;\n // eslint-disable-next-line no-var\n var __DEGEL_LOGGER_INITIALIZED__: boolean | undefined;\n}\n\n/**\n * 環境を判定してデフォルトのロガーを取得\n * サーバーサイドでは非同期初期化が必要なため、初回呼び出し時はクライアントロガーを返す\n */\nexport function getLogger(): Logger {\n // グローバルに初期化済みのロガーがあれば返す\n if (globalThis.__DEGEL_LOGGER__) {\n return globalThis.__DEGEL_LOGGER__;\n }\n\n // クライアントサイドの場合\n if (typeof window !== 'undefined') {\n globalThis.__DEGEL_LOGGER__ = createClientLogger();\n return globalThis.__DEGEL_LOGGER__;\n }\n\n // サーバーサイドだが未初期化の場合は一時的にクライアントロガーを返す\n // initializeLogger()を呼び出すことで正しく初期化される\n if (!globalThis.__DEGEL_LOGGER_INITIALIZED__) {\n return createClientLogger();\n }\n\n return globalThis.__DEGEL_LOGGER__ ?? createClientLogger();\n}\n\n/**\n * サーバーサイド用の非同期初期化\n * Next.js等で使用する場合、アプリケーション起動時に呼び出す\n */\nexport async function initializeLogger(config?: LoggerConfig): Promise<Logger> {\n // 既に初期化済みの場合は既存のロガーを返す\n if (globalThis.__DEGEL_LOGGER__ && globalThis.__DEGEL_LOGGER_INITIALIZED__) {\n return globalThis.__DEGEL_LOGGER__;\n }\n\n if (typeof window !== 'undefined') {\n globalThis.__DEGEL_LOGGER__ = createClientLogger(config);\n } else {\n globalThis.__DEGEL_LOGGER__ = await createServerLogger(config);\n }\n globalThis.__DEGEL_LOGGER_INITIALIZED__ = true;\n return globalThis.__DEGEL_LOGGER__;\n}\n\n/**\n * 共通ロガーオブジェクト(後方互換性のため)\n * サーバー/クライアントで自動的に適切なロガーを選択\n */\nexport const logger: Logger = {\n debug: (ctxOrMessage, messageOrLocation, originalError) =>\n getLogger().debug(ctxOrMessage as string, messageOrLocation, originalError),\n info: (ctxOrMessage, messageOrLocation, originalError) =>\n getLogger().info(ctxOrMessage as string, messageOrLocation, originalError),\n warn: (ctxOrMessage, messageOrLocation, originalError) =>\n getLogger().warn(ctxOrMessage as string, messageOrLocation, originalError),\n error: (ctxOrMessage, messageOrLocation, originalError) =>\n getLogger().error(\n ctxOrMessage as string,\n messageOrLocation,\n originalError as Error | string | null | undefined\n ),\n fatal: (ctxOrMessage, messageOrLocation, originalError) =>\n getLogger().fatal(\n ctxOrMessage as string,\n messageOrLocation,\n originalError as Error | string | null | undefined\n ),\n sqlError: (message, location, originalError) =>\n getLogger().sqlError(message, location, originalError),\n} as Logger;\n\nexport default logger;\n"]}
@@ -0,0 +1,36 @@
1
+ import { L as Logger, a as LoggerConfig } from './constants-Dw2vmgrv.cjs';
2
+ export { h as LOG_FILE_PREFIX, j as LOG_LEVEL_PRIORITY, k as LOG_ROTATION, b as LogContext, c as LogLevel, d as LogMethod, e as LogMethodWithContext, f as LogTypeConfig, S as SentryModule, T as TIMEZONE, V as VALID_LOG_LEVELS, g as createClientLogger, i as isSentryEnabled, s as setSentryModule } from './constants-Dw2vmgrv.cjs';
3
+ import 'pino';
4
+
5
+ /**
6
+ * サーバーサイド用ロガー作成関数(動的import)
7
+ * Next.jsなどのバンドラーでクライアント用にバンドルされる際に
8
+ * fsモジュールの解決エラーを防ぐため、動的importで提供
9
+ */
10
+ declare function createServerLogger(config?: LoggerConfig): Promise<Logger>;
11
+ /**
12
+ * グローバルシングルトン用の型定義
13
+ * Next.js開発モードでのモジュール分離問題を解決するため、
14
+ * globalThisを使用してロガーインスタンスを共有する
15
+ */
16
+ declare global {
17
+ var __DEGEL_LOGGER__: Logger | undefined;
18
+ var __DEGEL_LOGGER_INITIALIZED__: boolean | undefined;
19
+ }
20
+ /**
21
+ * 環境を判定してデフォルトのロガーを取得
22
+ * サーバーサイドでは非同期初期化が必要なため、初回呼び出し時はクライアントロガーを返す
23
+ */
24
+ declare function getLogger(): Logger;
25
+ /**
26
+ * サーバーサイド用の非同期初期化
27
+ * Next.js等で使用する場合、アプリケーション起動時に呼び出す
28
+ */
29
+ declare function initializeLogger(config?: LoggerConfig): Promise<Logger>;
30
+ /**
31
+ * 共通ロガーオブジェクト(後方互換性のため)
32
+ * サーバー/クライアントで自動的に適切なロガーを選択
33
+ */
34
+ declare const logger: Logger;
35
+
36
+ export { Logger, LoggerConfig, createServerLogger, logger as default, getLogger, initializeLogger, logger };