logixlysia 5.1.1 → 5.2.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.cjs CHANGED
@@ -1,13 +1,13 @@
1
- var Z=require("node:module");var J=Object.create;var{getPrototypeOf:j,defineProperty:u,getOwnPropertyNames:q,getOwnPropertyDescriptor:K}=Object,B=Object.prototype.hasOwnProperty;var b=(t,r,o)=>{o=t!=null?J(j(t)):{};let e=r||!t||!t.__esModule?u(o,"default",{value:t,enumerable:!0}):o;for(let n of q(t))if(!B.call(e,n))u(e,n,{get:()=>t[n],enumerable:!0});return e},N=new WeakMap,Q=(t)=>{var r=N.get(t),o;if(r)return r;if(r=u({},"__esModule",{value:!0}),t&&typeof t==="object"||typeof t==="function")q(t).map((e)=>!B.call(r,e)&&u(r,e,{get:()=>t[e],enumerable:!(o=K(t,e))||o.enumerable}));return N.set(t,r),r};var X=(t,r)=>{for(var o in r)u(t,o,{get:r[o],enumerable:!0,configurable:!0,set:(e)=>r[o]=()=>e})};var it={};X(it,{logToTransports:()=>h,handleHttpError:()=>d,default:()=>z,createLogger:()=>x});module.exports=Q(it);var Y=require("elysia");var M=(t,r)=>{let o=Math.max(0,(r-t.length)/2),e=" ".repeat(o);return`${e}${t}${e}`.padEnd(r)};function E(t,r){let o=t?.hostname??"localhost",e=t?.port??3000,n=t?.protocol??"http";if(r?.config?.startupMessageFormat!=="simple"){let a=`\uD83E\uDD8A Elysia is running at ${n}://${o}:${e}`,c=Math.max(22,a.length)+4,C="─".repeat(c),p=M("",c);console.log(`
2
- ┌${C}┐
3
- │${p}│
4
- │${M("Elysia with Logixlysia",c)}│
5
- │${p}│
6
- │${M(a,c)}│
7
- │${p}│
8
- └${C}┘
9
- `)}else console.log(`\uD83E\uDD8A Elysia is running at ${n}://${o}:${e}`)}var f=b(require("chalk")),G=require("elysia");function T(t){if(typeof t==="number")return t;return G.StatusMap[t]||500}function v(t,r){let o=t.toString();if(!r)return o;if(t>=500)return f.default.red(o);if(t>=400)return f.default.yellow(o);if(t>=300)return f.default.cyan(o);if(t>=200)return f.default.green(o);return f.default.white(o)}var I=b(require("chalk"));var g=b(require("chalk")),$={INFO:g.default.bgGreen.black,WARNING:g.default.bgYellow.black,ERROR:g.default.bgRed.black},F={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 P=b(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 O(t,r){let o=Number(process.hrtime.bigint()-t);for(let{unit:e,threshold:n,decimalPlaces:s}of V)if(o>=n){let a=`${(o/n).toFixed(s)}${e}`.padStart(8).padEnd(16);return r?P.default.gray(a):a}return r?P.default.gray("0ns".padStart(8).padEnd(16)):"0ns".padStart(8).padEnd(16)}function y(t,r){let o=t.toUpperCase();return r?$[o]?.(o.padEnd(7))||o:o.padEnd(7)}function R(t,r){let o=F[t];return r&&o?o(t.padEnd(7)):t.padEnd(7)}function D(t){try{return new URL(t.url).pathname}catch{return}}var l=(t)=>t.toString().padStart(2,"0");function tt(t){let r=t.getFullYear(),o=l(t.getMonth()+1),e=l(t.getDate()),n=l(t.getHours()),s=l(t.getMinutes()),i=l(t.getSeconds()),a=t.getMilliseconds().toString().padStart(3,"0");return`${r}-${o}-${e} ${n}:${s}:${i}.${a}`}function ot(t,r){let o={yyyy:t.getFullYear(),yy:t.getFullYear().toString().slice(-2),mm:l(t.getMonth()+1),dd:l(t.getDate()),HH:l(t.getHours()),MM:l(t.getMinutes()),ss:l(t.getSeconds()),SSS:l(t.getMilliseconds()),Z:-t.getTimezoneOffset()/60};return r.replace(/yyyy|yy|mm|dd|HH|MM|ss|SSS|Z/g,(e)=>(o[e]??"").toString())}function w(t,r){if(!r?.translateTime)return t.toISOString();if(r.translateTime===!0||r.translateTime==="SYS:STANDARD")return tt(t);return ot(t,r.translateTime)}var rt="\uD83E\uDD8A {now} {level} {duration} {method} {pathname} {status} {message} {context} {ip}";function et(t,r){if(r?.config?.useColors!==void 0)return r.config.useColors&&process.env.NO_COLOR===void 0;return t&&process.env.NO_COLOR===void 0}function m(t,r,o,e,n,s=!0){let i=et(s,n),a=new Date,c={now:i?I.default.bgYellow(I.default.black(w(a,n?.config?.timestamp))):w(a,n?.config?.timestamp),epoch:Math.floor(a.getTime()/1000).toString(),level:y(t,s),duration:O(e.beforeTime,s),method:R(r.method,s),pathname:D(r),status:v(o.status||200,s),message:o.message||"",context:o.context?(()=>{try{return JSON.stringify(o.context)}catch(p){return`[Error serializing context: ${p instanceof Error?p.message:"Unknown error"}]`}})():"",ip:n?.config?.ip&&r.headers.get("x-forwarded-for")?`IP: ${r.headers.get("x-forwarded-for")}`:""};return(n?.config?.customLogFormat||rt).replace(/{(\w+)}/g,(p,U)=>{if(U in c)return c[U]||"";return""})}async function h(t,r,o,e,n){if(!n?.config?.transports||n.config.transports.length===0)return;let s=m(t,r,o,e,n,!1),i=n.config.transports.map((a)=>a.log(t,s,{request:r,data:o,store:e}));await Promise.all(i)}var k=require("node:fs"),W=require("node:path");var A=new Set;async function nt(t){let r=W.dirname(t);if(!A.has(r))await k.promises.mkdir(r,{recursive:!0}),A.add(r)}async function L(t,r,o,e,n,s){await nt(t);let i=`${m(r,o,e,n,s,!1)}
10
- `;await k.promises.appendFile(t,i,{flag:"a"})}var H=(t,r)=>Array.isArray(t)?t.includes(r):t===r;function _(t,r,o,e){let n=e?.config?.logFilter;if(!n)return!0;return(!n.level||H(n.level,t))&&(!n.status||H(n.status,r))&&(!n.method||H(n.method,o))}function d(t,r,o,e){let n=r.status||500;console.error(m("ERROR",t,{status:n},o,e));let s=[];if(e?.config?.logFilePath)s.push(L(e.config.logFilePath,"ERROR",t,{status:n},o,e))}function st(){let t=process.memoryUsage().heapUsed/1024/1024,r=process.cpuUsage();return{memoryUsage:t,cpuUsage:r.user/1e6}}async function S(t,r,o,e,n){if(!_(t,o.status||200,r.method,n))return;if(!o.metrics)o.metrics=st();if(t==="ERROR"&&!o.stack)o.stack=new Error(`Error: ${o.message||"Unknown error"}`).stack;let s=m(t,r,o,e,n,!0);console.log(s);let i=[];if(n?.config?.logFilePath)i.push(L(n.config.logFilePath,t,r,o,e,n));if(n?.config?.transports?.length)i.push(h(t,r,o,e,n));await Promise.all(i)}function x(t){let r={store:void 0,log:(o,e,n,s)=>S(o,e,n,s,t),handleHttpError:(o,e,n)=>d(o,e,n,t),customLogFormat:t?.config?.customLogFormat,info:(o,e,n,s)=>{let i=s||r.store||{beforeTime:process.hrtime.bigint()};return i.hasCustomLog=!0,S("INFO",o,{message:e,context:n,status:200},i,t)},error:(o,e,n,s)=>{let i=s||r.store||{beforeTime:process.hrtime.bigint()};return i.hasCustomLog=!0,S("ERROR",o,{message:e,context:n,status:500},i,t)},warn:(o,e,n,s)=>{let i=s||r.store||{beforeTime:process.hrtime.bigint()};return i.hasCustomLog=!0,S("WARNING",o,{message:e,context:n,status:200},i,t)},debug:(o,e,n,s)=>{let i=s||r.store||{beforeTime:process.hrtime.bigint()};return i.hasCustomLog=!0,S("DEBUG",o,{message:e,context:n,status:200},i,t)}};return r}function z(t){let r=x(t);return new Y.Elysia({name:"Logixlysia"}).onStart((o)=>{if(t?.config?.showStartupMessage??!0)E(o.server,t)}).onRequest((o)=>{let e={...o.store,beforeTime:process.hrtime.bigint(),logger:r,hasCustomLog:!1};o.store=e,r.store=e}).onAfterHandle({as:"global"},({request:o,set:e,store:n})=>{let s=n;if(!s.hasCustomLog){let i=T(e.status||200);r.log("INFO",o,{status:i,message:String(e.headers?.["x-message"]||"")},s)}}).onError({as:"global"},({request:o,error:e,set:n,store:s})=>{let i=T(n.status||500);r.handleHttpError(o,{...e,status:i},s)})}
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
11
 
12
- //# debugId=5019F142C76DE99264756E2164756E21
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' }, ({ request, error, set, store }) => {\n      const status = getStatusCode(set.status || 500)\n      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 } from '../output'\nimport { buildLogMessage } from './build-log-message'\n\nexport function handleHttpError(\n  request: RequestInfo,\n  error: HttpError,\n  store: StoreData,\n  options?: Options\n): void {\n  const statusCode = error.status || 500\n  console.error(\n    buildLogMessage('ERROR', request, { status: statusCode }, store, options)\n  )\n\n  const promises: Promise<void>[] = []\n\n  if (options?.config?.logFilePath) {\n    promises.push(\n      logToFile(\n        options.config.logFilePath,\n        'ERROR',\n        request,\n        { status: statusCode },\n        store,\n        options\n      )\n    )\n  }\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  console.log(logMessage)\n\n  const promises: Promise<void>[] = []\n\n  if (options?.config?.logFilePath) {\n    promises.push(\n      logToFile(\n        options.config.logFilePath,\n        level,\n        request,\n        data,\n        store,\n        options\n      )\n    )\n  }\n\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: (request, error, store) =>\n      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": "5019F142C76DE99264756E2164756E21",
  "names": []
}
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 CHANGED
@@ -21,7 +21,7 @@ interface LogData {
21
21
  interface Logger {
22
22
  store?: StoreData;
23
23
  log(level: LogLevel, request: RequestInfo, data: LogData, store: StoreData): void;
24
- handleHttpError(request: RequestInfo, error: HttpError, store: StoreData): void;
24
+ handleHttpError(request: RequestInfo, error: HttpError, store: StoreData): Promise<void>;
25
25
  customLogFormat?: string;
26
26
  info(request: RequestInfo, message: string, context?: Record<string, string | number | boolean | null>, store?: StoreData): void;
27
27
  error(request: RequestInfo, message: string, context?: Record<string, string | number | boolean | null>, store?: StoreData): void;
@@ -76,10 +76,13 @@ interface Options {
76
76
  startupMessageFormat?: "banner" | "simple"
77
77
  transports?: Transport[]
78
78
  timestamp?: TimestampConfig
79
+ disableInternalLogger?: boolean
80
+ disableFileLogging?: boolean
81
+ useTransportsOnly?: boolean
79
82
  };
80
83
  }
81
84
  declare function createLogger(options?: Options): Logger;
82
- declare function handleHttpError2(request: RequestInfo, error: HttpError, store: StoreData, options?: Options): void;
85
+ declare function handleHttpError2(request: RequestInfo, error: HttpError, store: StoreData, options?: Options): Promise<void>;
83
86
  declare function logToTransports(level: LogLevel, request: RequestInfo, data: LogData, store: StoreData, options?: Options): Promise<void>;
84
87
  declare function logixlysia(options?: Options): Elysia;
85
88
  export { logToTransports, handleHttpError2 as handleHttpError, logixlysia as default, createLogger, Transport, StoreData, RequestInfo, Options, LogixlysiaContext, Logger, LogLevel, LogData, HttpError };
package/dist/index.d.ts CHANGED
@@ -21,7 +21,7 @@ interface LogData {
21
21
  interface Logger {
22
22
  store?: StoreData;
23
23
  log(level: LogLevel, request: RequestInfo, data: LogData, store: StoreData): void;
24
- handleHttpError(request: RequestInfo, error: HttpError, store: StoreData): void;
24
+ handleHttpError(request: RequestInfo, error: HttpError, store: StoreData): Promise<void>;
25
25
  customLogFormat?: string;
26
26
  info(request: RequestInfo, message: string, context?: Record<string, string | number | boolean | null>, store?: StoreData): void;
27
27
  error(request: RequestInfo, message: string, context?: Record<string, string | number | boolean | null>, store?: StoreData): void;
@@ -76,10 +76,13 @@ interface Options {
76
76
  startupMessageFormat?: "banner" | "simple"
77
77
  transports?: Transport[]
78
78
  timestamp?: TimestampConfig
79
+ disableInternalLogger?: boolean
80
+ disableFileLogging?: boolean
81
+ useTransportsOnly?: boolean
79
82
  };
80
83
  }
81
84
  declare function createLogger(options?: Options): Logger;
82
- declare function handleHttpError2(request: RequestInfo, error: HttpError, store: StoreData, options?: Options): void;
85
+ declare function handleHttpError2(request: RequestInfo, error: HttpError, store: StoreData, options?: Options): Promise<void>;
83
86
  declare function logToTransports(level: LogLevel, request: RequestInfo, data: LogData, store: StoreData, options?: Options): Promise<void>;
84
87
  declare function logixlysia(options?: Options): Elysia;
85
88
  export { logToTransports, handleHttpError2 as handleHttpError, logixlysia as default, createLogger, Transport, StoreData, RequestInfo, Options, LogixlysiaContext, Logger, LogLevel, LogData, HttpError };
package/dist/index.js CHANGED
@@ -1,13 +1,13 @@
1
- import{Elysia as J}from"elysia";var w=(t,r)=>{let o=Math.max(0,(r-t.length)/2),n=" ".repeat(o);return`${n}${t}${n}`.padEnd(r)};function L(t,r){let o=t?.hostname??"localhost",n=t?.port??3000,e=t?.protocol??"http";if(r?.config?.startupMessageFormat!=="simple"){let a=`\uD83E\uDD8A Elysia is running at ${e}://${o}:${n}`,c=Math.max(22,a.length)+4,D="─".repeat(c),p=w("",c);console.log(`
2
- ┌${D}┐
3
- │${p}│
4
- │${w("Elysia with Logixlysia",c)}│
5
- │${p}│
6
- │${w(a,c)}│
7
- │${p}│
8
- └${D}┘
9
- `)}else console.log(`\uD83E\uDD8A Elysia is running at ${e}://${o}:${n}`)}import f from"chalk";import{StatusMap as N}from"elysia";function C(t){if(typeof t==="number")return t;return N[t]||500}function d(t,r){let o=t.toString();if(!r)return o;if(t>=500)return f.red(o);if(t>=400)return f.yellow(o);if(t>=300)return f.cyan(o);if(t>=200)return f.green(o);return f.white(o)}import I from"chalk";import l from"chalk";var M={INFO:l.bgGreen.black,WARNING:l.bgYellow.black,ERROR:l.bgRed.black},T={GET:l.green,POST:l.yellow,PUT:l.blue,PATCH:l.magentaBright,DELETE:l.red,HEAD:l.cyan,OPTIONS:l.magenta};import P from"chalk";var q=[{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 S(t,r){let o=Number(process.hrtime.bigint()-t);for(let{unit:n,threshold:e,decimalPlaces:s}of q)if(o>=e){let a=`${(o/e).toFixed(s)}${n}`.padStart(8).padEnd(16);return r?P.gray(a):a}return r?P.gray("0ns".padStart(8).padEnd(16)):"0ns".padStart(8).padEnd(16)}function x(t,r){let o=t.toUpperCase();return r?M[o]?.(o.padEnd(7))||o:o.padEnd(7)}function b(t,r){let o=T[t];return r&&o?o(t.padEnd(7)):t.padEnd(7)}function E(t){try{return new URL(t.url).pathname}catch{return}}var g=(t)=>t.toString().padStart(2,"0");function B(t){let r=t.getFullYear(),o=g(t.getMonth()+1),n=g(t.getDate()),e=g(t.getHours()),s=g(t.getMinutes()),i=g(t.getSeconds()),a=t.getMilliseconds().toString().padStart(3,"0");return`${r}-${o}-${n} ${e}:${s}:${i}.${a}`}function G(t,r){let o={yyyy:t.getFullYear(),yy:t.getFullYear().toString().slice(-2),mm:g(t.getMonth()+1),dd:g(t.getDate()),HH:g(t.getHours()),MM:g(t.getMinutes()),ss:g(t.getSeconds()),SSS:g(t.getMilliseconds()),Z:-t.getTimezoneOffset()/60};return r.replace(/yyyy|yy|mm|dd|HH|MM|ss|SSS|Z/g,(n)=>(o[n]??"").toString())}function v(t,r){if(!r?.translateTime)return t.toISOString();if(r.translateTime===!0||r.translateTime==="SYS:STANDARD")return B(t);return G(t,r.translateTime)}var A="\uD83E\uDD8A {now} {level} {duration} {method} {pathname} {status} {message} {context} {ip}";function W(t,r){if(r?.config?.useColors!==void 0)return r.config.useColors&&process.env.NO_COLOR===void 0;return t&&process.env.NO_COLOR===void 0}function m(t,r,o,n,e,s=!0){let i=W(s,e),a=new Date,c={now:i?I.bgYellow(I.black(v(a,e?.config?.timestamp))):v(a,e?.config?.timestamp),epoch:Math.floor(a.getTime()/1000).toString(),level:x(t,s),duration:S(n.beforeTime,s),method:b(r.method,s),pathname:E(r),status:d(o.status||200,s),message:o.message||"",context:o.context?(()=>{try{return JSON.stringify(o.context)}catch(p){return`[Error serializing context: ${p instanceof Error?p.message:"Unknown error"}]`}})():"",ip:e?.config?.ip&&r.headers.get("x-forwarded-for")?`IP: ${r.headers.get("x-forwarded-for")}`:""};return(e?.config?.customLogFormat||A).replace(/{(\w+)}/g,(p,F)=>{if(F in c)return c[F]||"";return""})}async function O(t,r,o,n,e){if(!e?.config?.transports||e.config.transports.length===0)return;let s=m(t,r,o,n,e,!1),i=e.config.transports.map((a)=>a.log(t,s,{request:r,data:o,store:n}));await Promise.all(i)}import{promises as H}from"node:fs";import{dirname as _}from"node:path";var k=new Set;async function Y(t){let r=_(t);if(!k.has(r))await H.mkdir(r,{recursive:!0}),k.add(r)}async function u(t,r,o,n,e,s){await Y(t);let i=`${m(r,o,n,e,s,!1)}
10
- `;await H.appendFile(t,i,{flag:"a"})}var $=(t,r)=>Array.isArray(t)?t.includes(r):t===r;function U(t,r,o,n){let e=n?.config?.logFilter;if(!e)return!0;return(!e.level||$(e.level,t))&&(!e.status||$(e.status,r))&&(!e.method||$(e.method,o))}function y(t,r,o,n){let e=r.status||500;console.error(m("ERROR",t,{status:e},o,n));let s=[];if(n?.config?.logFilePath)s.push(u(n.config.logFilePath,"ERROR",t,{status:e},o,n))}function z(){let t=process.memoryUsage().heapUsed/1024/1024,r=process.cpuUsage();return{memoryUsage:t,cpuUsage:r.user/1e6}}async function h(t,r,o,n,e){if(!U(t,o.status||200,r.method,e))return;if(!o.metrics)o.metrics=z();if(t==="ERROR"&&!o.stack)o.stack=new Error(`Error: ${o.message||"Unknown error"}`).stack;let s=m(t,r,o,n,e,!0);console.log(s);let i=[];if(e?.config?.logFilePath)i.push(u(e.config.logFilePath,t,r,o,n,e));if(e?.config?.transports?.length)i.push(O(t,r,o,n,e));await Promise.all(i)}function R(t){let r={store:void 0,log:(o,n,e,s)=>h(o,n,e,s,t),handleHttpError:(o,n,e)=>y(o,n,e,t),customLogFormat:t?.config?.customLogFormat,info:(o,n,e,s)=>{let i=s||r.store||{beforeTime:process.hrtime.bigint()};return i.hasCustomLog=!0,h("INFO",o,{message:n,context:e,status:200},i,t)},error:(o,n,e,s)=>{let i=s||r.store||{beforeTime:process.hrtime.bigint()};return i.hasCustomLog=!0,h("ERROR",o,{message:n,context:e,status:500},i,t)},warn:(o,n,e,s)=>{let i=s||r.store||{beforeTime:process.hrtime.bigint()};return i.hasCustomLog=!0,h("WARNING",o,{message:n,context:e,status:200},i,t)},debug:(o,n,e,s)=>{let i=s||r.store||{beforeTime:process.hrtime.bigint()};return i.hasCustomLog=!0,h("DEBUG",o,{message:n,context:e,status:200},i,t)}};return r}function j(t){let r=R(t);return new J({name:"Logixlysia"}).onStart((o)=>{if(t?.config?.showStartupMessage??!0)L(o.server,t)}).onRequest((o)=>{let n={...o.store,beforeTime:process.hrtime.bigint(),logger:r,hasCustomLog:!1};o.store=n,r.store=n}).onAfterHandle({as:"global"},({request:o,set:n,store:e})=>{let s=e;if(!s.hasCustomLog){let i=C(n.status||200);r.log("INFO",o,{status:i,message:String(n.headers?.["x-message"]||"")},s)}}).onError({as:"global"},({request:o,error:n,set:e,store:s})=>{let i=C(e.status||500);r.handleHttpError(o,{...n,status:i},s)})}export{O as logToTransports,y as handleHttpError,j as default,R as createLogger};
1
+ import{Elysia as J}from"elysia";var D=(r,o)=>{let t=Math.max(0,(o-r.length)/2),n=" ".repeat(t);return`${n}${r}${n}`.padEnd(o)};function d(r,o){let t=r?.hostname??"localhost",n=r?.port??3000,e=r?.protocol??"http";if(o?.config?.startupMessageFormat!=="simple"){let i=`\uD83E\uDD8A Elysia is running at ${e}://${t}:${n}`,m=Math.max(22,i.length)+4,w="─".repeat(m),f=D("",m);console.log(`
2
+ ┌${w}┐
3
+ │${f}│
4
+ │${D("Elysia with Logixlysia",m)}│
5
+ │${f}│
6
+ │${D(i,m)}│
7
+ │${f}│
8
+ └${w}┘
9
+ `)}else console.log(`\uD83E\uDD8A Elysia is running at ${e}://${t}:${n}`)}import u from"chalk";import{StatusMap as N}from"elysia";function T(r){if(typeof r==="number")return r;return N[r]||500}function S(r,o){let t=r.toString();if(!o)return t;if(r>=500)return u.red(t);if(r>=400)return u.yellow(t);if(r>=300)return u.cyan(t);if(r>=200)return u.green(t);return u.white(t)}import I from"chalk";import l from"chalk";var C={INFO:l.bgGreen.black,WARNING:l.bgYellow.black,ERROR:l.bgRed.black},F={GET:l.green,POST:l.yellow,PUT:l.blue,PATCH:l.magentaBright,DELETE:l.red,HEAD:l.cyan,OPTIONS:l.magenta};import $ from"chalk";var q=[{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 b(r,o){let t=Number(process.hrtime.bigint()-r);for(let{unit:n,threshold:e,decimalPlaces:s}of q)if(t>=e){let i=`${(t/e).toFixed(s)}${n}`.padStart(8).padEnd(16);return o?$.gray(i):i}return o?$.gray("0ns".padStart(8).padEnd(16)):"0ns".padStart(8).padEnd(16)}function x(r,o){let t=r.toUpperCase();return o?C[t]?.(t.padEnd(7))||t:t.padEnd(7)}function y(r,o){let t=F[r];return o&&t?t(r.padEnd(7)):r.padEnd(7)}function O(r){try{return new URL(r.url).pathname}catch{return}}var g=(r)=>r.toString().padStart(2,"0");function B(r){let o=r.getFullYear(),t=g(r.getMonth()+1),n=g(r.getDate()),e=g(r.getHours()),s=g(r.getMinutes()),a=g(r.getSeconds()),i=r.getMilliseconds().toString().padStart(3,"0");return`${o}-${t}-${n} ${e}:${s}:${a}.${i}`}function G(r,o){let t={yyyy:r.getFullYear(),yy:r.getFullYear().toString().slice(-2),mm:g(r.getMonth()+1),dd:g(r.getDate()),HH:g(r.getHours()),MM:g(r.getMinutes()),ss:g(r.getSeconds()),SSS:g(r.getMilliseconds()),Z:-r.getTimezoneOffset()/60};return o.replace(/yyyy|yy|mm|dd|HH|MM|ss|SSS|Z/g,(n)=>(t[n]??"").toString())}function E(r,o){if(!o?.translateTime)return r.toISOString();if(o.translateTime===!0||o.translateTime==="SYS:STANDARD")return B(r);return G(r,o.translateTime)}var A="\uD83E\uDD8A {now} {level} {duration} {method} {pathname} {status} {message} {context} {ip}";function W(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,n,e,s=!0){let a=W(s,e),i=new Date,m={now:a?I.bgYellow(I.black(E(i,e?.config?.timestamp))):E(i,e?.config?.timestamp),epoch:Math.floor(i.getTime()/1000).toString(),level:x(r,s),duration:b(n.beforeTime,s),method:y(o.method,s),pathname:O(o),status:S(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:e?.config?.ip&&o.headers.get("x-forwarded-for")?`IP: ${o.headers.get("x-forwarded-for")}`:""};return(e?.config?.customLogFormat||A).replace(/{(\w+)}/g,(f,P)=>{if(P in m)return m[P]||"";return""})}async function p(r,o,t,n,e){if(!e?.config?.transports||e.config.transports.length===0)return;let s=c(r,o,t,n,e,!1),a=e.config.transports.map((i)=>i.log(r,s,{request:o,data:t,store:n}));await Promise.all(a)}import{promises as H}from"node:fs";import{dirname as _}from"node:path";var k=new Set;async function Y(r){let o=_(r);if(!k.has(o))await H.mkdir(o,{recursive:!0}),k.add(o)}async function h(r,o,t,n,e,s){await Y(r);let a=`${c(o,t,n,e,s,!1)}
10
+ `;await H.appendFile(r,a,{flag:"a"})}var M=(r,o)=>Array.isArray(r)?r.includes(o):r===o;function U(r,o,t,n){let e=n?.config?.logFilter;if(!e)return!0;return(!e.level||M(e.level,r))&&(!e.status||M(e.status,o))&&(!e.method||M(e.method,t))}async function R(r,o,t,n){let s={status:o.status||500,message:o.message,stack:o.stack},a=[];if(!(n?.config?.useTransportsOnly||n?.config?.disableInternalLogger))console.error(c("ERROR",r,s,t,n));if(!n?.config?.useTransportsOnly&&n?.config?.logFilePath&&!n?.config?.disableFileLogging)a.push(h(n.config.logFilePath,"ERROR",r,s,t,n));if(n?.config?.transports?.length)a.push(p("ERROR",r,s,t,n));await Promise.all(a)}function z(){let r=process.memoryUsage().heapUsed/1024/1024,o=process.cpuUsage();return{memoryUsage:r,cpuUsage:o.user/1e6}}async function L(r,o,t,n,e){if(!U(r,t.status||200,o.method,e))return;if(!t.metrics)t.metrics=z();if(r==="ERROR"&&!t.stack)t.stack=Error(`Error: ${t.message||"Unknown error"}`).stack;let s=c(r,o,t,n,e,!0),a=[];if(!(e?.config?.useTransportsOnly||e?.config?.disableInternalLogger))console.log(s);if(!e?.config?.useTransportsOnly&&e?.config?.logFilePath&&!e?.config?.disableFileLogging)a.push(h(e.config.logFilePath,r,o,t,n,e));if(e?.config?.transports?.length)a.push(p(r,o,t,n,e));await Promise.all(a)}function v(r){let o={store:void 0,log:(t,n,e,s)=>L(t,n,e,s,r),handleHttpError:async(t,n,e)=>await R(t,n,e,r),customLogFormat:r?.config?.customLogFormat,info:(t,n,e,s)=>{let a=s||o.store||{beforeTime:process.hrtime.bigint()};return a.hasCustomLog=!0,L("INFO",t,{message:n,context:e,status:200},a,r)},error:(t,n,e,s)=>{let a=s||o.store||{beforeTime:process.hrtime.bigint()};return a.hasCustomLog=!0,L("ERROR",t,{message:n,context:e,status:500},a,r)},warn:(t,n,e,s)=>{let a=s||o.store||{beforeTime:process.hrtime.bigint()};return a.hasCustomLog=!0,L("WARNING",t,{message:n,context:e,status:200},a,r)},debug:(t,n,e,s)=>{let a=s||o.store||{beforeTime:process.hrtime.bigint()};return a.hasCustomLog=!0,L("DEBUG",t,{message:n,context:e,status:200},a,r)}};return o}function j(r){let o=v(r);return new J({name:"Logixlysia"}).onStart((t)=>{if(r?.config?.showStartupMessage??!0)d(t.server,r)}).onRequest((t)=>{let n={...t.store,beforeTime:process.hrtime.bigint(),logger:o,hasCustomLog:!1};t.store=n,o.store=n}).onAfterHandle({as:"global"},({request:t,set:n,store:e})=>{let s=e;if(!s.hasCustomLog){let a=T(n.status||200);o.log("INFO",t,{status:a,message:String(n.headers?.["x-message"]||"")},s)}}).onError({as:"global"},async({request:t,error:n,set:e,store:s})=>{let a=T(e.status||500);await o.handleHttpError(t,{...n,status:a},s)})}export{p as logToTransports,R as handleHttpError,j as default,v as createLogger};
11
11
 
12
- //# debugId=F56AA4EFC34A3D6864756E2164756E21
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' }, ({ request, error, set, store }) => {\n      const status = getStatusCode(set.status || 500)\n      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 } from '../output'\nimport { buildLogMessage } from './build-log-message'\n\nexport function handleHttpError(\n  request: RequestInfo,\n  error: HttpError,\n  store: StoreData,\n  options?: Options\n): void {\n  const statusCode = error.status || 500\n  console.error(\n    buildLogMessage('ERROR', request, { status: statusCode }, store, options)\n  )\n\n  const promises: Promise<void>[] = []\n\n  if (options?.config?.logFilePath) {\n    promises.push(\n      logToFile(\n        options.config.logFilePath,\n        'ERROR',\n        request,\n        { status: statusCode },\n        store,\n        options\n      )\n    )\n  }\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  console.log(logMessage)\n\n  const promises: Promise<void>[] = []\n\n  if (options?.config?.logFilePath) {\n    promises.push(\n      logToFile(\n        options.config.logFilePath,\n        level,\n        request,\n        data,\n        store,\n        options\n      )\n    )\n  }\n\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: (request, error, store) =>\n      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": "F56AA4EFC34A3D6864756E2164756E21",
  "names": []
}
12
+ //# debugId=C43B828C0DA6DD5064756E2164756E21
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": "C43B828C0DA6DD5064756E2164756E21",
  "names": []
}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "logixlysia",
3
- "version": "5.1.1",
3
+ "version": "5.2.0",
4
4
  "description": "🦊 Logixlysia is a logger for Elysia",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",