7.15.96 • Published 12 months ago

@taktikorg/velit-nobis-blanditiis v7.15.96

Weekly downloads
-
License
MIT
Repository
github
Last release
12 months ago

fran-logging

Fran logger is a simple logging with an easy configuration. Supports level based filtering and tagging that keeps your logs readable and uncluttered!

Simple Features

  • Small footprint, around 500 bytes
  • Filter by level, ERROR > WARN > INFO > TRACE > DEBUG
  • Filter by tag, 'security' | 'anything'

Install

npm install fran-logging

Initialize

Tags typically refer to a subsystem or component like 'security' or FooBar.name. When fran-logging is initialized, tags can be assigned a level. A message is logged when its level is greater than or equal to its tag's assigned level.

import { log, LogLevel } from 'fran-logging';
import chalk from 'chalk';

// handler which does the logging to the console or anything
const logger = {
  [LogLevel.ERROR]: (tag, msg, params) => console.error(`[${chalk.red(tag)}]`, msg, ...params),
  [LogLevel.WARN]: (tag, msg, params) => console.warn(`[${chalk.yellow(tag)}]`, msg, ...params),
  [LogLevel.INFO]: (tag, msg, params) => console.log(`[${chalk.brightGreen(tag)}]`, msg, ...params),
  [LogLevel.TRACE]: (tag, msg, params) => console.log(`[${chalk.cyan(tag)}]`, msg, ...params),
  [LogLevel.DEBUG]: (tag, msg, params) => console.log(`[${chalk.magenta(tag)}]`, msg, ...params),
} as Record<LogLevel, (tag: string, msg: unknown, params: unknown[]) => void>;

/**
 * initialize fran-logging
 * @param config JSON which assigns tags levels. An uninitialized,
 *    tag's level defaults to DEBUG.
 * @param callback? handle logging whichever way works best for you
 */
log.init({ transporter: 'INFO', security: 'ERROR', system: 'OFF' }, (level, tag, msg, params) => {
  logger[level as keyof typeof logger](tag, msg, params);
});

Usage

import { log, tag } from 'fran-logging';

// the imported value "tag" is populated with YOUR tags!
log.error(tag.security, 'not authorized', statusCode);

// but if you prefer simply use strings
log.warn('transporter', 'Evil twin detected!');

// filtered since security's log level ERROR is greater than INFO
log.info(tag.security, 'login successful');

// trace
log.trace(tag.system, 'entering engine room');

// debug
log.debug(tag.system, { warpFactor, starDate });

// also filtered since system's level is OFF
log.error(tag.system, 'eject the warp core', error);

// updates tag levels on the fly
log.init({ loader: 'ERROR', system: 'INFO' });

// disable logging by clearing the callback
log.init();

Advanced Usage

Create an instance with its own tags and callback.

import { Log, tag } from 'fran-logging';

const myLog = new Log().init(
  { loader: 'INFO', security: 'ERROR' },
  (level, tag, msg, params) => {
    console.log(`${level}: [${tag}] `, msg, ...params);
});

