-
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathlogging.ts
63 lines (55 loc) · 1.91 KB
/
logging.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
import winston from "winston";
import colors from "yoctocolors";
import { config } from "@/common/config.ts";
import { BaseSamplerRequest } from "@/common/sampling.ts";
const customFormat = winston.format.printf(({ timestamp, level, message }) => {
const coloredTimestamp = colors.dim(timestamp as string);
const upperLevel = level.toUpperCase();
// Set colored log level
let coloredLevel = upperLevel;
switch (level) {
case "error":
coloredLevel = colors.red(upperLevel);
break;
case "warn":
coloredLevel = colors.yellow(upperLevel);
break;
case "info":
coloredLevel = colors.green(upperLevel);
break;
case "debug":
coloredLevel = colors.cyan(upperLevel);
break;
default:
coloredLevel = colors.dim(upperLevel);
}
coloredLevel = colors.bold(coloredLevel);
const coloredPrefix = colors.dim("YALS");
return `${coloredTimestamp} ${coloredLevel} ${coloredPrefix}: ${message}`;
});
export const logger = winston.createLogger({
level: "debug",
format: winston.format.combine(
winston.format.splat(),
winston.format.timestamp({ format: "YYYY-MM-DD HH:mm:ss.SSS" }),
customFormat,
),
transports: [new winston.transports.Console({ level: "info" })],
});
export function logPrompt(prompt: string) {
// Log prompt to console
if (config.logging.log_prompt) {
logger.info(`Prompt: \n${prompt}`);
}
}
export function logGenParams(params: BaseSamplerRequest) {
if (config.logging.log_generation_params) {
const samplerParams = BaseSamplerRequest.parse(params);
const formattedParams = Deno.inspect(samplerParams, {
depth: 2,
compact: true,
breakLength: Infinity,
});
logger.info(`Generation Parameters: ${colors.green(formattedParams)}`);
}
}