npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

queryable-logger

v0.1.2

Published

TypeScript logger that can be queried for log messages.

Downloads

1

Readme

Queryable Logger

TypeScript logger that can be queried for log messages.

npm version npm License

Installation

npm install --save-dev npm-queryable-logger

Usage

import QueryableLogger from 'npm-queryable-logger';

// Initialize a logger instance
const logger = new QueryableLogger();

// Log some messages
logger.log('Hello world!');
logger.warn('This is a warning!');
logger.error('This is an error!');

// Log some advanced messages
logger.log('This is an error!', { foo: 'bar' });
logger.warn('This is a warning!', { foo: 'bar' });
logger.error('This is an error!', ["trace stack 1", "trace stack 2"], 404, { foo: 'bar' }, { baz: 'qux' });

// Query the log messages
let query = logger.select(['id', 'timestamp', 'message', 'foo']).from('warn').where('message', ['LIKE', 'a warning!']);
let result = query.get();

// result = [
//   {
//     id: 2,
//     timestamp: 1667279539356,
//     message: 'This is a warning!',
//     foo: null
//   },
//   {
//     id: 5,
//     timestamp: 1667279539356,
//     message: 'This is a warning!',
//     foo: 'bar'
//   }
// ]

// Save the log message to local storage
const id: string = logger.saveToLocalStore();

// Retrieve an session from local storage
const session: QueryableLogger = QueryableLogger.loadFromLocalStore(id);

// Clear the local storage from logger instances
QueryableLogger.clearLocalStore();

API

QueryableLogger

Constructor

constructor(userDefinedAttrs?: string[], enablePrint: boolean = false);
Parameters

| Name | Type | Description | | --- | --- | --- | | userDefinedAttrs | string[] | User defined attributes that can be logged (currently only used to safe guard reads) | | enablePrint | boolean | Enable printing of log messages to the console |

Methods

log
log(message: string, ...args: Record<string, any>): Log;

Log a message. The message will be printed to the console if enablePrint or displayInfo is set to true in the constructor. The message will be saved to the log store. The message will be returned as a Log object. See Log for more information.

Parameters

| Name | Type | Description | | --- | --- | --- | | message | string | The message to log | | ...args | Record<string, any> | Additional arguments to log |

warn
warn(message: string, ...args: Record<string, any>): Log;

Log a warning message. The message will be printed to the console if enablePrint or displayInfo is set to true in the constructor. The message will be saved to the log store. The message will be returned as a Log object. See Log for more information.

Parameters

| Name | Type | Description | | --- | --- | --- | | message | string | The message to log | | ...args | Record<string, any> | Additional arguments to log |

