Compare commits
6 Commits
Author | SHA1 | Date | |
---|---|---|---|
77e6a40261 | |||
3deb536323 | |||
f6b0e63751 | |||
d52f9cfdc3 | |||
0ffe3d6b13 | |||
d4bd054953 |
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@ztimson/js-utilities",
|
||||
"version": "0.3.3",
|
||||
"version": "0.3.8",
|
||||
"description": "JavaScript Utility library",
|
||||
"author": "Zak Timson",
|
||||
"license": "MIT",
|
||||
|
@ -4,7 +4,6 @@ export * from './errors';
|
||||
export * from './logger';
|
||||
export * from './misc';
|
||||
export * from './objects';
|
||||
// export * from './redis';
|
||||
export * from './string';
|
||||
export * from './time';
|
||||
export * from './xhr';
|
||||
|
@ -43,9 +43,11 @@ export const CliBackground = {
|
||||
|
||||
export enum LOG_LEVEL {
|
||||
VERBOSE,
|
||||
INFO,
|
||||
WARN,
|
||||
ERROR
|
||||
DEBUG = 0,
|
||||
LOG = 1,
|
||||
INFO = 2,
|
||||
WARN = 3,
|
||||
ERROR = 4,
|
||||
}
|
||||
|
||||
export type LoggerEvents = TypedEvents & {
|
||||
@ -56,7 +58,7 @@ export type LoggerEvents = TypedEvents & {
|
||||
};
|
||||
|
||||
export class Logger extends TypedEmitter<LoggerEvents> {
|
||||
static LOG_LEVEL: LOG_LEVEL = LOG_LEVEL.INFO;
|
||||
static LOG_LEVEL: LOG_LEVEL = LOG_LEVEL.VERBOSE;
|
||||
|
||||
constructor(public readonly namespace?: string) {
|
||||
super();
|
||||
@ -70,7 +72,6 @@ export class Logger extends TypedEmitter<LoggerEvents> {
|
||||
return !end ? padding + t : t + padding;
|
||||
}
|
||||
|
||||
|
||||
private format(...text: string[]): string {
|
||||
const now = new Date();
|
||||
const timestamp = `${now.getFullYear()}-${now.getMonth() + 1}-${now.getDate()} ${this.pad(now.getHours().toString(), 2, '0')}:${this.pad(now.getMinutes().toString(), 2, '0')}:${this.pad(now.getSeconds().toString(), 2, '0')}.${this.pad(now.getMilliseconds().toString(), 3, '0', true)}`;
|
||||
@ -78,42 +79,37 @@ export class Logger extends TypedEmitter<LoggerEvents> {
|
||||
}
|
||||
|
||||
debug(...args: string[]) {
|
||||
if(LOG_LEVEL.VERBOSE >= Logger.LOG_LEVEL) {
|
||||
const str = this.format(...args);
|
||||
Logger.emit(LOG_LEVEL.VERBOSE, str);
|
||||
console.debug(CliForeground.LIGHT_GREY + str + CliEffects.CLEAR);
|
||||
}
|
||||
}
|
||||
|
||||
error(...args: string[]) {
|
||||
if(LOG_LEVEL.ERROR >= Logger.LOG_LEVEL) {
|
||||
const str = this.format(...args);
|
||||
Logger.emit(LOG_LEVEL.ERROR, str);
|
||||
console.error(CliForeground.RED + str + CliEffects.CLEAR);
|
||||
}
|
||||
}
|
||||
|
||||
info(...args: string[]) {
|
||||
if(LOG_LEVEL.INFO >= Logger.LOG_LEVEL) {
|
||||
const str = this.format(...args);
|
||||
Logger.emit(LOG_LEVEL.INFO, str);
|
||||
console.info(CliForeground.BLUE + str + CliEffects.CLEAR);
|
||||
}
|
||||
if(Logger.LOG_LEVEL > LOG_LEVEL.VERBOSE) return;
|
||||
const str = this.format(...args);
|
||||
Logger.emit(LOG_LEVEL.VERBOSE, str);
|
||||
console.debug(CliForeground.LIGHT_GREY + str + CliEffects.CLEAR);
|
||||
}
|
||||
|
||||
log(...args: string[]) {
|
||||
if(LOG_LEVEL.INFO >= Logger.LOG_LEVEL) {
|
||||
const str = this.format(...args);
|
||||
Logger.emit(LOG_LEVEL.INFO, str);
|
||||
console.log(CliEffects.CLEAR + str);
|
||||
}
|
||||
if(Logger.LOG_LEVEL > LOG_LEVEL.INFO) return;
|
||||
const str = this.format(...args);
|
||||
Logger.emit(LOG_LEVEL.INFO, str);
|
||||
console.log(CliEffects.CLEAR + str);
|
||||
}
|
||||
|
||||
info(...args: string[]) {
|
||||
if(Logger.LOG_LEVEL > LOG_LEVEL.INFO) return;
|
||||
const str = this.format(...args);
|
||||
Logger.emit(LOG_LEVEL.INFO, str);
|
||||
console.info(CliForeground.BLUE + str + CliEffects.CLEAR);
|
||||
}
|
||||
|
||||
warn(...args: string[]) {
|
||||
if(LOG_LEVEL.WARN >= Logger.LOG_LEVEL) {
|
||||
const str = this.format(...args);
|
||||
Logger.emit(LOG_LEVEL.WARN, str);
|
||||
console.warn(CliForeground.YELLOW + str + CliEffects.CLEAR);
|
||||
}
|
||||
if(Logger.LOG_LEVEL > LOG_LEVEL.WARN) return;
|
||||
const str = this.format(...args);
|
||||
Logger.emit(LOG_LEVEL.WARN, str);
|
||||
console.warn(CliForeground.YELLOW + str + CliEffects.CLEAR);
|
||||
}
|
||||
|
||||
error(...args: string[]) {
|
||||
if(Logger.LOG_LEVEL > LOG_LEVEL.ERROR) return;
|
||||
const str = this.format(...args);
|
||||
Logger.emit(LOG_LEVEL.ERROR, str);
|
||||
console.error(CliForeground.RED + str + CliEffects.CLEAR);
|
||||
}
|
||||
}
|
||||
|
@ -16,11 +16,12 @@ export function formEncode(data: any): string {
|
||||
* Get profile image from Gravatar
|
||||
*
|
||||
* @param {string} email Account email address
|
||||
* @param {string} def Default image, can be a link or '404', see: https://docs.gravatar.com/general/images/
|
||||
* @returns {string} Gravatar URL
|
||||
*/
|
||||
export function gravatar(email: string) {
|
||||
export function gravatar(email: string, def='mp') {
|
||||
if(!email) return '';
|
||||
return `https://www.gravatar.com/avatar/${md5(email)}`;
|
||||
return `https://www.gravatar.com/avatar/${md5(email)}?d=${def}`;
|
||||
}
|
||||
|
||||
/** Parts of a URL */
|
||||
|
72
src/redis.ts
72
src/redis.ts
@ -1,72 +0,0 @@
|
||||
// import {createClient, RedisClientType} from 'redis';
|
||||
// import {environment} from '../environments/environment';
|
||||
//
|
||||
// export type RedisKey = string | string[];
|
||||
//
|
||||
// export let Redis!: RedisClientType & {
|
||||
// // get/set shimmed for JSON
|
||||
// jGet: (redisKey: string) => Promise<any>,
|
||||
// jSet: (redisKey: string, obj: any, opts?: any) => Promise<void>,
|
||||
// // hGet/hSet shimmed for objects
|
||||
// oGet: (redisKey: string) => Promise<any>;
|
||||
// oSet: (redisKey: string, obj: any) => Promise<void>,
|
||||
// // Helpers
|
||||
// findKeys: (filter: RedisKey) => Promise<string[]>,
|
||||
// forEach: (filter: RedisKey, cb: (key: string) => any) => Promise<void>,
|
||||
// };
|
||||
//
|
||||
// export async function connectRedis(retry = 3) {
|
||||
// Redis = <any>createClient({
|
||||
// url: `redis://host:port`
|
||||
// });
|
||||
// if(!Redis && retry > 0) {
|
||||
// await connectRedis(retry - 1);
|
||||
// } else if(!!Redis) {
|
||||
// Redis.jGet = async (redisKey: string) => {
|
||||
// const val = await Redis.get(redisKey);
|
||||
// return val ? JSON.parse(val) || val : null;
|
||||
// };
|
||||
// Redis.jSet = (redisKey: string, obj: any, opts?: any) => {
|
||||
// return Redis.set(redisKey, JSON.stringify(obj), opts).then(() => {});
|
||||
// };
|
||||
// Redis.oGet = async (redisKey: string) => {
|
||||
// if(!(await Redis.hLen(redisKey))) return null;
|
||||
// const val = await Redis.hGetAll(redisKey);
|
||||
// Object.entries(val).forEach(([key, v]) => val[key] = JSON.parse(v));
|
||||
// return val;
|
||||
// };
|
||||
// Redis.oSet = (redisKey: string, obj: any) => {
|
||||
// const r = Redis.multi();
|
||||
// Object.entries(obj).forEach(([key, val]) => {
|
||||
// r.hSet(redisKey, key, JSON.stringify(val));
|
||||
// });
|
||||
// return r.exec().then(() => {});
|
||||
// };
|
||||
// Redis.findKeys = async (filter: RedisKey): Promise<string[]> => {
|
||||
// const found: string[] = [];
|
||||
// await Redis.forEach(filter, (key: string) => found.push(key));
|
||||
// return found;
|
||||
// }
|
||||
// Redis.forEach = async (filter: RedisKey, cb: (key: string) => any): Promise<void> => {
|
||||
// for await (const k of Redis.scanIterator({MATCH: createKey(filter)})) {
|
||||
// const rtn = cb(k);
|
||||
// if(rtn instanceof Promise) await rtn;
|
||||
// }
|
||||
// }
|
||||
// await Redis.connect();
|
||||
// }
|
||||
// }
|
||||
//
|
||||
// export function createKey(...keys: (string | string[])[]) {
|
||||
// return keys.flat().map(k => k == null ? '*' : k).join(':');
|
||||
// }
|
||||
//
|
||||
// export function namespacedKey(namespace: string, key: RedisKey): string {
|
||||
// return createKey(namespace, ...(Array.isArray(key) ? key : [key]));
|
||||
// }
|
||||
//
|
||||
// export function nameSpacer(namespace: string) {
|
||||
// return (key: RedisKey) => {
|
||||
// return namespacedKey(namespace, key);
|
||||
// };
|
||||
// }
|
@ -52,11 +52,12 @@ export function insertAt(target: string, str: string, index: number): String {
|
||||
return `${target.slice(0, index)}${str}${target.slice(index + 1)}`;
|
||||
}
|
||||
|
||||
export function pad(text: string, length: number, char: string, start = true) {
|
||||
const l = length - text.length;
|
||||
if(l <= 0) return text;
|
||||
export function pad(text: any, length: number, char: string, start = true) {
|
||||
const t = text.toString();
|
||||
const l = length - t.length;
|
||||
if(l <= 0) return t;
|
||||
const padding = Array(~~(l / char.length)).fill(char).join('');
|
||||
return start ? padding + text : text + padding;
|
||||
return start ? padding + t : t + padding;
|
||||
}
|
||||
|
||||
/**
|
||||
|
Reference in New Issue
Block a user