REST Service for POPCORN - ILIAS
alex
2025-08-13 a0228eb7c0d7df0f41ac3a36243eb7d46c6ed09b
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
const _ = require("lodash")
const dayjs = require("dayjs")
const colors = require("colors/safe")
const fs = require("node:fs/promises")
 
/////////////////////////////////////////////////////////////////////////
 
module.exports = {
   debug: msg => log("DEBUG", msg),
   info: msg => log("INFO", msg),
   warn: msg => log("WARN", msg),
   error: msg => log("ERROR", msg),
}
 
/////////////////////////////////////////////////////////////////////////
 
function log (level, msg) {
   if (!_.isString(msg)) {
      if (msg.message) {
         msg = msg.message
      }
      else {
         try {
            msg = JSON.stringify(msg)
         } catch (ex) {
            msg = msg?.toString()
         }
      }
   }
   level = _.padEnd(level, 5)
   level = format(level.toLowerCase())
   let message = `${level} ${dayjs().format("DD.MM.YYYY HH:mm:ss")} - ${msg}`
   console.log(message)
   return fs.appendFile("log.log", message + "\n")
}
 
function format (level) {
   switch (level.trim()) {
      case "info":
         return colors.green(level.toUpperCase())
      case "warn":
         return colors.blue(level.toUpperCase())
      case "error":
         return colors.red(level.toUpperCase())
      case "debug":
         return colors.grey(level.toUpperCase())
   }
   return level
}