hivessh
Version:
HiveSsh is an innovative library designed to streamline SSH2 connections and simplify task execution on Linux servers.
353 lines • 46.7 kB
JavaScript
export const logNames = [
"Fatal", "Error", "Warning", "Info", "Trace", "Debug",
];
export const logShorts = [
"FAT", "ERR", "WAR", "INF", "TRA", "DEB",
];
export const customLogType = {};
export const fatalLogType = getLogTypeByLevel(0);
export const errorLogType = getLogTypeByLevel(4);
export const warningLogType = getLogTypeByLevel(8);
export const infoLogType = getLogTypeByLevel(12);
export const traceLogType = getLogTypeByLevel(16);
export const debugLogType = getLogTypeByLevel(20);
export function getLogTypeByLevel(level) {
if (level == 0 ||
level == 4 ||
level == 8 ||
level == 12 ||
level == 16 ||
level == 20) {
return {
level: level,
name: logNames[level / 4],
short: logShorts[level / 4]
};
}
if (customLogType[level]) {
return {
name: customLogType[level].name,
short: (customLogType[level].short)
.toUpperCase()
.slice(0, 3),
level: level,
};
}
return {
level: level,
name: "Unknown",
short: "UNK",
};
}
export function defaultLogParser(log) {
return getLogTimestemp(log.time) +
"|" + log.type.short +
"|" + (log.area ?
log.area + "| " :
" ") + (log.value
.split("\n")
.join("\n ")) + (log.value.includes("\n") ?
"\n" :
"");
}
export function getLogTimestemp(date) {
if (typeof date == "number") {
date = new Date(date);
}
let year = date.getFullYear();
let month = ('0' + (date.getMonth() + 1)).slice(-2);
let day = ('0' + date.getDate()).slice(-2);
let hours = ('0' + date.getHours()).slice(-2);
let minutes = ('0' + date.getMinutes()).slice(-2);
let seconds = ('0' + date.getSeconds()).slice(-2);
return `${year}.${month}.${day}-${hours}:${minutes}:${seconds}`;
}
export class Logger {
prefix;
logs;
pipeTargets;
static StdOut = new Logger((log) => {
console.info(defaultLogParser(log));
});
static StdStreams = new Logger((log) => {
if (log.type.level < 10) {
console.error(defaultLogParser(log));
}
else {
console.info(defaultLogParser(log));
}
});
constructor(pipeTargets = undefined, prefix = "", logs = []) {
this.prefix = prefix;
this.logs = logs;
if (pipeTargets) {
if (Array.isArray(pipeTargets)) {
this.pipeTargets = pipeTargets;
}
else {
this.pipeTargets = [pipeTargets];
}
for (const pipeTarget of this.pipeTargets) {
if (!pipeTarget ||
pipeTarget == null ||
(typeof pipeTarget != "function" &&
typeof pipeTarget != "object")) {
throw new Error("Pipe target need to be an object with log method or a calback function");
}
else if (pipeTarget == this) {
throw new Error("Cant select a logger as its own pipe target");
}
}
}
}
rewrite = (options) => {
const settings = {
...options,
isArea: !options.isArea ?
undefined :
Array.isArray(options.isArea) ?
options.isArea :
[options.isArea],
notArea: !options.notArea ?
undefined :
Array.isArray(options.notArea) ?
options.notArea :
[options.notArea],
startsWithArea: !options.startsWithArea ?
undefined :
Array.isArray(options.startsWithArea) ?
options.startsWithArea :
[options.startsWithArea],
newAreaPrefix: options.newAreaPrefix ?
parseArea(options.newAreaPrefix) :
undefined,
};
return (log) => {
if (log.area) {
if (settings.justWithoutArea == true) {
return;
}
if (settings.notArea &&
settings.notArea.includes(log.area)) {
return;
}
if (settings.isArea &&
!settings.isArea.includes(log.area)) {
return;
}
if (settings.startsWithArea) {
let found = false;
for (const startsWithArea of settings.startsWithArea) {
if (log.area.startsWith(startsWithArea)) {
found = true;
break;
}
}
if (!found) {
return;
}
}
}
else if (settings.justWithArea == true ||
(settings.isArea &&
settings.isArea.length > 0 ||
settings.startsWithArea &&
settings.startsWithArea.length > 0)) {
return;
}
if (settings.maxLogLevel &&
log.type.level > settings.maxLogLevel) {
return;
}
if (settings.minLogLevel &&
log.type.level < settings.minLogLevel) {
return;
}
this.addLog({
...log,
area: log.area ? (settings.newAreaPrefix ?
settings.newAreaPrefix + "-" + log.area :
log.area) : (settings.newAreaPrefix ?
settings.newAreaPrefix :
undefined)
});
};
};
pipe(pipeTarget, justNewLogs = false) {
if (!pipeTarget ||
pipeTarget == null ||
(typeof pipeTarget != "function" &&
typeof pipeTarget != "object")) {
throw new Error("Pipe target need to be an object with log method or a calback function");
}
else if (pipeTarget == this) {
throw new Error("Cant select a logger as its own pipe target");
}
if (!justNewLogs) {
for (const log of this.logs) {
if (typeof pipeTarget == "function") {
pipeTarget(log);
}
else {
pipeTarget.addLog(log);
}
}
}
if (!this.pipeTargets) {
this.pipeTargets = [];
}
this.pipeTargets.push(pipeTarget);
}
unpipe(pipeTarget) {
if (!this.pipeTargets ||
pipeTarget == this) {
return;
}
if (!pipeTarget ||
pipeTarget == null ||
(typeof pipeTarget != "function" &&
typeof pipeTarget != "object")) {
throw new Error("Pipe target need to be an object with log method or a calback function");
}
if (typeof pipeTarget == "function") {
const pipeTargetString = "" + pipeTarget;
this.pipeTargets = this.pipeTargets.filter((v) => {
if (typeof v == "function") {
return "" + v != pipeTargetString;
}
return true;
});
}
else {
this.pipeTargets = this.pipeTargets.filter((v) => {
if (typeof v == "object") {
return v != pipeTarget;
}
return true;
});
}
if (this.pipeTargets.length == 0) {
this.pipeTargets = undefined;
}
}
unpipeAll() {
this.pipeTargets = undefined;
}
clear() {
this.logs = [];
}
fatal(value, area) {
this.log(fatalLogType, value, area);
}
error(value, area) {
this.log(errorLogType, value, area);
}
warn(value, area) {
this.log(warningLogType, value, area);
}
info(value, area) {
this.log(infoLogType, value, area);
}
trace(value, area) {
this.log(traceLogType, value, area);
}
debug(value, area) {
this.log(debugLogType, value, area);
}
log(level, value, area) {
this.addLog({
type: typeof level == "number" ?
getLogTypeByLevel(level) :
level,
value: (this.prefix != undefined ?
this.prefix + value :
value),
area: area ?
parseArea(area) :
undefined,
time: Date.now(),
});
}
addLog(log) {
this.logs.push(log);
if (this.pipeTargets) {
for (const pipeTarget of this.pipeTargets) {
if (typeof pipeTarget == "function") {
pipeTarget(log);
}
else {
pipeTarget.addLog(log);
}
}
}
}
getAbove(level, includeLevel) {
return this.logs.filter((v) => includeLevel ?
v.type.level >= level :
v.type.level > level);
}
getBelow(level, includeLevel) {
return this.logs.filter((v) => includeLevel ?
v.type.level <= level :
v.type.level < level);
}
getLogsWithAreas(areas) {
return this.logs.filter((v) => v.area ?
areas.includes(v.area) :
false);
}
getLogsInArea(areas) {
return this.logs.filter((v) => {
if (!v.area) {
return false;
}
for (const area of areas) {
if (area.startsWith(v.area)) {
return true;
}
}
return false;
});
}
getLogsNotInAreas(areas) {
return this.logs.filter((v) => v.area ?
!areas.includes(v.area) :
!areas.includes("default"));
}
parseLogs(logParser = defaultLogParser) {
let out = "";
for (const log of this.logs) {
out += logParser(log) + "\n";
}
return out;
}
}
export function parseArea(area) {
area = area.toLowerCase();
while (area.startsWith("-")) {
area = area.slice(1);
}
while (area.endsWith("-")) {
area = area.slice(0, -1);
}
if (area.includes(" ")) {
area = area.split(" ").join("-");
}
if (area.includes("_")) {
area = area.split("_").join("-");
}
if (area.includes("#")) {
area = area.split("#").join("-");
}
if (area.includes(";")) {
area = area.split(";").join("-");
}
if (area.includes("/")) {
area = area.split("/").join("-");
}
if (area.includes("\\")) {
area = area.split("\\").join("-");
}
return area;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"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","sourcesContent":["\nexport const logNames = [\n    \"Fatal\", \"Error\", \"Warning\", \"Info\", \"Trace\", \"Debug\",\n] as const\nexport type LogName = typeof logNames[number]\n\nexport const logShorts = [\n    \"FAT\", \"ERR\", \"WAR\", \"INF\", \"TRA\", \"DEB\",\n] as const\nexport type LogShort = typeof logShorts[number]\n\nexport const customLogType: {\n    [level: number]: {\n        name: string,\n        short: string,\n    }\n} = {}\n\nexport const fatalLogType: LogType = getLogTypeByLevel(0)\nexport const errorLogType: LogType = getLogTypeByLevel(4)\nexport const warningLogType: LogType = getLogTypeByLevel(8)\nexport const infoLogType: LogType = getLogTypeByLevel(12)\nexport const traceLogType: LogType = getLogTypeByLevel(16)\nexport const debugLogType: LogType = getLogTypeByLevel(20)\n\nexport interface LogType {\n    name: string,\n    short: string,\n    level: number,\n}\n\nexport function getLogTypeByLevel(\n    level: number\n): LogType {\n    if (\n        level == 0 ||\n        level == 4 ||\n        level == 8 ||\n        level == 12 ||\n        level == 16 ||\n        level == 20\n    ) {\n        return {\n            level: level,\n            name: logNames[level / 4],\n            short: logShorts[level / 4]\n        }\n    }\n\n    if (customLogType[level]) {\n        return {\n            name: customLogType[level].name,\n            short: (customLogType[level].short)\n                .toUpperCase()\n                .slice(0, 3),\n            level: level,\n        }\n    }\n\n    return {\n        level: level,\n        name: \"Unknown\",\n        short: \"UNK\",\n    }\n}\n\nexport interface Log {\n    time: number,\n    type: LogType,\n    value: string,\n    area?: string,\n}\n\nexport type LogParser = (log: Log) => string\n\nexport function defaultLogParser(log: Log): string {\n    return getLogTimestemp(log.time) +\n        \"|\" + log.type.short +\n        \"|\" + (\n            log.area ?\n                log.area + \"| \" :\n                \" \"\n        ) + (\n            log.value\n                .split(\"\\n\")\n                .join(\"\\n  \")\n        ) + (\n            log.value.includes(\"\\n\") ?\n                \"\\n\" :\n                \"\"\n        )\n}\n\nexport function getLogTimestemp(date: Date | number): string {\n    if (typeof date == \"number\") {\n        date = new Date(date)\n    }\n\n    let year = date.getFullYear()\n    let month = ('0' + (date.getMonth() + 1)).slice(-2)\n    let day = ('0' + date.getDate()).slice(-2)\n    let hours = ('0' + date.getHours()).slice(-2)\n    let minutes = ('0' + date.getMinutes()).slice(-2)\n    let seconds = ('0' + date.getSeconds()).slice(-2)\n\n    return `${year}.${month}.${day}-${hours}:${minutes}:${seconds}`\n}\n\nexport type PipeTargetFunc = ((log: Log) => any)\nexport interface PipeTargetObject {\n    addLog: (log: Log) => any\n}\n\nexport type PipeTarget = PipeTargetFunc | PipeTargetObject\n\nexport interface LogRewriteOptions {\n    isArea?: string | string[],\n    notArea?: string | string[],\n    startsWithArea?: string | string[],\n    newAreaPrefix?: string,\n    justWithoutArea?: boolean,\n    justWithArea?: boolean,\n    minLogLevel?: number,\n    maxLogLevel?: number,\n}\n\nexport interface LogRewriteSettings {\n    isArea: string[] | undefined,\n    notArea: string[] | undefined,\n    startsWithArea: string[] | undefined,\n    newAreaPrefix: string | undefined,\n    justWithoutArea?: boolean,\n    justWithArea?: boolean,\n    minLogLevel?: number,\n    maxLogLevel?: number,\n}\n\nexport class Logger {\n    pipeTargets: PipeTarget[] | undefined\n\n    static StdOut: Logger = new Logger(\n        (log: Log): void => {\n            console.info(defaultLogParser(log))\n        }\n    )\n\n    static StdStreams: Logger = new Logger(\n        (log: Log): void => {\n            if (log.type.level < 10) {\n                console.error(defaultLogParser(log))\n            } else {\n                console.info(defaultLogParser(log))\n            }\n        }\n    )\n\n    constructor(\n        pipeTargets: PipeTarget | PipeTarget[] | undefined = undefined,\n        public prefix: string | undefined = \"\",\n        public logs: Log[] = [],\n    ) {\n        if (pipeTargets) {\n            if (Array.isArray(pipeTargets)) {\n                this.pipeTargets = pipeTargets\n            } else {\n                this.pipeTargets = [pipeTargets]\n            }\n            for (const pipeTarget of this.pipeTargets) {\n                if (\n                    !pipeTarget ||\n                    pipeTarget == null ||\n                    (\n                        typeof pipeTarget != \"function\" &&\n                        typeof pipeTarget != \"object\"\n                    )\n                ) {\n                    throw new Error(\n                        \"Pipe target need to be an object with log method or a calback function\"\n                    )\n                } else if (pipeTarget == this) {\n                    throw new Error(\"Cant select a logger as its own pipe target\")\n                }\n            }\n        }\n    }\n\n    rewrite = (\n        options: LogRewriteOptions\n    ): PipeTargetFunc => {\n        const settings: LogRewriteSettings = {\n            ...options,\n            isArea: !options.isArea ?\n                undefined :\n                Array.isArray(options.isArea) ?\n                    options.isArea :\n                    [options.isArea],\n            notArea: !options.notArea ?\n                undefined :\n                Array.isArray(options.notArea) ?\n                    options.notArea :\n                    [options.notArea],\n            startsWithArea: !options.startsWithArea ?\n                undefined :\n                Array.isArray(options.startsWithArea) ?\n                    options.startsWithArea :\n                    [options.startsWithArea],\n            newAreaPrefix: options.newAreaPrefix ?\n                parseArea(options.newAreaPrefix) :\n                undefined,\n        }\n\n        return (log) => {\n            if (log.area) {\n                if (settings.justWithoutArea == true) {\n                    return\n                }\n\n                if (\n                    settings.notArea &&\n                    settings.notArea.includes(log.area)\n                ) {\n                    return\n                }\n\n                if (\n                    settings.isArea &&\n                    !settings.isArea.includes(log.area)\n                ) {\n                    return\n                }\n\n                if (\n                    settings.startsWithArea\n                ) {\n                    let found: boolean = false\n                    for (const startsWithArea of settings.startsWithArea) {\n                        if (log.area.startsWith(startsWithArea)) {\n                            found = true\n                            break\n                        }\n                    }\n                    if (!found) {\n                        return\n                    }\n                }\n            } else if (\n                settings.justWithArea == true ||\n                (\n                    settings.isArea &&\n                    settings.isArea.length > 0 ||\n                    settings.startsWithArea &&\n                    settings.startsWithArea.length > 0\n                )\n            ) {\n                return\n            }\n\n            if (\n                settings.maxLogLevel &&\n                log.type.level > settings.maxLogLevel\n            ) {\n                return\n            }\n\n            if (\n                settings.minLogLevel &&\n                log.type.level < settings.minLogLevel\n            ) {\n                return\n            }\n\n            this.addLog({\n                ...log,\n                area: log.area ? (\n                    settings.newAreaPrefix ?\n                        settings.newAreaPrefix + \"-\" + log.area :\n                        log.area\n                ) : (\n                    settings.newAreaPrefix ?\n                        settings.newAreaPrefix :\n                        undefined\n                )\n            })\n        }\n    }\n\n    pipe(\n        pipeTarget: PipeTarget,\n        justNewLogs: boolean = false\n    ): void {\n        if (\n            !pipeTarget ||\n            pipeTarget == null ||\n            (\n                typeof pipeTarget != \"function\" &&\n                typeof pipeTarget != \"object\"\n            )\n        ) {\n            throw new Error(\n                \"Pipe target need to be an object with log method or a calback function\"\n            )\n        } else if (pipeTarget == this) {\n            throw new Error(\"Cant select a logger as its own pipe target\")\n        }\n\n        if (!justNewLogs) {\n            for (const log of this.logs) {\n                if (typeof pipeTarget == \"function\") {\n                    pipeTarget(log)\n                } else {\n                    pipeTarget.addLog(log)\n                }\n            }\n        }\n\n        if (!this.pipeTargets) {\n            this.pipeTargets = []\n        }\n\n        this.pipeTargets.push(pipeTarget)\n    }\n\n    unpipe(\n        pipeTarget: PipeTarget,\n    ): void {\n        if (\n            !this.pipeTargets ||\n            pipeTarget == this\n        ) {\n            return\n        }\n\n        if (\n            !pipeTarget ||\n            pipeTarget == null ||\n            (\n                typeof pipeTarget != \"function\" &&\n                typeof pipeTarget != \"object\"\n            )\n        ) {\n            throw new Error(\n                \"Pipe target need to be an object with log method or a calback function\"\n            )\n        }\n\n        if (typeof pipeTarget == \"function\") {\n            const pipeTargetString = \"\" + pipeTarget\n\n            this.pipeTargets = this.pipeTargets.filter(\n                (v) => {\n                    if (typeof v == \"function\") {\n                        return \"\" + v != pipeTargetString\n                    }\n                    return true\n                }\n            )\n        } else {\n            this.pipeTargets = this.pipeTargets.filter(\n                (v) => {\n                    if (typeof v == \"object\") {\n                        return v != pipeTarget\n                    }\n                    return true\n                }\n            )\n        }\n\n        if (this.pipeTargets.length == 0) {\n            this.pipeTargets = undefined\n        }\n    }\n\n    unpipeAll(): void {\n        this.pipeTargets = undefined\n    }\n\n    clear(): void {\n        this.logs = []\n    }\n\n    fatal(\n        value: string,\n        area?: string,\n    ): void {\n        this.log(\n            fatalLogType,\n            value,\n            area\n        )\n    }\n\n    error(\n        value: string,\n        area?: string,\n    ): void {\n        this.log(\n            errorLogType,\n            value,\n            area\n        )\n    }\n\n    warn(\n        value: string,\n        area?: string,\n    ): void {\n        this.log(\n            warningLogType,\n            value,\n            area\n        )\n    }\n\n    info(\n        value: string,\n        area?: string,\n    ): void {\n        this.log(\n            infoLogType,\n            value,\n            area\n        )\n    }\n\n    trace(\n        value: string,\n        area?: string,\n    ): void {\n        this.log(\n            traceLogType,\n            value,\n            area\n        )\n    }\n\n    debug(\n        value: string,\n        area?: string,\n    ): void {\n        this.log(\n            debugLogType,\n            value,\n            area\n        )\n    }\n\n    log(\n        level: number | LogType,\n        value: string,\n        area?: string,\n    ): void {\n        this.addLog({\n            type: typeof level == \"number\" ?\n                getLogTypeByLevel(level) :\n                level,\n            value: (\n                this.prefix != undefined ?\n                    this.prefix + value :\n                    value\n            ),\n            area: area ?\n                parseArea(area) :\n                undefined,\n            time: Date.now(),\n        })\n    }\n\n    addLog(\n        log: Log,\n    ): void {\n        this.logs.push(log)\n\n        if (this.pipeTargets) {\n            for (const pipeTarget of this.pipeTargets) {\n                if (typeof pipeTarget == \"function\") {\n                    pipeTarget(log)\n                } else {\n                    pipeTarget.addLog(log)\n                }\n            }\n        }\n    }\n\n    getAbove(\n        level: number,\n        includeLevel: boolean,\n    ): Log[] {\n        return this.logs.filter(\n            (v) => includeLevel ?\n                v.type.level >= level :\n                v.type.level > level\n        )\n    }\n\n    getBelow(\n        level: number,\n        includeLevel: boolean,\n    ): Log[] {\n        return this.logs.filter(\n            (v) => includeLevel ?\n                v.type.level <= level :\n                v.type.level < level\n        )\n    }\n\n    getLogsWithAreas(\n        areas: string[]\n    ): Log[] {\n        return this.logs.filter(\n            (v) => v.area ?\n                areas.includes(v.area) :\n                false\n        )\n    }\n\n    getLogsInArea(\n        areas: string[]\n    ): Log[] {\n        return this.logs.filter(\n            (v) => {\n                if (!v.area) {\n                    return false\n                }\n\n                for (const area of areas) {\n                    if (area.startsWith(v.area)) {\n                        return true\n                    }\n                }\n                return false\n            }\n        )\n    }\n\n    getLogsNotInAreas(\n        areas: string[]\n    ): Log[] {\n        return this.logs.filter(\n            (v) => v.area ?\n                !areas.includes(v.area) :\n                !areas.includes(\"default\")\n        )\n    }\n\n    parseLogs(\n        logParser: LogParser = defaultLogParser,\n    ) {\n        let out: string = \"\"\n        for (const log of this.logs) {\n            out += logParser(log) + \"\\n\"\n        }\n        return out\n    }\n}\n\nexport function parseArea(\n    area: string\n): string {\n    area = area.toLowerCase()\n    while (area.startsWith(\"-\")) {\n        area = area.slice(1)\n    }\n\n    while (area.endsWith(\"-\")) {\n        area = area.slice(0, -1)\n    }\n\n    if (area.includes(\" \")) {\n        area = area.split(\" \").join(\"-\")\n    }\n    if (area.includes(\"_\")) {\n        area = area.split(\"_\").join(\"-\")\n    }\n    if (area.includes(\"#\")) {\n        area = area.split(\"#\").join(\"-\")\n    }\n    if (area.includes(\";\")) {\n        area = area.split(\";\").join(\"-\")\n    }\n    if (area.includes(\"/\")) {\n        area = area.split(\"/\").join(\"-\")\n    }\n    if (area.includes(\"\\\\\")) {\n        area = area.split(\"\\\\\").join(\"-\")\n    }\n    return area\n}"]}