This logger is simple and advanced logger module for Deno Fresh
// _middleware.ts
import { loggerHandler } from "https://deno.land/x/[email protected]/mod.ts";
export const handler = [loggerHandler];
// _middleware.ts
import {LogModule, type Logger, type RemoteLogSenderFunction} from "https://deno.land/x/[email protected]/mod.ts";
function logSender(level: LogLevel, logBody: string): void {
// Filter log, omit "log"
if (["info", "warn", "error"].indexOf(level) === -1) return;
// Any log service
fetch("[any url]", {
method: "post",
headers: {
"Accept": "application/json",
"Content-Type": "application/json",
},
body: JSON.stringify({
message: logBody,
}),
});
}
function loggerHandler(_req: Request, ctx: MiddlewareHandlerContext<Logger>) {
ctx.state.logger = new LogModule()
return ctx.next();
}
export const handler = [loggerHandler];
// main.ts
/// <reference no-default-lib="true" />
/// <reference lib="dom" />
/// <reference lib="dom.iterable" />
/// <reference lib="dom.asynciterable" />
/// <reference lib="deno.ns" />
import "$std/dotenv/load.ts";
import { start } from "$fresh/server.ts";
import manifest from "./fresh.gen.ts";
import twindPlugin from "$fresh/plugins/twind.ts";
import twindConfig from "./twind.config.ts";
import { getLoggerHandler } from "https://deno.land/x/[email protected]/mod.ts"; // <= Import module
await start(manifest, {
plugins: [
getLoggerHandler(), // <= Set handler
twindPlugin(twindConfig),
],
});