myLog.info(tag.security, 'login successful');
removeflagsbddhooksworkflowdefinetrimkeyqueueMicrotaskparserglacierdeep-copycopyRxuninstalldeepcloneswfiteratorsetIteratortypedarraySymbol.toStringTagformattingstreams2Uint16Arrayavamatchnames$.extendbrowserlistcircularzeroshebangnamees2018wraputilitykarmathrottleES2020characterjsxmixinsES5ratelimitmatchAllresolvesequenceprefixtermfast-copycallboundSetES2017querytc39package managerbootstrap cssURLSearchParamssetterespreeprotocol-bufferspromisegdprreducerrangeerrorless.jswatchingmapArrayrateReactiveExtensionsupprotohas-ownchromiumdeepcopyRFC-6455fetchdropenumerableES7private datalazymkdirsstructuredClonecss lessCSSStyleDeclarationwidthsimpledbmodulessymbolsconcurrencygetOwnPropertyDescriptorpnpm9persistentroutemkdirpcompilerArray.prototype.filtersesnegative zeroarraydescriptionconsumewalkrapidbyteLengthworkerObjectmake dirdebuggeriterate_.extendObject.definePropertytostringtagreactchinesetypeerrortypedarraysparentssetPrototypeOffseventspicomatchstyleregular expressionsuperstructReflect.getPrototypeOflrueventDispatcherquotei18ncommandECMAScript 5string.envfunctionbcryptextrarobustnested csspackagesjsonworkspace:*censorcall-bindemitvariables in cssdynamodbarttoolkitconcatMap@@toStringTagmergetouchclass-validatordotenvsome__proto__viewtddjsquerystringredirectcolourttyoncehasOwnPropertywatchFilegroupdom-testing-libraryES2021preprocessorECMAScript 3lesscssemojinpmTypeScriptUint32ArrayclientshamtypedqueuecodesshimpostcssamazonECMAScript 7typeofPushstreamsbeanstalkfscloudwatchpropertywafArray.prototype.flattennumberebsweakmapspeedstylingfastdescriptorspackagelinkhardlinkscloudformationdirectorykoreanimportloginstallerES2018schemeeslintpluginobjectString.prototype.matchAllinvariantobjbyteOffsetdataviewcolormimetypesPromiseargumentperformantqsincludesparentvisualserializeenderESECMAScript 2017escompareHyBischeme-validationcompile lesspropgraphqlObject.fromEntriesschemaflagsearchstatelesscliinputminimalcallbacknodeines7breakajaxpositiveframeworkprettyaccessibilitywarningarraybufferansiduplextoSortedArrayBufferpromisespathlimitedbundlingsameValueZerofastcopyhookformtoArraytapstarterenvformsuperagentwhatwgajvisConcatSpreadablehelpersdomrecursivephonecreatestringifiersyntaxproxylibphonenumberInt16ArraynodejsReactiveXgettrimStartes-abstractArray.prototype.flatMaphashgetPrototypeOfassertfile
@taktikorg/ab-laudantium@taktikorg/accusantium-cum@taktikorg/ad-id@taktikorg/accusamus-quod-debitis@taktikorg/accusantium-possimus@taktikorg/adipisci-quia@taktikorg/ad-ipsa@taktikorg/asperiores-distinctio@taktikorg/asperiores-doloribus@taktikorg/ab-deserunt@taktikorg/alias-asperiores-non@taktikorg/aliquid-rerum-voluptate@taktikorg/alias-suscipit@taktikorg/architecto-nobis@taktikorg/aperiam-iure@taktikorg/amet-dolore-eius@taktikorg/amet-odio@taktikorg/animi-nihil@taktikorg/aperiam-dolores-dolor@taktikorg/amet-hic-culpa@taktikorg/atque-repudiandae@taktikorg/atque-tempore-provident@taktikorg/aspernatur-dolorem@taktikorg/saepe-culpa-pariatur@taktikorg/rerum-quod@taktikorg/sapiente-officiis@taktikorg/soluta-dolores-exercitationem@taktikorg/sunt-nulla-ad@taktikorg/sunt-velit@taktikorg/tenetur-et-modi@taktikorg/tenetur-incidunt-minus@taktikorg/vel-illo@taktikorg/vel-deleniti@taktikorg/voluptate-vitae-aspernatur@taktikorg/sapiente-cupiditate@taktikorg/similique-adipisci@taktikorg/similique-porro-et@taktikorg/sit-maiores@taktikorg/sit-ut@taktikorg/sint-sequi-velit@taktikorg/temporibus-iure@taktikorg/vel-nihil-aliquam@taktikorg/sed-cupiditate-vero@taktikorg/suscipit-nesciunt-itaque@taktikorg/tempore-occaecati@taktikorg/veritatis-laboriosam@taktikorg/velit-perspiciatis@taktikorg/vitae-a@taktikorg/veritatis-officia@taktikorg/voluptatibus-error@taktikorg/voluptatem-pariatur-tenetur@taktikorg/voluptatem-nostrum@taktikorg/voluptatibus-dolor@taktikorg/voluptates-quo@taktikorg/voluptatem-nesciunt@taktikorg/dolorem-ducimus@taktikorg/dolores-recusandae-excepturi@taktikorg/dolores-totam@taktikorg/doloribus-quos@taktikorg/dolorum-assumenda@taktikorg/esse-totam@taktikorg/esse-nihil@taktikorg/eum-debitis-fugiat@taktikorg/eveniet-ipsum@taktikorg/facilis-itaque-ut@taktikorg/facere-nemo-enim@taktikorg/fuga-inventore@taktikorg/illo-excepturi-at@taktikorg/natus-enim-non@taktikorg/nemo-magnam@taktikorg/necessitatibus-sunt@taktikorg/natus-fugit@taktikorg/natus-officiis@taktikorg/nihil-itaque-nesciunt@taktikorg/quae-dolorem-eum@taktikorg/quae-ab@taktikorg/quaerat-nulla-nesciunt@taktikorg/quas-eveniet-explicabo@taktikorg/quisquam-temporibus@taktikorg/cumque-repudiandae-veritatis@taktikorg/eos-iure@taktikorg/eos-asperiores@taktikorg/exercitationem-quae-recusandae@taktikorg/expedita-assumenda-temporibus@taktikorg/expedita-corporis@taktikorg/excepturi-neque@taktikorg/exercitationem-deserunt@taktikorg/ex-voluptatibus@taktikorg/id-adipisci@taktikorg/harum-reprehenderit-perferendis@taktikorg/hic-officia@taktikorg/harum-eum@taktikorg/illum-molestiae-placeat@taktikorg/ipsum-magni@taktikorg/ipsum-aperiam@taktikorg/iste-doloremque-a@taktikorg/ipsa-voluptatibus@taktikorg/ipsa-totam-aperiam@taktikorg/perspiciatis-iste@taktikorg/qui-tempore
4.11.58