error
error(message: string, trace: string[] = [], errorCode: number = 400, ...args: Record<string, any>[]): Log {

Log an error message. The message will be printed to the console if enablePrint or displayInfo is set to true in the constructor. The message will be saved to the log store. The message will be returned as a Log object. See Log for more information. Error messages may optionally have a trace stack, an error code, and additional arguments. Errors have a defaulted paramater resolved = False that can be set to true if the error has been resolved.

Parameters

| Name | Type | Description | | --- | --- | --- | | message | string | The message to log | | trace | string[] | The trace stack | | errorCode | number | The error code | | ...args | Record<string, any> | Additional arguments to log |

getLog
getLog(id: number): Log;

Get a log message by its id.

Parameters

| Name | Type | Description | | --- | --- | --- | | id | number | The id of the log message |

getLogs
getLogs(): Log[];

Get all log messages.

getInfo
getInfo(): Log[];

Get all info messages.

getWarn
getWarn(): Log[];

Get all warning messages.

getError
getError(): Log[];

Get all error messages.

resolveError
resolveError(id: number): Log;

Sets an error log message to resolved.

Parameters

| Name | Type | Description | | --- | --- | --- | | id | number | The id of the log message |

resolveAllErrors
resolveAllErrors(): Log[];

Sets all error log messages to resolved.

clearLogs
clearLogs(): void;

Clears all log messages.

clearErrors
clearErrors(): void;

Clears all error messages.

clearWarnings
clearWarnings(): void;
clearInfo
clearInfo(): void;

Clears all info messages.

displayLogs
displayLogs(): void;

Prints all log messages to the console using console.table.

displayErrors
displayErrors(): void;

Prints all error messages to the console using console.table.

displayWarnings
displayWarnings(): void;

Prints all warning messages to the console using console.table.

displayInfo
displayInfo(): void;

Prints all info messages to the console using console.table.

downloadJSON
downloadJSON(): void;

Downloads the log messages as a JSON file. This is only supported in browsers.

getJSON
getJSON(): string;

Returns a JSON string of the log messages.

getCSV
getCSV(logs: Logs[] = this.logs): string;

Returns a CSV string of the log messages with columns id, message, timestamp, datetime, userDefinedAttrs.

Parameters

| Name | Type | Description | | --- | --- | --- | | logs | Logs[] | The log messages to format as csv |

downloadCSV
downloadCSV(logs: Logs[] = this.logs): void;

Downloads the log messages as a CSV file. This is only supported in browsers.

Parameters

| Name | Type | Description | | --- | --- | --- | | logs | Logs[] | The log messages to download |

saveToLocalStore
saveToLocalStore(): number;

Saves the log messages to local storage. Returns the id of the log messages. All log messages are saved to local storage with the key QueryableLoggerNPM-{id}.

loadFromLocalStore
static loadFromLocalStore(id: number): QueryableLogger | null;

Loads the log messages from local storage. Returns a QueryableLogger object. Returns null if the log messages are not found.

Parameters

| Name | Type | Description | | --- | --- | --- | | id | number | The id of the log messages |

clearLocalStore
static clearLocalStore(id?: number): void;

Clears the log messages from local storage. If no id is provided, all log messages are cleared.

Parameters

| Name | Type | Description | | --- | --- | --- | | id | number (optional) | The id of the log messages |

overrideLogs
overrideLogs(logs: Log[]): void;

Overrides the log messages with the provided log messages.

Parameters

| Name | Type | Description | | --- | --- | --- | | logs | Log[] | The log messages to override |

select
select(columns: string[] = ['id', 'message', 'type', 'timestamp', 'userDefinedAttrs']): LoggerQueryContainer;

Selects the columns to display in the console table. The default columns are id, message, type, timestamp, and userDefinedAttrs. Every query must start with a select.

Parameters

| Name | Type | Description | | --- | --- | --- | | columns | string[] | The columns to select |

from
static from(selected: Log[], type = "all" || "error" || "warn" || "log"): Log[];

Selects the type of log messages to query. The default type is all. The type can be all, error, warn, or log. This method is not meant to be called directly. It is called by the LoggerQueryContainer class.

Parameters

| Name | Type | Description | | --- | --- | --- | | selected | Log[] | The log messages to query | | type | string | The type of log messages to query |

where
static where(selected: Log[], key: string, value: (string | number)[]): Log[];

Filters the log messages by the provided key and value. This method is not meant to be called directly. It is called by the LoggerQueryContainer class.

Parameters

| Name | Type | Description | | --- | --- | --- | | selected | Log[] | The log messages to query | | key | string | The key to filter by | | value | (string \| number)[] | The value to filter by (e.g. ('key', ['LIKE', 'value']) |

LoggerQueryContainer.get()
get(): Log[];

Returns the log messages after the query has been executed. This method must be called at the end of the query, although it is not part of the QueryableLogger class. This method is not a child of the QueryableLogger class.

setDisplayLogs
setDisplayLogs(object: Record<string, boolean>) {

Overrides default behaviour of issuing console calls on the use of log, warn, and error.

Parameters

| Name | Type | Description | | --- | --- | --- | | object | Record<string, boolean> | An object with keys log, warn, and error |

object example
{
    "displayLogs": true,
    "displayErrors": true,
    "displayWarnings": true,
    "displayInfos": true,
    "displayResolvedErrors": true,
    "displayUnresolvedErrors": true,
}

LoggerQueryContainer

The LoggerQueryContainer class is used to build queries. It is not meant to be used directly. It is used by the QueryableLogger class. When a query is initiated using the QueryableLogger.select method, a LoggerQueryContainer object is returned. The LoggerQueryContainer object has the following methods:

from
from(type = "all" || "error" || "warn" || "log"): LoggerQueryContainer;

Delegates execution to QueryableLogger.from and wraps the result in a LoggerQueryContainer object.

Parameters

| Name | Type | Description | | --- | --- | --- | | type | string | The type of log messages to query |

where
where(key: string, value: (string | number)[]): LoggerQueryContainer;

Delegates execution to QueryableLogger.where and wraps the result in a LoggerQueryContainer object.

Parameters

| Name | Type | Description | | --- | --- | --- | | key | string | The key to filter by | | value | (string \| number)[] | The value to filter by (e.g. ('key', ['LIKE', 'value']) |

get
get(): Log[];

Uses columns from QueryableLogger.select() to filter the generated result and return the result as an array of Log objects.

Log

Log is an algebriac datatype that represents a log message. It groups log messages into three categories: info, warn, error. It has the following definition:

type Log = LogError | LogWarning | LogInfo;

LogMessage

LogMessage is a data interface that represents information shared by LogError, LogWarning, and LogInfo. It has the following definition:

interface LogMessage {
    id: number;
    message: string;
    type: "info" | "warn" | "error";
    timestamp: number;
    datetime: string;
    userDefinedAttrs: Record<string, any>;
}

Paramaters for LogMessage

| Name | Type | Description | | --- | --- | --- | | id | number | The id of the log message | | message | string | The message of the log message | | type | "info" \| "warn" \| "error" | The type of the log message | | timestamp | number | The timestamp of the log message | | datetime | string | The ISO representation of the timestamp |

LogError

LogError is a data interface that represents an error log message. It defines additional special paramaters to the error message. It has the following definition:

interface LogError extends LogMessage {
    type: "error";
    trace: string[];
    resolved: boolean;
    errorCode: number;
}

Paramaters for LogError

| Name | Type | Description | | --- | --- | --- | | trace | string[] | The stack trace of the error | | resolved | boolean | Whether the error has been resolved | | errorCode | number | The error code of the error |

LogWarning

LogWarning is a data interface that represents a warning log message. It has the following definition:

interface LogWarning extends LogMessage {
    type: "warn";
}

LogInfo

LogInfo is a data interface that represents an info log message. It has the following definition:

interface LogInfo extends LogMessage {
    type: "info";
}

Future Work

  • [ ] Add support for indexing and index stores
  • [ ] Add support for custom loggers

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

Authors and acknowledgment

Project status

This project is currently in development.

Contact

License

MIT