Comparing version 1.4.2 to 2.0.1
{ | ||
"name": "zaq", | ||
"version": "1.4.2", | ||
"version": "2.0.1", | ||
"description": "Yet another fun little logging utility.", | ||
"main": "zaq.js", | ||
"scripts": { | ||
"test": "node test.js" | ||
"test": "node tests/main.js" | ||
}, | ||
@@ -9,0 +9,0 @@ "repository": { |
345
README.md
@@ -5,43 +5,346 @@ # zaq | ||
Have you met `zaq`? He's based on practicality and performance. What are you doing? *Shake his hand!* | ||
Have you met `zaq`? He's all about practicality and style. What are you doing? *Shake his hand!* | ||
License: **MIT** | ||
## Installation | ||
You know the drill. Install via NPM: | ||
```bash | ||
``` | ||
npm install zaq | ||
``` | ||
Require in your Node project: | ||
(or Yarn, if you, too, are a hipster): | ||
``` | ||
yarn add zaq | ||
``` | ||
Require in your Node based project: | ||
```js | ||
var zaq = require('zaq'); | ||
``` | ||
data:image/s3,"s3://crabby-images/87cbb/87cbb4205a2f4c396d438ef12aa43cbd65dcb8de" alt="Zaq Demo" | ||
data:image/s3,"s3://crabby-images/6340a/6340af03d8592a13c6a4a72a2b530fbdb273d532" alt="Zaq Demo" | ||
## Logging API | ||
--- | ||
### `.log( message )` | ||
Pass a `message` to `zaq.log()` to have it printed to the console. *Yes, this is an alias of `console.log()`.* | ||
## Basic Usage | ||
- Logging namespaces can be easily implemented, using `zaq.as('MyNamespace')`. See `zaq.as()` details below. | ||
- `zaq` logging functions are chainable, since each logging function returns its parent `zaq` instance. | ||
- *Loggable objects* passed after the *message* are rendered in "pretty print" so you can easily visually grep for meaningful bits. Pass as many objects as you want as additional arguments to any `zaq` logging function. | ||
### `.win( message )` | ||
Pass a success `message` to `zaq.win()` to display it in the win/success style: following a green checkmark and 'WIN:' prefix. | ||
### `.err( message )` | ||
Pass an error `message` to `zaq.err()` to display it in the error style: following a red 'X' and 'ERR:' prefix. | ||
## Log Levels | ||
### `.info( message )` | ||
Pass an informational `message` to `zaq.info()` to display it in the info style: following a blue arrow and 'INFO:' prefix. | ||
|Level|Level Name|Methods At This Level| | ||
|:---|:---|:---| | ||
|0|`debug`|`zaq.debug`| | ||
|1|`info`|`zaq.info`, `zaq.ok`, `zaq.flag`, `zaq.time`, `zaq.divider`| | ||
|2|`warn`|`zaq.warn`| | ||
|3|`error`|`zaq.err`| | ||
|4|`fatal`|`zaq.fatal`| | ||
### `.warn( message )` | ||
Pass a warning `message` to `zaq.warn()` to display it in the warning style: following a yellow hash and 'WARN:' prefix. | ||
### `.time( message )` | ||
Pass a timing `message` to `zaq.time()` to display it in the timing style: following a grey diamond and 'TIME:' prefix. | ||
### Logging Styles/Functions | ||
Use the following `zaq` methods to log info from your app in more meaningful ways. Each logging "style" has an associated prefix, color, and logging level. In basic usage (i.e. purely logging to the transient console), logging level does not have any impact, but when you leverage `zaq.use()`, you can divert messages of specific levels to different recipients (resembling a simple messaging platform). More info on `zaq.use` can be found below. | ||
### `.pretty( obj )` | ||
Pass an `array` or `object` to `zaq.pretty()` to get returned a `JSON.stringify()` string version that's properly spaced and indented. Used internally for `.json()` calls. | ||
### `zaq.ok(message[, ...loggables])` | ||
Prints a message and any additional "loggable" values in the "OK" style, indicating successful operations. | ||
#### ...and much more to be documented. | ||
**Color**: `green` | ||
**Log Level**: `1: info` | ||
**Example:** | ||
```js | ||
const zaq = require('zaq'); | ||
zaq.ok('Successfully completed task.', { | ||
detail: 'someDetail', | ||
executionTime: 1200, | ||
sessionId: 'someSessionId_10101010' | ||
}); | ||
``` | ||
data:image/s3,"s3://crabby-images/f7063/f7063bdb071e14140bbdc19a68764a0acd7e2052" alt="Example zaq.ok() result" | ||
### `zaq.err(message[, ...loggables])` | ||
Prints a message and any additional "loggable" values in the "ERR" style, indicating an error encountered. | ||
**Color**: `red` | ||
**Log Level**: `3: error` | ||
**Example:** | ||
```js | ||
const zaq = require('zaq'); | ||
zaq.err('Failed to do a thing!', { | ||
detail: 'someDetail', | ||
executionTime: 1200, | ||
sessionId: 'someSessionId_10101010' | ||
}); | ||
``` | ||
data:image/s3,"s3://crabby-images/a6731/a6731fa2ad832e3e81ac343eea3446fdaa69ec86" alt="Example zaq.err() result" | ||
### `zaq.fatal(message[, ...loggables])` | ||
Prints a message and any additional "loggable" values in the "FATAL" style, indicating a fatal exception. Similar to the `err` level, but with a higher log level severity (for potentially diverting messages to a developer's inbox, etc.). | ||
**Color**: `red` | ||
**Log Level**: `4: fatal` | ||
**Example:** | ||
```js | ||
const zaq = require('zaq'); | ||
zaq.fatal('Universe-ending exception encountered.', { | ||
detail: 'someDetail', | ||
executionTime: 1200, | ||
sessionId: 'someSessionId_10101010' | ||
}); | ||
``` | ||
data:image/s3,"s3://crabby-images/bd094/bd094edd29703bab6844777b9102f27bcbe978ea" alt="Example zaq.fatal() result" | ||
### `zaq.info(message[, ...loggables])` | ||
Prints a message and any additional "loggable" values in the "INFO" style, indicating situation-neutral general information. | ||
**Color**: `blue` | ||
**Log Level**: `1: info` | ||
**Example:** | ||
```js | ||
const zaq = require('zaq'); | ||
zaq.info('Neutral information, always nice:', { | ||
detail: 'someDetail', | ||
executionTime: 1200, | ||
sessionId: 'someSessionId_10101010' | ||
}); | ||
``` | ||
data:image/s3,"s3://crabby-images/68e5f/68e5f4d8f4347119848658edaaaedee773f3a676" alt="Example zaq.info() result" | ||
### `zaq.warn(message[, ...loggables])` | ||
Prints a message and any additional "loggable" values in the "INFO" style, indicating situation-neutral general information. | ||
**Color**: `yellow` | ||
**Log Level**: `2: warn` | ||
**Example:** | ||
```js | ||
const zaq = require('zaq'); | ||
zaq.warn('Attempted to do bad thing...:', { | ||
detail: 'someDetail', | ||
executionTime: 1200, | ||
sessionId: 'someSessionId_10101010' | ||
}); | ||
``` | ||
data:image/s3,"s3://crabby-images/e69dd/e69ddc9facaf7bfed1654b20befb8b232ffa64b5" alt="Example zaq.warn() result" | ||
### `zaq.flag(message[, ...loggables])` | ||
Prints a message and any additional "loggable" values in the "FLAG" style, indicating neutral yet high-profile information. | ||
**Color**: `magenta` | ||
**Log Level**: `1: info` | ||
**Example:** | ||
```js | ||
const zaq = require('zaq'); | ||
zaq.flag('Something you should know.', { | ||
detail: 'someDetail', | ||
executionTime: 1200, | ||
sessionId: 'someSessionId_10101010' | ||
}); | ||
``` | ||
data:image/s3,"s3://crabby-images/66642/666426ccb27b6d4609b8c42fb6fbbb764760250a" alt="Example zaq.flag() result" | ||
### `zaq.debug(message[, ...loggables])` | ||
Prints a message and any additional "loggable" values in the "DEBUG" style, indicating potentially low-level developer-to-developer information for debugging purposes. | ||
**Color**: `cyan` | ||
**Log Level**: `0: debug` | ||
**Example:** | ||
```js | ||
const zaq = require('zaq'); | ||
zaq.debug('Something you should know.', { | ||
detail: 'someDetail', | ||
executionTime: 1200, | ||
sessionId: 'someSessionId_10101010' | ||
}); | ||
``` | ||
data:image/s3,"s3://crabby-images/44990/44990a29568154a11930c6de8f5ea3241f1cff02" alt="Example zaq.debug() result" | ||
### `zaq.time(message[, ...loggables])` | ||
Prints a message and any additional "loggable" values in the "TIME" style, indicating temporally-related information. | ||
**Color**: `grey` | ||
**Log Level**: `1: info` | ||
**Example:** | ||
```js | ||
const zaq = require('zaq'); | ||
zaq.time('MyProcess consumed ' + some_duration + 'ms compute time', { | ||
start: some_start_time, | ||
end: some_end_time | ||
}); | ||
``` | ||
data:image/s3,"s3://crabby-images/0ba25/0ba251e96a3605ece438cde04ffa50a13cf8ad10" alt="Example zaq.time() result" | ||
--- | ||
## Other functionality | ||
### `zaq.divider(dividerText[, options])` | ||
Prints a "divider"-style line for better visual separation in your logs. Automatically fills the width of the present console process. Accepts several options: | ||
|Option Key|Accepted Values|Default Value|Info| | ||
|:---|:---|:---|:---| | ||
|`centered`|`true` or `false`|`false`|"Centers" the divider text when `true`| | ||
|`space`|Integers|0|Number of empty line-breaks to pad before and after the divider| | ||
|`lineSymbol`|A String|`'-'`|Character to repeat to render the divider "line". Can be multiple characters or an empty space.| | ||
|`lineColor`|A valid `chalk` color string.||Uses `chalk` to render the divider "line" in a given color.| | ||
**Log Level**: `1: info` | ||
**Example:** | ||
```js | ||
const zaq = require('zaq'); | ||
zaq | ||
.flag('Pre-divider text') | ||
.divider('Cool Divider Text', { lineColor: 'magenta', space: 1, centered: true }) | ||
.flag('Post-divider text'); | ||
``` | ||
data:image/s3,"s3://crabby-images/d9ba0/d9ba02611fa7da5bd9bf8767eb1131b1863891da" alt="Example zaq.divider() result" | ||
### `zaq.weight(filepath)` | ||
Gets the 'weight' (size in KB) of the file at a given path. Logs the filesize using `zaq.info`. | ||
**Color**: `blue` | ||
**Log Level**: `1: info` | ||
**Example:** | ||
```js | ||
const zaq = require('zaq'); | ||
zaq.weight('./weight.js'); | ||
``` | ||
data:image/s3,"s3://crabby-images/9321c/9321c84ea8914238e3dab8010eb5723c77f878d3" alt="Example zaq.time() result" | ||
## Usability | ||
### `zaq.as(namespace)` | ||
Returns a new instance of `zaq` wherein all log messages will be prefixed with the given `namespace` name. `namespace` can take the form of a string, number, or object (on which `toString` will be called for serialized identification, so be careful!). | ||
`zaq` instances are managed globally. This means that you can say `const zaq = require('zaq').as('MyModule')` in two different files, but both `zaq` *references* will actually refer to the same *instance*. | ||
**Example:** | ||
```js | ||
const fooZaq = require('zaq').as('Foo'); | ||
const barZaq = require('zaq').as('Bar_Module'); | ||
fooZaq.info('Some Information from Clone A.'); | ||
barZaq.info('Some Differing Information from Clone B.'); | ||
``` | ||
data:image/s3,"s3://crabby-images/68bd5/68bd511679d1bff70901618cde2d355be7399cb0" alt="Example zaq.as() result" | ||
### `zaq.use(handlerConfig)` | ||
Registers a message/log handler with `zaq`. | ||
**Returns a numerical index which can be passed to `zaq.dispose()` afterward to remove/disable the handler.** | ||
A `handlerConfig` looks like this: | ||
```js | ||
{ | ||
handler: function someHandlerFunction (logMessage) { | ||
// logMessage is the complete "message" string, including | ||
// prefixes, namespaces, whitespace, and ASCII color | ||
// codes (unless { stripColors: true } is given) | ||
// e.g., | ||
// "[Foo] → INFO: Some Information from Clone A." | ||
doSomethingWith(logMessage); | ||
}, | ||
options: { | ||
logLevel: 1, | ||
stripColors: true | ||
} | ||
} | ||
``` | ||
The following options are accepted. All options are optional. | ||
|Option Key|Accepted Values|Default Value|Info| | ||
|:---|:---|:---|:---| | ||
|`logLevel`|Integers 0-4|0|Only log messages of the given level or higher are passed to the handler. For instance, a value of `1` will prevent the handler from ever receiving `debug`-level messages. See the table above for more information about log levels. | ||
|`acceptLevels`|A single level string of an array of log level names.||When given, only messages with a log level contained in this array are passed to the handler. For example, `{ acceptLevels: 'debug' }` would allow the handler function to only receive `debug`-level messages. **Note: log messages must meet the criteria of both `acceptLevels` AND `logLevel` if both are provided.** (E.g., `{ logLevel: 3, acceptLevels: ['debug']}` will never handle any messages.)| | ||
|`stripColors`|`true` or `false`|`false`|When `true`, all ASCII-based color codes are stripped from the output. Useful when writing log messages somewhere other than a standard terminal (like a plaintext file, for instance).| | ||
|`timestamps`|`true` or `false`|`false`|When `true`, simple timestamps are prepended to logging messages. Especially useful when persisting logs to any sort of storage. | ||
**Example:** | ||
```js | ||
const zaq = require('zaq').as('MyService'); | ||
// ( ... ) | ||
function persistentLoggerFn (logMessage) { | ||
addMessageToWriteBuffer(logMessage); | ||
} | ||
function fatalErrorHandler (fatalMessage) { | ||
dispatchMidnightEmail({ | ||
to: 'sleepingDev@website.com', | ||
message: fatalMessage | ||
}); | ||
} | ||
const persistentHandler = zaq.use(persistentLoggerFn, { timestamps: true, stripColors: true, logLevel: 1 }); | ||
const fatalHandler = zaq.use(fatalErrorHandler, { timestamps: true, stripColors: logLevel: 4 } ); | ||
// ( ... ) | ||
zaq.warn('User email duplicate detected.', { user }); | ||
// ^ This message is a warning (level 2), so it will hit "persistentLoggerFn", | ||
// which passes on the message to some disk write operation. | ||
zaq.fatal('Failed to reconnect to DB Interface.', { dbResponse }); | ||
// ^ This message is a fatal error (level 4), so it will hit both "persistentLoggerFn" | ||
// AND "fatalErrorHandler", which will send an email to our poor sleeping dev | ||
// with the message content like this (truncated): | ||
// | ||
// 3/16/2018 11:52:14 PM [MyService] ✖ FATAL: Failed to reconnect to DB Interface. | ||
// 3/16/2018 11:52:14 PM [MyService] >>>> { | ||
// 3/16/2018 11:52:14 PM [MyService] :::: "dbResponse": [...] | ||
// ... | ||
``` | ||
### `zaq.dispose(handlerIndex)` | ||
Deletes the handler & options associated with the given **`handlerIndex`, which is originally given as the return value of `zaq.use`**. | ||
**Example:** | ||
```js | ||
// --> continued from previous example | ||
// ( ... ) | ||
if (siteIsNoLongerLive()) { | ||
zaq.dispose(fatalHandler); | ||
} | ||
// ( ... ) | ||
zaq.fatal('Oh no, the servers are on fire again.', request, { serverFireStats }); | ||
// ^ Since we disposed of the "fatalHandler" due to some site going offline, | ||
// this fatal error will be logged using "persistentLoggerFn", but will NOT | ||
// trigger a 3 AM email to our sleeping dev. Rejoice! | ||
``` |
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
30
326
350
575850
1