1 year ago

7.14.89

1 year ago

7.14.88

1 year ago

4.11.59

1 year ago

7.14.87

1 year ago

7.14.86

1 year ago

7.14.85

1 year ago

3.7.39

1 year ago

7.14.84

1 year ago

7.14.83

1 year ago

7.14.82

1 year ago

7.14.81

1 year ago

7.14.80

1 year ago

3.5.25

1 year ago

3.5.24

1 year ago

3.7.42

1 year ago

3.7.43

1 year ago

3.5.29

1 year ago

3.5.28

1 year ago

3.5.27

1 year ago

3.5.26

1 year ago

3.7.40

1 year ago

3.7.41

1 year ago

6.13.71

1 year ago

6.13.72

1 year ago

4.9.51

1 year ago

6.13.70

1 year ago

4.9.50

1 year ago

4.9.53

1 year ago

4.9.52

1 year ago

4.9.55

1 year ago

4.9.54

1 year ago

4.9.57

1 year ago

2.4.18

1 year ago

4.9.56

1 year ago

2.4.19

1 year ago

6.13.75

1 year ago

6.13.73

1 year ago

6.13.74

1 year ago

4.10.57

1 year ago

4.10.58

1 year ago

7.14.94

12 months ago

6.13.68

1 year ago

7.14.93

12 months ago

6.13.69

1 year ago

7.14.92

12 months ago

6.13.66

1 year ago

4.9.48

1 year ago

7.14.91

1 year ago

6.13.67

1 year ago

7.14.90

1 year ago

6.13.64

1 year ago

6.13.65

1 year ago

4.9.49

1 year ago

6.13.62

1 year ago

6.13.63

1 year ago

1.4.13

1 year ago

2.4.20

1 year ago

1.4.12

1 year ago

1.4.15

1 year ago

1.4.14

1 year ago

1.4.17

1 year ago

1.4.16

1 year ago

1.4.18

1 year ago

7.13.79

1 year ago

7.13.78

1 year ago

7.13.77

1 year ago

7.13.76

1 year ago

7.13.75

1 year ago

7.15.96

12 months ago

7.15.95

12 months ago

7.15.94

12 months ago

4.12.61

1 year ago

4.12.60

1 year ago

3.6.37

1 year ago

3.6.36

1 year ago

3.6.35

1 year ago

5.12.61

1 year ago

3.6.34

1 year ago

4.12.59

1 year ago

3.6.33

1 year ago

3.6.32

1 year ago

3.6.31

1 year ago

3.6.39

1 year ago

3.6.38

1 year ago

4.7.43

1 year ago

4.7.44

1 year ago

3.5.31

1 year ago

3.5.30

1 year ago

4.8.45

1 year ago

4.8.44

1 year ago

4.8.47

1 year ago

4.8.46

1 year ago

4.8.48

1 year ago

6.12.61

1 year ago

6.12.62

1 year ago

2.5.21

1 year ago

2.5.22

1 year ago

2.5.23

1 year ago

2.5.24

1 year ago

2.5.20

1 year ago

7.13.80

1 year ago

1.3.12

1 year ago

1.2.9

1 year ago

1.3.11

1 year ago

1.2.10

1 year ago

1.2.11

1 year ago

1.2.8

1 year ago

1.1.8

1 year ago

1.1.7

1 year ago

1.1.6

1 year ago

1.1.5

1 year ago

1.1.4

1 year ago

1.0.4

1 year ago

1.0.3

1 year ago

1.0.2

1 year ago

1.0.1

1 year ago

1.0.0

1 year ago