logixlysia 5.2.0 → 6.0.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/dist/index.d.ts +68 -85
- package/dist/index.js +5 -12
- package/package.json +27 -73
- package/src/extensions/banner.ts +26 -0
- package/src/extensions/index.ts +28 -0
- package/src/helpers/status.ts +58 -0
- package/src/index.ts +106 -0
- package/src/interfaces.ts +117 -0
- package/src/logger/create-logger.ts +246 -0
- package/src/logger/handle-http-error.ts +51 -0
- package/src/logger/index.ts +126 -0
- package/src/output/file.ts +85 -0
- package/src/output/fs.ts +5 -0
- package/src/output/index.ts +58 -0
- package/src/output/rotation-manager.ts +122 -0
- package/src/utils/error.ts +15 -0
- package/src/utils/rotation.ts +91 -0
- package/LICENSE +0 -21
- package/README.md +0 -51
- package/dist/index.cjs +0 -13
- package/dist/index.d.cts +0 -88
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import { appendFile } from 'node:fs/promises'
|
|
2
|
+
import { dirname } from 'node:path'
|
|
3
|
+
import type { LogLevel, Options, RequestInfo, StoreData } from '../interfaces'
|
|
4
|
+
import { ensureDir } from './fs'
|
|
5
|
+
import { performRotation, shouldRotate } from './rotation-manager'
|
|
6
|
+
|
|
7
|
+
type LogToFileInput = {
|
|
8
|
+
filePath: string
|
|
9
|
+
level: LogLevel
|
|
10
|
+
request: RequestInfo
|
|
11
|
+
data: Record<string, unknown>
|
|
12
|
+
store: StoreData
|
|
13
|
+
options: Options
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export const logToFile = async (
|
|
17
|
+
...args:
|
|
18
|
+
| [LogToFileInput]
|
|
19
|
+
| [
|
|
20
|
+
string,
|
|
21
|
+
LogLevel,
|
|
22
|
+
RequestInfo,
|
|
23
|
+
Record<string, unknown>,
|
|
24
|
+
StoreData,
|
|
25
|
+
Options
|
|
26
|
+
]
|
|
27
|
+
): Promise<void> => {
|
|
28
|
+
const input: LogToFileInput =
|
|
29
|
+
typeof args[0] === 'string'
|
|
30
|
+
? (() => {
|
|
31
|
+
const [
|
|
32
|
+
filePathArg,
|
|
33
|
+
levelArg,
|
|
34
|
+
requestArg,
|
|
35
|
+
dataArg,
|
|
36
|
+
storeArg,
|
|
37
|
+
optionsArg
|
|
38
|
+
] = args as [
|
|
39
|
+
string,
|
|
40
|
+
LogLevel,
|
|
41
|
+
RequestInfo,
|
|
42
|
+
Record<string, unknown>,
|
|
43
|
+
StoreData,
|
|
44
|
+
Options
|
|
45
|
+
]
|
|
46
|
+
return {
|
|
47
|
+
filePath: filePathArg,
|
|
48
|
+
level: levelArg,
|
|
49
|
+
request: requestArg,
|
|
50
|
+
data: dataArg,
|
|
51
|
+
store: storeArg,
|
|
52
|
+
options: optionsArg
|
|
53
|
+
}
|
|
54
|
+
})()
|
|
55
|
+
: args[0]
|
|
56
|
+
|
|
57
|
+
const { filePath, level, request, data, store, options } = input
|
|
58
|
+
const config = options.config
|
|
59
|
+
const useTransportsOnly = config?.useTransportsOnly === true
|
|
60
|
+
const disableFileLogging = config?.disableFileLogging === true
|
|
61
|
+
if (useTransportsOnly || disableFileLogging) {
|
|
62
|
+
return
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
const message = typeof data.message === 'string' ? data.message : ''
|
|
66
|
+
const durationMs =
|
|
67
|
+
store.beforeTime === BigInt(0)
|
|
68
|
+
? 0
|
|
69
|
+
: Number(process.hrtime.bigint() - store.beforeTime) / 1_000_000
|
|
70
|
+
|
|
71
|
+
const line = `${level} ${durationMs.toFixed(2)}ms ${request.method} ${new URL(request.url).pathname} ${message}\n`
|
|
72
|
+
|
|
73
|
+
await ensureDir(dirname(filePath))
|
|
74
|
+
await appendFile(filePath, line, { encoding: 'utf-8' })
|
|
75
|
+
|
|
76
|
+
const rotation = config?.logRotation
|
|
77
|
+
if (!rotation) {
|
|
78
|
+
return
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
const should = await shouldRotate(filePath, rotation)
|
|
82
|
+
if (should) {
|
|
83
|
+
await performRotation(filePath, rotation)
|
|
84
|
+
}
|
|
85
|
+
}
|
package/src/output/fs.ts
ADDED
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import type { LogLevel, Options, RequestInfo, StoreData } from '../interfaces'
|
|
2
|
+
|
|
3
|
+
type LogToTransportsInput = {
|
|
4
|
+
level: LogLevel
|
|
5
|
+
request: RequestInfo
|
|
6
|
+
data: Record<string, unknown>
|
|
7
|
+
store: StoreData
|
|
8
|
+
options: Options
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export const logToTransports = (
|
|
12
|
+
...args:
|
|
13
|
+
| [LogToTransportsInput]
|
|
14
|
+
| [LogLevel, RequestInfo, Record<string, unknown>, StoreData, Options]
|
|
15
|
+
): void => {
|
|
16
|
+
const input: LogToTransportsInput =
|
|
17
|
+
typeof args[0] === 'string'
|
|
18
|
+
? {
|
|
19
|
+
level: args[0],
|
|
20
|
+
request: args[1],
|
|
21
|
+
data: args[2],
|
|
22
|
+
store: args[3],
|
|
23
|
+
options: args[4]
|
|
24
|
+
}
|
|
25
|
+
: args[0]
|
|
26
|
+
|
|
27
|
+
const { level, request, data, store, options } = input
|
|
28
|
+
const transports = options.config?.transports ?? []
|
|
29
|
+
if (transports.length === 0) {
|
|
30
|
+
return
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
const message = typeof data.message === 'string' ? data.message : ''
|
|
34
|
+
const meta: Record<string, unknown> = {
|
|
35
|
+
request: {
|
|
36
|
+
method: request.method,
|
|
37
|
+
url: request.url
|
|
38
|
+
},
|
|
39
|
+
...data,
|
|
40
|
+
beforeTime: store.beforeTime
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
for (const transport of transports) {
|
|
44
|
+
try {
|
|
45
|
+
const result = transport.log(level, message, meta)
|
|
46
|
+
if (
|
|
47
|
+
result &&
|
|
48
|
+
typeof (result as { catch?: unknown }).catch === 'function'
|
|
49
|
+
) {
|
|
50
|
+
;(result as Promise<void>).catch(() => {
|
|
51
|
+
// Ignore errors
|
|
52
|
+
})
|
|
53
|
+
}
|
|
54
|
+
} catch {
|
|
55
|
+
// Transport failures must never crash application logging.
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { promises as fs } from 'node:fs'
|
|
2
|
+
import { promisify } from 'node:util'
|
|
3
|
+
import { gzip } from 'node:zlib'
|
|
4
|
+
import type { LogRotationConfig } from '../interfaces'
|
|
5
|
+
import {
|
|
6
|
+
getRotatedFiles,
|
|
7
|
+
parseRetention,
|
|
8
|
+
parseSize,
|
|
9
|
+
shouldRotateBySize
|
|
10
|
+
} from '../utils/rotation'
|
|
11
|
+
|
|
12
|
+
const gzipAsync = promisify(gzip)
|
|
13
|
+
|
|
14
|
+
const pad2 = (value: number): string => String(value).padStart(2, '0')
|
|
15
|
+
|
|
16
|
+
export const getRotatedFileName = (filePath: string, date: Date): string => {
|
|
17
|
+
const yyyy = date.getFullYear()
|
|
18
|
+
const mm = pad2(date.getMonth() + 1)
|
|
19
|
+
const dd = pad2(date.getDate())
|
|
20
|
+
const HH = pad2(date.getHours())
|
|
21
|
+
const MM = pad2(date.getMinutes())
|
|
22
|
+
const ss = pad2(date.getSeconds())
|
|
23
|
+
return `${filePath}.${yyyy}-${mm}-${dd}-${HH}-${MM}-${ss}`
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export const rotateFile = async (filePath: string): Promise<string> => {
|
|
27
|
+
try {
|
|
28
|
+
const stat = await fs.stat(filePath)
|
|
29
|
+
if (stat.size === 0) {
|
|
30
|
+
return ''
|
|
31
|
+
}
|
|
32
|
+
} catch {
|
|
33
|
+
return ''
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
const rotated = getRotatedFileName(filePath, new Date())
|
|
37
|
+
await fs.rename(filePath, rotated)
|
|
38
|
+
return rotated
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export const compressFile = async (filePath: string): Promise<void> => {
|
|
42
|
+
const content = await fs.readFile(filePath)
|
|
43
|
+
const compressed = await gzipAsync(content)
|
|
44
|
+
await fs.writeFile(`${filePath}.gz`, compressed)
|
|
45
|
+
await fs.rm(filePath, { force: true })
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
export const shouldRotate = async (
|
|
49
|
+
filePath: string,
|
|
50
|
+
config: LogRotationConfig
|
|
51
|
+
): Promise<boolean> => {
|
|
52
|
+
if (config.maxSize === undefined) {
|
|
53
|
+
return false
|
|
54
|
+
}
|
|
55
|
+
const maxSize = parseSize(config.maxSize)
|
|
56
|
+
return await shouldRotateBySize(filePath, maxSize)
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
const cleanupByCount = async (
|
|
60
|
+
filePath: string,
|
|
61
|
+
maxFiles: number
|
|
62
|
+
): Promise<void> => {
|
|
63
|
+
const rotated = await getRotatedFiles(filePath)
|
|
64
|
+
if (rotated.length <= maxFiles) {
|
|
65
|
+
return
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
const stats = await Promise.all(
|
|
69
|
+
rotated.map(async p => ({ path: p, stat: await fs.stat(p) }))
|
|
70
|
+
)
|
|
71
|
+
|
|
72
|
+
stats.sort((a, b) => b.stat.mtimeMs - a.stat.mtimeMs)
|
|
73
|
+
const toDelete = stats.slice(maxFiles)
|
|
74
|
+
await Promise.all(toDelete.map(({ path }) => fs.rm(path, { force: true })))
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
const cleanupByTime = async (
|
|
78
|
+
filePath: string,
|
|
79
|
+
maxAgeMs: number
|
|
80
|
+
): Promise<void> => {
|
|
81
|
+
const rotated = await getRotatedFiles(filePath)
|
|
82
|
+
if (rotated.length === 0) {
|
|
83
|
+
return
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
const now = Date.now()
|
|
87
|
+
const stats = await Promise.all(
|
|
88
|
+
rotated.map(async p => ({ path: p, stat: await fs.stat(p) }))
|
|
89
|
+
)
|
|
90
|
+
|
|
91
|
+
const toDelete = stats.filter(({ stat }) => now - stat.mtimeMs > maxAgeMs)
|
|
92
|
+
await Promise.all(toDelete.map(({ path }) => fs.rm(path, { force: true })))
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
export const performRotation = async (
|
|
96
|
+
filePath: string,
|
|
97
|
+
config: LogRotationConfig
|
|
98
|
+
): Promise<void> => {
|
|
99
|
+
const rotated = await rotateFile(filePath)
|
|
100
|
+
if (!rotated) {
|
|
101
|
+
return
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
const shouldCompress = config.compress === true
|
|
105
|
+
if (shouldCompress) {
|
|
106
|
+
const algo = config.compression ?? 'gzip'
|
|
107
|
+
if (algo === 'gzip') {
|
|
108
|
+
await compressFile(rotated)
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
if (config.maxFiles !== undefined) {
|
|
113
|
+
const retention = parseRetention(config.maxFiles)
|
|
114
|
+
if (retention.type === 'count') {
|
|
115
|
+
await cleanupByCount(filePath, retention.value)
|
|
116
|
+
} else {
|
|
117
|
+
await cleanupByTime(filePath, retention.value)
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
// Optional interval-based rotation cleanup (create interval directories / naming) is not required by tests.
|
|
122
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export const parseError = (error: unknown): string => {
|
|
2
|
+
let message = 'An error occurred'
|
|
3
|
+
|
|
4
|
+
if (error instanceof Error) {
|
|
5
|
+
message = error.message
|
|
6
|
+
} else if (error && typeof error === 'object' && 'message' in error) {
|
|
7
|
+
message = error.message as string
|
|
8
|
+
} else {
|
|
9
|
+
message = String(error)
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
console.error(`Parsing error: ${message}`)
|
|
13
|
+
|
|
14
|
+
return message
|
|
15
|
+
}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { promises as fs } from 'node:fs'
|
|
2
|
+
import { basename, dirname } from 'node:path'
|
|
3
|
+
|
|
4
|
+
const SIZE_REGEX = /^(\d+(?:\.\d+)?)(k|kb|m|mb|g|gb)$/i
|
|
5
|
+
const INTERVAL_REGEX = /^(\d+)(h|d|w)$/i
|
|
6
|
+
const ROTATED_REGEX = /\.(\d{4}-\d{2}-\d{2}-\d{2}-\d{2}-\d{2})(?:\.gz)?$/
|
|
7
|
+
|
|
8
|
+
export const parseSize = (value: number | string): number => {
|
|
9
|
+
if (typeof value === 'number') {
|
|
10
|
+
return value
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
const trimmed = value.trim()
|
|
14
|
+
const asNumber = Number(trimmed)
|
|
15
|
+
if (Number.isFinite(asNumber)) {
|
|
16
|
+
return asNumber
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
const match = trimmed.match(SIZE_REGEX)
|
|
20
|
+
if (!match) {
|
|
21
|
+
throw new Error(`Invalid size format: ${value}`)
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
const amount = Number(match[1])
|
|
25
|
+
const unit = match[2].toLowerCase()
|
|
26
|
+
|
|
27
|
+
let base = 1024
|
|
28
|
+
if (unit.startsWith('m')) {
|
|
29
|
+
base = 1024 * 1024
|
|
30
|
+
} else if (unit.startsWith('g')) {
|
|
31
|
+
base = 1024 * 1024 * 1024
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
return Math.floor(amount * base)
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
export const parseInterval = (value: string): number => {
|
|
38
|
+
const match = value.trim().match(INTERVAL_REGEX)
|
|
39
|
+
if (!match) {
|
|
40
|
+
throw new Error(`Invalid interval format: ${value}`)
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const amount = Number(match[1])
|
|
44
|
+
const unit = match[2].toLowerCase()
|
|
45
|
+
|
|
46
|
+
let ms = 60 * 60 * 1000
|
|
47
|
+
if (unit === 'd') {
|
|
48
|
+
ms = 24 * 60 * 60 * 1000
|
|
49
|
+
} else if (unit === 'w') {
|
|
50
|
+
ms = 7 * 24 * 60 * 60 * 1000
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
return amount * ms
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
export const parseRetention = (
|
|
57
|
+
value: number | string
|
|
58
|
+
): { type: 'count' | 'time'; value: number } => {
|
|
59
|
+
if (typeof value === 'number') {
|
|
60
|
+
return { type: 'count', value }
|
|
61
|
+
}
|
|
62
|
+
return { type: 'time', value: parseInterval(value) }
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
export const shouldRotateBySize = async (
|
|
66
|
+
filePath: string,
|
|
67
|
+
maxSizeBytes: number
|
|
68
|
+
): Promise<boolean> => {
|
|
69
|
+
try {
|
|
70
|
+
const stat = await fs.stat(filePath)
|
|
71
|
+
return stat.size > maxSizeBytes
|
|
72
|
+
} catch {
|
|
73
|
+
return false
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
export const getRotatedFiles = async (filePath: string): Promise<string[]> => {
|
|
78
|
+
const dir = dirname(filePath)
|
|
79
|
+
const base = basename(filePath)
|
|
80
|
+
|
|
81
|
+
let entries: string[]
|
|
82
|
+
try {
|
|
83
|
+
entries = await fs.readdir(dir)
|
|
84
|
+
} catch {
|
|
85
|
+
return []
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
return entries
|
|
89
|
+
.filter(name => name.startsWith(`${base}.`) && ROTATED_REGEX.test(name))
|
|
90
|
+
.map(name => `${dir}/${name}`)
|
|
91
|
+
}
|
package/LICENSE
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
MIT License
|
|
2
|
-
|
|
3
|
-
Copyright (c) 2023 PunGrumpy
|
|
4
|
-
|
|
5
|
-
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
-
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
-
in the Software without restriction, including without limitation the rights
|
|
8
|
-
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
-
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
-
furnished to do so, subject to the following conditions:
|
|
11
|
-
|
|
12
|
-
The above copyright notice and this permission notice shall be included in all
|
|
13
|
-
copies or substantial portions of the Software.
|
|
14
|
-
|
|
15
|
-
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
-
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
-
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
-
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
-
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
-
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
-
SOFTWARE.
|
package/README.md
DELETED
|
@@ -1,51 +0,0 @@
|
|
|
1
|
-
<div align="center">
|
|
2
|
-
<h1><code>🦊</code> Logixlysia</h1>
|
|
3
|
-
<strong>Logixlysia is a logging library for ElysiaJS</strong>
|
|
4
|
-
<img src="./website/app/opengraph-image.png" alt="Logixlysia" width="100%" height="auto" />
|
|
5
|
-
</div>
|
|
6
|
-
|
|
7
|
-
## `📩` Installation
|
|
8
|
-
|
|
9
|
-
```bash
|
|
10
|
-
bun add logixlysia
|
|
11
|
-
```
|
|
12
|
-
|
|
13
|
-
## `📝` Usage
|
|
14
|
-
|
|
15
|
-
```ts
|
|
16
|
-
import { Elysia } from 'elysia'
|
|
17
|
-
import logixlysia from 'logixlysia'
|
|
18
|
-
|
|
19
|
-
const app = new Elysia({
|
|
20
|
-
name: 'Logixlysia Example'
|
|
21
|
-
}).use(
|
|
22
|
-
logixlysia({
|
|
23
|
-
config: {
|
|
24
|
-
showStartupMessage: true,
|
|
25
|
-
startupMessageFormat: 'simple',
|
|
26
|
-
timestamp: {
|
|
27
|
-
translateTime: 'yyyy-mm-dd HH:MM:ss'
|
|
28
|
-
},
|
|
29
|
-
ip: true,
|
|
30
|
-
logFilePath: './logs/example.log',
|
|
31
|
-
customLogFormat:
|
|
32
|
-
'🦊 {now} {level} {duration} {method} {pathname} {status} {message} {ip} {epoch}',
|
|
33
|
-
logFilter: {
|
|
34
|
-
level: ['ERROR', 'WARNING'],
|
|
35
|
-
status: [500, 404],
|
|
36
|
-
method: 'GET'
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
})
|
|
40
|
-
)
|
|
41
|
-
|
|
42
|
-
app.listen(3000)
|
|
43
|
-
```
|
|
44
|
-
|
|
45
|
-
## `📚` Documentation
|
|
46
|
-
|
|
47
|
-
Check out the [website](https://logixlysia.vercel.app) for more detailed documentation and examples.
|
|
48
|
-
|
|
49
|
-
## `📄` License
|
|
50
|
-
|
|
51
|
-
Licensed under the [MIT License](LICENSE).
|
package/dist/index.cjs
DELETED
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
var Z=require("node:module");var J=Object.create;var{getPrototypeOf:j,defineProperty:h,getOwnPropertyNames:q,getOwnPropertyDescriptor:K}=Object,B=Object.prototype.hasOwnProperty;var x=(r,o,t)=>{t=r!=null?J(j(r)):{};let e=o||!r||!r.__esModule?h(t,"default",{value:r,enumerable:!0}):t;for(let n of q(r))if(!B.call(e,n))h(e,n,{get:()=>r[n],enumerable:!0});return e},N=new WeakMap,Q=(r)=>{var o=N.get(r),t;if(o)return o;if(o=h({},"__esModule",{value:!0}),r&&typeof r==="object"||typeof r==="function")q(r).map((e)=>!B.call(o,e)&&h(o,e,{get:()=>r[e],enumerable:!(t=K(r,e))||t.enumerable}));return N.set(r,o),o};var X=(r,o)=>{for(var t in o)h(r,t,{get:o[t],enumerable:!0,configurable:!0,set:(e)=>o[t]=()=>e})};var ar={};X(ar,{logToTransports:()=>p,handleHttpError:()=>d,default:()=>z,createLogger:()=>b});module.exports=Q(ar);var Y=require("elysia");var C=(r,o)=>{let t=Math.max(0,(o-r.length)/2),e=" ".repeat(t);return`${e}${r}${e}`.padEnd(o)};function y(r,o){let t=r?.hostname??"localhost",e=r?.port??3000,n=r?.protocol??"http";if(o?.config?.startupMessageFormat!=="simple"){let i=`\uD83E\uDD8A Elysia is running at ${n}://${t}:${e}`,m=Math.max(22,i.length)+4,T="─".repeat(m),f=C("",m);console.log(`
|
|
2
|
-
┌${T}┐
|
|
3
|
-
│${f}│
|
|
4
|
-
│${C("Elysia with Logixlysia",m)}│
|
|
5
|
-
│${f}│
|
|
6
|
-
│${C(i,m)}│
|
|
7
|
-
│${f}│
|
|
8
|
-
└${T}┘
|
|
9
|
-
`)}else console.log(`\uD83E\uDD8A Elysia is running at ${n}://${t}:${e}`)}var u=x(require("chalk")),G=require("elysia");function F(r){if(typeof r==="number")return r;return G.StatusMap[r]||500}function O(r,o){let t=r.toString();if(!o)return t;if(r>=500)return u.default.red(t);if(r>=400)return u.default.yellow(t);if(r>=300)return u.default.cyan(t);if(r>=200)return u.default.green(t);return u.default.white(t)}var I=x(require("chalk"));var g=x(require("chalk")),M={INFO:g.default.bgGreen.black,WARNING:g.default.bgYellow.black,ERROR:g.default.bgRed.black},P={GET:g.default.green,POST:g.default.yellow,PUT:g.default.blue,PATCH:g.default.magentaBright,DELETE:g.default.red,HEAD:g.default.cyan,OPTIONS:g.default.magenta};var $=x(require("chalk")),V=[{unit:"s",threshold:1e9,decimalPlaces:2},{unit:"ms",threshold:1e6,decimalPlaces:0},{unit:"µs",threshold:1000,decimalPlaces:0},{unit:"ns",threshold:1,decimalPlaces:0}];function E(r,o){let t=Number(process.hrtime.bigint()-r);for(let{unit:e,threshold:n,decimalPlaces:s}of V)if(t>=n){let i=`${(t/n).toFixed(s)}${e}`.padStart(8).padEnd(16);return o?$.default.gray(i):i}return o?$.default.gray("0ns".padStart(8).padEnd(16)):"0ns".padStart(8).padEnd(16)}function R(r,o){let t=r.toUpperCase();return o?M[t]?.(t.padEnd(7))||t:t.padEnd(7)}function v(r,o){let t=P[r];return o&&t?t(r.padEnd(7)):r.padEnd(7)}function w(r){try{return new URL(r.url).pathname}catch{return}}var l=(r)=>r.toString().padStart(2,"0");function rr(r){let o=r.getFullYear(),t=l(r.getMonth()+1),e=l(r.getDate()),n=l(r.getHours()),s=l(r.getMinutes()),a=l(r.getSeconds()),i=r.getMilliseconds().toString().padStart(3,"0");return`${o}-${t}-${e} ${n}:${s}:${a}.${i}`}function tr(r,o){let t={yyyy:r.getFullYear(),yy:r.getFullYear().toString().slice(-2),mm:l(r.getMonth()+1),dd:l(r.getDate()),HH:l(r.getHours()),MM:l(r.getMinutes()),ss:l(r.getSeconds()),SSS:l(r.getMilliseconds()),Z:-r.getTimezoneOffset()/60};return o.replace(/yyyy|yy|mm|dd|HH|MM|ss|SSS|Z/g,(e)=>(t[e]??"").toString())}function D(r,o){if(!o?.translateTime)return r.toISOString();if(o.translateTime===!0||o.translateTime==="SYS:STANDARD")return rr(r);return tr(r,o.translateTime)}var or="\uD83E\uDD8A {now} {level} {duration} {method} {pathname} {status} {message} {context} {ip}";function er(r,o){if(o?.config?.useColors!==void 0)return o.config.useColors&&process.env.NO_COLOR===void 0;return r&&process.env.NO_COLOR===void 0}function c(r,o,t,e,n,s=!0){let a=er(s,n),i=new Date,m={now:a?I.default.bgYellow(I.default.black(D(i,n?.config?.timestamp))):D(i,n?.config?.timestamp),epoch:Math.floor(i.getTime()/1000).toString(),level:R(r,s),duration:E(e.beforeTime,s),method:v(o.method,s),pathname:w(o),status:O(t.status||200,s),message:t.message||"",context:t.context?(()=>{try{return JSON.stringify(t.context)}catch(f){return`[Error serializing context: ${f instanceof Error?f.message:"Unknown error"}]`}})():"",ip:n?.config?.ip&&o.headers.get("x-forwarded-for")?`IP: ${o.headers.get("x-forwarded-for")}`:""};return(n?.config?.customLogFormat||or).replace(/{(\w+)}/g,(f,U)=>{if(U in m)return m[U]||"";return""})}async function p(r,o,t,e,n){if(!n?.config?.transports||n.config.transports.length===0)return;let s=c(r,o,t,e,n,!1),a=n.config.transports.map((i)=>i.log(r,s,{request:o,data:t,store:e}));await Promise.all(a)}var k=require("node:fs"),W=require("node:path");var A=new Set;async function nr(r){let o=W.dirname(r);if(!A.has(o))await k.promises.mkdir(o,{recursive:!0}),A.add(o)}async function L(r,o,t,e,n,s){await nr(r);let a=`${c(o,t,e,n,s,!1)}
|
|
10
|
-
`;await k.promises.appendFile(r,a,{flag:"a"})}var H=(r,o)=>Array.isArray(r)?r.includes(o):r===o;function _(r,o,t,e){let n=e?.config?.logFilter;if(!n)return!0;return(!n.level||H(n.level,r))&&(!n.status||H(n.status,o))&&(!n.method||H(n.method,t))}async function d(r,o,t,e){let s={status:o.status||500,message:o.message,stack:o.stack},a=[];if(!(e?.config?.useTransportsOnly||e?.config?.disableInternalLogger))console.error(c("ERROR",r,s,t,e));if(!e?.config?.useTransportsOnly&&e?.config?.logFilePath&&!e?.config?.disableFileLogging)a.push(L(e.config.logFilePath,"ERROR",r,s,t,e));if(e?.config?.transports?.length)a.push(p("ERROR",r,s,t,e));await Promise.all(a)}function sr(){let r=process.memoryUsage().heapUsed/1024/1024,o=process.cpuUsage();return{memoryUsage:r,cpuUsage:o.user/1e6}}async function S(r,o,t,e,n){if(!_(r,t.status||200,o.method,n))return;if(!t.metrics)t.metrics=sr();if(r==="ERROR"&&!t.stack)t.stack=Error(`Error: ${t.message||"Unknown error"}`).stack;let s=c(r,o,t,e,n,!0),a=[];if(!(n?.config?.useTransportsOnly||n?.config?.disableInternalLogger))console.log(s);if(!n?.config?.useTransportsOnly&&n?.config?.logFilePath&&!n?.config?.disableFileLogging)a.push(L(n.config.logFilePath,r,o,t,e,n));if(n?.config?.transports?.length)a.push(p(r,o,t,e,n));await Promise.all(a)}function b(r){let o={store:void 0,log:(t,e,n,s)=>S(t,e,n,s,r),handleHttpError:async(t,e,n)=>await d(t,e,n,r),customLogFormat:r?.config?.customLogFormat,info:(t,e,n,s)=>{let a=s||o.store||{beforeTime:process.hrtime.bigint()};return a.hasCustomLog=!0,S("INFO",t,{message:e,context:n,status:200},a,r)},error:(t,e,n,s)=>{let a=s||o.store||{beforeTime:process.hrtime.bigint()};return a.hasCustomLog=!0,S("ERROR",t,{message:e,context:n,status:500},a,r)},warn:(t,e,n,s)=>{let a=s||o.store||{beforeTime:process.hrtime.bigint()};return a.hasCustomLog=!0,S("WARNING",t,{message:e,context:n,status:200},a,r)},debug:(t,e,n,s)=>{let a=s||o.store||{beforeTime:process.hrtime.bigint()};return a.hasCustomLog=!0,S("DEBUG",t,{message:e,context:n,status:200},a,r)}};return o}function z(r){let o=b(r);return new Y.Elysia({name:"Logixlysia"}).onStart((t)=>{if(r?.config?.showStartupMessage??!0)y(t.server,r)}).onRequest((t)=>{let e={...t.store,beforeTime:process.hrtime.bigint(),logger:o,hasCustomLog:!1};t.store=e,o.store=e}).onAfterHandle({as:"global"},({request:t,set:e,store:n})=>{let s=n;if(!s.hasCustomLog){let a=F(e.status||200);o.log("INFO",t,{status:a,message:String(e.headers?.["x-message"]||"")},s)}}).onError({as:"global"},async({request:t,error:e,set:n,store:s})=>{let a=F(n.status||500);await o.handleHttpError(t,{...e,status:a},s)})}
|
|
11
|
-
|
|
12
|
-
//# debugId=31613BB08018F53664756E2164756E21
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/index.ts", "../src/extensions/start-server.ts", "../src/helpers/status.ts", "../src/logger/build-log-message.ts", "../src/helpers/color-mapping.ts", "../src/helpers/duration.ts", "../src/helpers/log.ts", "../src/helpers/method.ts", "../src/helpers/path.ts", "../src/helpers/timestamp.ts", "../src/output/console.ts", "../src/output/file.ts", "../src/logger/filter.ts", "../src/logger/handle-http-error.ts", "../src/logger/create-logger.ts"],
  "sourcesContent": [
    "import { Elysia } from 'elysia'\n\nimport { startServer } from './extensions'\nimport { getStatusCode } from './helpers/status'\nimport type { HttpError, Options, Server, StoreData } from './interfaces'\nimport { createLogger } from './logger'\n\nexport default function logixlysia(options?: Options): Elysia {\n  const log = createLogger(options)\n\n  return new Elysia({\n    name: 'Logixlysia'\n  })\n    .onStart(ctx => {\n      const showStartupMessage = options?.config?.showStartupMessage ?? true\n      if (showStartupMessage) {\n        startServer(ctx.server as Server, options)\n      }\n    })\n    .onRequest(ctx => {\n      const store = {\n        ...ctx.store,\n        beforeTime: process.hrtime.bigint(),\n        logger: log,\n        hasCustomLog: false\n      }\n      ctx.store = store\n      log.store = store\n    })\n    .onAfterHandle({ as: 'global' }, ({ request, set, store }) => {\n      const storeData = store as StoreData\n\n      if (!storeData.hasCustomLog) {\n        const status = getStatusCode(set.status || 200)\n        log.log(\n          'INFO',\n          request,\n          {\n            status,\n            message: String(set.headers?.['x-message'] || '')\n          },\n          storeData\n        )\n      }\n    })\n    .onError({ as: 'global' }, async ({ request, error, set, store }) => {\n      const status = getStatusCode(set.status || 500)\n      await log.handleHttpError(\n        request,\n        { ...error, status } as HttpError,\n        store as StoreData\n      )\n    })\n}\n\nexport type {\n  HttpError,\n  LogData,\n  Logger,\n  LogixlysiaContext,\n  LogLevel,\n  Options,\n  RequestInfo,\n  StoreData,\n  Transport\n} from './interfaces'\nexport { createLogger, handleHttpError } from './logger'\nexport { logToTransports } from './output'\n",
    "import type { Options, Server } from '../interfaces'\n\nconst createBoxText = (text: string, width: number): string => {\n  const paddingLength = Math.max(0, (width - text.length) / 2)\n  const padding = ' '.repeat(paddingLength)\n  return `${padding}${text}${padding}`.padEnd(width)\n}\n\nexport default function startServer(config: Server, options?: Options): void {\n  const hostname = config?.hostname ?? 'localhost'\n  const port = config?.port ?? 3000\n  const protocol = config?.protocol ?? 'http'\n  const showBanner = options?.config?.startupMessageFormat !== 'simple'\n\n  if (showBanner) {\n    const title = 'Elysia with Logixlysia'\n    const message = `🦊 Elysia is running at ${protocol}://${hostname}:${port}`\n    const boxWidth = Math.max(title.length, message.length) + 4\n    const border = '─'.repeat(boxWidth)\n    const emptyLine = createBoxText('', boxWidth)\n\n    console.log(`\n      ┌${border}┐\n      │${emptyLine}│\n      │${createBoxText(title, boxWidth)}│\n      │${emptyLine}│\n      │${createBoxText(message, boxWidth)}│\n      │${emptyLine}│\n      └${border}┘\n    `)\n  } else {\n    console.log(`🦊 Elysia is running at ${protocol}://${hostname}:${port}`)\n  }\n}\n",
    "import chalk from 'chalk'\nimport { StatusMap } from 'elysia'\n\nexport function getStatusCode(status: string | number): number {\n  if (typeof status === 'number') {\n    return status\n  }\n  return (StatusMap as Record<string, number>)[status] || 500\n}\n\nexport default function statusString(\n  status: number,\n  useColors: boolean\n): string {\n  const statusStr = status.toString()\n  if (!useColors) {\n    return statusStr\n  }\n\n  if (status >= 500) {\n    return chalk.red(statusStr)\n  }\n  if (status >= 400) {\n    return chalk.yellow(statusStr)\n  }\n  if (status >= 300) {\n    return chalk.cyan(statusStr)\n  }\n  if (status >= 200) {\n    return chalk.green(statusStr)\n  }\n  return chalk.white(statusStr)\n}\n",
    "import chalk from 'chalk'\n\nimport {\n  durationString,\n  formatTimestamp,\n  logString,\n  methodString,\n  pathString,\n  statusString\n} from '../helpers'\nimport type {\n  LogComponents,\n  LogData,\n  LogLevel,\n  Options,\n  RequestInfo,\n  StoreData\n} from '../interfaces'\n\nconst defaultLogFormat =\n  '🦊 {now} {level} {duration} {method} {pathname} {status} {message} {context} {ip}'\n\nfunction shouldUseColors(useColors: boolean, options?: Options): boolean {\n  if (options?.config?.useColors !== undefined) {\n    return options.config.useColors && process.env.NO_COLOR === undefined\n  }\n  return useColors && process.env.NO_COLOR === undefined\n}\n\nexport function buildLogMessage(\n  level: LogLevel,\n  request: RequestInfo,\n  data: LogData,\n  store: StoreData,\n  options?: Options,\n  useColors = true\n): string {\n  const actuallyUseColors = shouldUseColors(useColors, options)\n  const now = new Date()\n  const components: LogComponents = {\n    now: actuallyUseColors\n      ? chalk.bgYellow(\n          chalk.black(formatTimestamp(now, options?.config?.timestamp))\n        )\n      : formatTimestamp(now, options?.config?.timestamp),\n    epoch: Math.floor(now.getTime() / 1000).toString(),\n    level: logString(level, useColors),\n    duration: durationString(store.beforeTime, useColors),\n    method: methodString(request.method, useColors),\n    pathname: pathString(request),\n    status: statusString(data.status || 200, useColors),\n    message: data.message || '',\n    context: data.context\n      ? (() => {\n          try {\n            return JSON.stringify(data.context)\n          } catch (error) {\n            return `[Error serializing context: ${error instanceof Error ? error.message : 'Unknown error'}]`\n          }\n        })()\n      : '',\n    ip:\n      options?.config?.ip && request.headers.get('x-forwarded-for')\n        ? `IP: ${request.headers.get('x-forwarded-for')}`\n        : ''\n  }\n\n  const logFormat = options?.config?.customLogFormat || defaultLogFormat\n\n  return logFormat.replace(/{(\\w+)}/g, (_, key: string) => {\n    if (key in components) {\n      return components[key as keyof LogComponents] || ''\n    }\n    return ''\n  })\n}\n",
    "import chalk from 'chalk'\n\nimport type { ColorMap } from '../interfaces'\n\nexport const LogLevelColorMap: ColorMap = {\n  INFO: chalk.bgGreen.black,\n  WARNING: chalk.bgYellow.black,\n  ERROR: chalk.bgRed.black\n}\n\nexport const HttpMethodColorMap: ColorMap = {\n  GET: chalk.green,\n  POST: chalk.yellow,\n  PUT: chalk.blue,\n  PATCH: chalk.magentaBright,\n  DELETE: chalk.red,\n  HEAD: chalk.cyan,\n  OPTIONS: chalk.magenta\n}\n",
    "import chalk from 'chalk'\n\nconst timeUnits = [\n  { unit: 's', threshold: 1e9, decimalPlaces: 2 },\n  { unit: 'ms', threshold: 1e6, decimalPlaces: 0 },\n  { unit: 'µs', threshold: 1e3, decimalPlaces: 0 },\n  { unit: 'ns', threshold: 1, decimalPlaces: 0 }\n]\n\nexport default function durationString(\n  beforeTime: bigint,\n  useColors: boolean\n): string {\n  const nanoseconds = Number(process.hrtime.bigint() - beforeTime)\n\n  for (const { unit, threshold, decimalPlaces } of timeUnits) {\n    if (nanoseconds >= threshold) {\n      const value = (nanoseconds / threshold).toFixed(decimalPlaces)\n      const timeStr = `${value}${unit}`.padStart(8).padEnd(16)\n      return useColors ? chalk.gray(timeStr) : timeStr\n    }\n  }\n\n  return useColors\n    ? chalk.gray('0ns'.padStart(8).padEnd(16))\n    : '0ns'.padStart(8).padEnd(16)\n}\n",
    "import type { LogLevel } from '../interfaces'\nimport { LogLevelColorMap } from './color-mapping'\n\nexport default function logString(level: LogLevel, useColors: boolean): string {\n  const levelStr = level.toUpperCase()\n  return useColors\n    ? LogLevelColorMap[levelStr]?.(levelStr.padEnd(7)) || levelStr\n    : levelStr.padEnd(7)\n}\n",
    "import { HttpMethodColorMap } from './color-mapping'\n\nexport default function methodString(\n  method: string,\n  useColors: boolean\n): string {\n  const colorFunction = HttpMethodColorMap[method]\n  return useColors && colorFunction\n    ? colorFunction(method.padEnd(7))\n    : method.padEnd(7)\n}\n",
    "import type { RequestInfo } from '../interfaces'\n\nexport default function pathString(\n  requestInfo: RequestInfo\n): string | undefined {\n  try {\n    return new URL(requestInfo.url).pathname\n  } catch {\n    return\n  }\n}\n",
    "import type { TimestampConfig } from '../interfaces'\n\n// const DEFAULT_TIMESTAMP_FORMAT = 'yyyy-mm-dd HH:MM:ss'\nconst SYS_TIME = 'SYS:STANDARD'\n\nconst pad = (n: number): string => n.toString().padStart(2, '0')\n\nfunction formatSystemTime(date: Date): string {\n  const year = date.getFullYear()\n  const month = pad(date.getMonth() + 1)\n  const day = pad(date.getDate())\n  const hours = pad(date.getHours())\n  const minutes = pad(date.getMinutes())\n  const seconds = pad(date.getSeconds())\n  const ms = date.getMilliseconds().toString().padStart(3, '0')\n\n  return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}.${ms}`\n}\n\nfunction formatCustomTime(date: Date, format: string): string {\n  const tokens: { [key: string]: string | number } = {\n    yyyy: date.getFullYear(),\n    yy: date.getFullYear().toString().slice(-2),\n    mm: pad(date.getMonth() + 1),\n    dd: pad(date.getDate()),\n    HH: pad(date.getHours()),\n    MM: pad(date.getMinutes()),\n    ss: pad(date.getSeconds()),\n    SSS: pad(date.getMilliseconds()),\n    Z: -date.getTimezoneOffset() / 60\n  }\n\n  return format.replace(/yyyy|yy|mm|dd|HH|MM|ss|SSS|Z/g, match =>\n    (tokens[match] ?? '').toString()\n  )\n}\n\nexport function formatTimestamp(date: Date, config?: TimestampConfig): string {\n  if (!config?.translateTime) {\n    return date.toISOString()\n  }\n\n  if (config.translateTime === true || config.translateTime === SYS_TIME) {\n    return formatSystemTime(date)\n  }\n\n  return formatCustomTime(date, config.translateTime)\n}\n",
    "import type {\n  LogData,\n  LogLevel,\n  Options,\n  RequestInfo,\n  StoreData\n} from '../interfaces'\nimport { buildLogMessage } from '../logger/build-log-message'\n\nexport async function logToTransports(\n  level: LogLevel,\n  request: RequestInfo,\n  data: LogData,\n  store: StoreData,\n  options?: Options\n): Promise<void> {\n  if (!options?.config?.transports || options.config.transports.length === 0) {\n    return\n  }\n\n  const message = buildLogMessage(level, request, data, store, options, false)\n\n  const promises = options.config.transports.map(transport =>\n    transport.log(level, message, { request, data, store })\n  )\n\n  await Promise.all(promises)\n}\n",
    "import { promises as fs } from 'node:fs'\nimport { dirname } from 'node:path'\n\nimport type {\n  LogData,\n  LogLevel,\n  Options,\n  RequestInfo,\n  StoreData\n} from '../interfaces'\nimport { buildLogMessage } from '../logger/build-log-message'\n\nconst dirCache = new Set<string>()\n\nasync function ensureDirectoryExists(filePath: string): Promise<void> {\n  const dir = dirname(filePath)\n  if (!dirCache.has(dir)) {\n    await fs.mkdir(dir, { recursive: true })\n    dirCache.add(dir)\n  }\n}\n\nexport async function logToFile(\n  filePath: string,\n  level: LogLevel,\n  request: RequestInfo,\n  data: LogData,\n  store: StoreData,\n  options?: Options\n): Promise<void> {\n  await ensureDirectoryExists(filePath)\n  const logMessage = `${buildLogMessage(level, request, data, store, options, false)}\\n`\n  await fs.appendFile(filePath, logMessage, { flag: 'a' })\n}\n",
    "import type { LogLevel, Options } from '../interfaces'\n\nconst checkFilter = (filterValue: unknown, value: unknown) =>\n  Array.isArray(filterValue)\n    ? filterValue.includes(value)\n    : filterValue === value\n\nexport function filterLog(\n  logLevel: LogLevel,\n  status: number,\n  method: string,\n  options?: Options\n): boolean {\n  const filter = options?.config?.logFilter\n  if (!filter) {\n    return true\n  }\n\n  return (\n    (!filter.level || checkFilter(filter.level, logLevel)) &&\n    (!filter.status || checkFilter(filter.status, status)) &&\n    (!filter.method || checkFilter(filter.method, method))\n  )\n}\n",
    "import type { HttpError, Options, RequestInfo, StoreData } from '../interfaces'\nimport { logToFile, logToTransports } from '../output'\nimport { buildLogMessage } from './build-log-message'\n\nexport async function handleHttpError(\n  request: RequestInfo,\n  error: HttpError,\n  store: StoreData,\n  options?: Options\n): Promise<void> {\n  const statusCode = error.status || 500\n  const logData = {\n    status: statusCode,\n    message: error.message,\n    stack: error.stack\n  }\n\n  const promises: Promise<void>[] = []\n\n  // Handle console logging\n  if (\n    !(\n      options?.config?.useTransportsOnly ||\n      options?.config?.disableInternalLogger\n    )\n  ) {\n    console.error(buildLogMessage('ERROR', request, logData, store, options))\n  }\n\n  // Handle file logging\n  if (\n    !options?.config?.useTransportsOnly &&\n    options?.config?.logFilePath &&\n    !options?.config?.disableFileLogging\n  ) {\n    promises.push(\n      logToFile(\n        options.config.logFilePath,\n        'ERROR',\n        request,\n        logData,\n        store,\n        options\n      )\n    )\n  }\n\n  // Handle transport logging\n  if (options?.config?.transports?.length) {\n    promises.push(logToTransports('ERROR', request, logData, store, options))\n  }\n\n  await Promise.all(promises)\n}\n",
    "import type {\n  LogData,\n  Logger,\n  LogLevel,\n  Options,\n  RequestInfo,\n  StoreData\n} from '../interfaces'\nimport { logToFile, logToTransports } from '../output'\nimport { buildLogMessage } from './build-log-message'\nimport { filterLog } from './filter'\nimport { handleHttpError } from './handle-http-error'\n\nfunction getMetrics(): LogData['metrics'] {\n  const memoryUsage = process.memoryUsage().heapUsed / 1024 / 1024 // MB\n  const cpuUsage = process.cpuUsage()\n\n  return {\n    memoryUsage,\n    cpuUsage: cpuUsage.user / 1_000_000 // convert to seconds\n  }\n}\n\nasync function log(\n  level: LogLevel,\n  request: RequestInfo,\n  data: LogData,\n  store: StoreData,\n  options?: Options\n): Promise<void> {\n  if (!filterLog(level, data.status || 200, request.method, options)) {\n    return\n  }\n\n  // Add metrics if not provided\n  if (!data.metrics) {\n    data.metrics = getMetrics()\n  }\n\n  // Add stack trace for errors\n  if (level === 'ERROR' && !data.stack) {\n    data.stack = new Error(`Error: ${data.message || 'Unknown error'}`).stack\n  }\n\n  const logMessage = buildLogMessage(level, request, data, store, options, true)\n\n  const promises: Promise<void>[] = []\n\n  // Handle console logging\n  if (\n    !(\n      options?.config?.useTransportsOnly ||\n      options?.config?.disableInternalLogger\n    )\n  ) {\n    console.log(logMessage)\n  }\n\n  // Handle file logging\n  if (\n    !options?.config?.useTransportsOnly &&\n    options?.config?.logFilePath &&\n    !options?.config?.disableFileLogging\n  ) {\n    promises.push(\n      logToFile(\n        options.config.logFilePath,\n        level,\n        request,\n        data,\n        store,\n        options\n      )\n    )\n  }\n\n  // Handle transport logging\n  if (options?.config?.transports?.length) {\n    promises.push(logToTransports(level, request, data, store, options))\n  }\n\n  await Promise.all(promises)\n}\n\nexport function createLogger(options?: Options): Logger {\n  const logger: Logger = {\n    store: undefined,\n    log: (level, request, data, store) =>\n      log(level, request, data, store, options),\n    handleHttpError: async (request, error, store) =>\n      await handleHttpError(request, error, store, options),\n    customLogFormat: options?.config?.customLogFormat,\n    info: (request, message, context, store) => {\n      const storeData = store ||\n        logger.store || { beforeTime: process.hrtime.bigint() }\n      storeData.hasCustomLog = true\n      return log(\n        'INFO',\n        request,\n        { message, context, status: 200 },\n        storeData,\n        options\n      )\n    },\n    error: (request, message, context, store) => {\n      const storeData = store ||\n        logger.store || { beforeTime: process.hrtime.bigint() }\n      storeData.hasCustomLog = true\n      return log(\n        'ERROR',\n        request,\n        { message, context, status: 500 },\n        storeData,\n        options\n      )\n    },\n    warn: (request, message, context, store) => {\n      const storeData = store ||\n        logger.store || { beforeTime: process.hrtime.bigint() }\n      storeData.hasCustomLog = true\n      return log(\n        'WARNING',\n        request,\n        { message, context, status: 200 },\n        storeData,\n        options\n      )\n    },\n    debug: (request, message, context, store) => {\n      const storeData = store ||\n        logger.store || { beforeTime: process.hrtime.bigint() }\n      storeData.hasCustomLog = true\n      return log(\n        'DEBUG',\n        request,\n        { message, context, status: 200 },\n        storeData,\n        options\n      )\n    }\n  }\n  return logger\n}\n"
  ],
  "mappings": "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",
  "debugId": "31613BB08018F53664756E2164756E21",
  "names": []
}
|
package/dist/index.d.cts
DELETED
|
@@ -1,88 +0,0 @@
|
|
|
1
|
-
import { Elysia } from "elysia";
|
|
2
|
-
interface RequestInfo {
|
|
3
|
-
headers: {
|
|
4
|
-
get: (key: string) => string | null
|
|
5
|
-
};
|
|
6
|
-
method: string;
|
|
7
|
-
url: string;
|
|
8
|
-
}
|
|
9
|
-
type LogLevel = "DEBUG" | "INFO" | "WARNING" | "ERROR" | string;
|
|
10
|
-
interface LogData {
|
|
11
|
-
status?: number;
|
|
12
|
-
message?: string;
|
|
13
|
-
context?: Record<string, string | number | boolean | null>;
|
|
14
|
-
stack?: string;
|
|
15
|
-
metrics?: {
|
|
16
|
-
memoryUsage?: number
|
|
17
|
-
cpuUsage?: number
|
|
18
|
-
responseSize?: number
|
|
19
|
-
};
|
|
20
|
-
}
|
|
21
|
-
interface Logger {
|
|
22
|
-
store?: StoreData;
|
|
23
|
-
log(level: LogLevel, request: RequestInfo, data: LogData, store: StoreData): void;
|
|
24
|
-
handleHttpError(request: RequestInfo, error: HttpError, store: StoreData): Promise<void>;
|
|
25
|
-
customLogFormat?: string;
|
|
26
|
-
info(request: RequestInfo, message: string, context?: Record<string, string | number | boolean | null>, store?: StoreData): void;
|
|
27
|
-
error(request: RequestInfo, message: string, context?: Record<string, string | number | boolean | null>, store?: StoreData): void;
|
|
28
|
-
warn(request: RequestInfo, message: string, context?: Record<string, string | number | boolean | null>, store?: StoreData): void;
|
|
29
|
-
debug(request: RequestInfo, message: string, context?: Record<string, string | number | boolean | null>, store?: StoreData): void;
|
|
30
|
-
}
|
|
31
|
-
interface StoreData {
|
|
32
|
-
beforeTime: bigint;
|
|
33
|
-
logger?: Logger;
|
|
34
|
-
hasCustomLog?: boolean;
|
|
35
|
-
}
|
|
36
|
-
interface LogixlysiaContext {
|
|
37
|
-
store: {
|
|
38
|
-
logger: Logger
|
|
39
|
-
beforeTime: bigint
|
|
40
|
-
hasCustomLog: boolean
|
|
41
|
-
};
|
|
42
|
-
request: RequestInfo;
|
|
43
|
-
}
|
|
44
|
-
declare class HttpError extends Error {
|
|
45
|
-
status: number;
|
|
46
|
-
constructor(status: number, message: string);
|
|
47
|
-
}
|
|
48
|
-
type TransportFunction = (level: LogLevel, message: string, meta: {
|
|
49
|
-
request: RequestInfo
|
|
50
|
-
data: LogData
|
|
51
|
-
store: StoreData
|
|
52
|
-
}) => Promise<void> | void;
|
|
53
|
-
interface Transport {
|
|
54
|
-
log: TransportFunction;
|
|
55
|
-
}
|
|
56
|
-
interface TimestampConfig {
|
|
57
|
-
translateTime?: boolean | string;
|
|
58
|
-
}
|
|
59
|
-
interface Options {
|
|
60
|
-
config?: {
|
|
61
|
-
customLogFormat?: string
|
|
62
|
-
logFilePath?: string
|
|
63
|
-
logRotation?: {
|
|
64
|
-
maxSize?: number
|
|
65
|
-
maxFiles?: number
|
|
66
|
-
compress?: boolean
|
|
67
|
-
}
|
|
68
|
-
logFilter?: {
|
|
69
|
-
level?: LogLevel | LogLevel[]
|
|
70
|
-
method?: string | string[]
|
|
71
|
-
status?: number | number[]
|
|
72
|
-
} | null
|
|
73
|
-
ip?: boolean
|
|
74
|
-
useColors?: boolean
|
|
75
|
-
showStartupMessage?: boolean
|
|
76
|
-
startupMessageFormat?: "banner" | "simple"
|
|
77
|
-
transports?: Transport[]
|
|
78
|
-
timestamp?: TimestampConfig
|
|
79
|
-
disableInternalLogger?: boolean
|
|
80
|
-
disableFileLogging?: boolean
|
|
81
|
-
useTransportsOnly?: boolean
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
declare function createLogger(options?: Options): Logger;
|
|
85
|
-
declare function handleHttpError2(request: RequestInfo, error: HttpError, store: StoreData, options?: Options): Promise<void>;
|
|
86
|
-
declare function logToTransports(level: LogLevel, request: RequestInfo, data: LogData, store: StoreData, options?: Options): Promise<void>;
|
|
87
|
-
declare function logixlysia(options?: Options): Elysia;
|
|
88
|
-
export { logToTransports, handleHttpError2 as handleHttpError, logixlysia as default, createLogger, Transport, StoreData, RequestInfo, Options, LogixlysiaContext, Logger, LogLevel, LogData, HttpError };
|