-
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathlogging.ts
69 lines (61 loc) · 2.09 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
64
65
66
67
68
69
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
// Prompts can be very large, so make the newline log a console.log instead
if (config.logging.log_prompt) {
logger.info(`Prompt:`);
console.log(prompt);
}
}
export function logGenParams(requestId: string, 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 (ID: ${requestId}): ${
colors.green(formattedParams)
}`,
);
}
}