Socket
Socket
Sign inDemoInstall

@open-pioneer/core

Package Overview
Dependencies
0
Maintainers
4
Versions
11
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    @open-pioneer/core

Contains basic utility functions and classes used by the @open-pioneer project.


Version published
Maintainers
4
Install size
51.0 kB
Created

Readme

Source

@open-pioneer/core

This package contains basic utility functions and classes used by the @open-pioneer project.

Events

The package exports the EventEmitter class that supports emitting and subscribing to user defined events.

Errors

The Error class extends JavaScript's global error class with a user defined id value that can be used to explicitly identify error conditions.

import { Error } from "@open-pioneer/core";
throw new Error("my-error:identifier", "This is the error message");

Error also exposes the optional cause attribute that allows nesting of error instances. Note that browser support for that property is still required:

import { Error, getErrorChain } from "@open-pioneer/core";

try {
    someFunctionThatCanThrow();
} catch (e) {
    throw new Error("my-error:higher-level-error-id", "Error text", { cause: e });
}

// getErrorChain gathers the error and all its causes (if any) into an array:
const errors = getErrorChain(error);

Resources

The Resource type exported from this package is used by objects with a destructor. All object needing some cleanup action to be called should use the destroy method for consistency and easier handling.

Logger

The 'Logger' class provides a logger for standardized application wide logging. The log level is configured globally in the vite.config.js.

To create a logger instance, call the createLogger method. It takes a prefix (string) to prepend to each message. Use : as a separator to encode hierarchical names (e.g. "some-package:SomeClass").

The logger provides log methods for the following log levels with the following order: DEBUG < INFO < WARN < ERROR.

For example (as class attribute):

import { createLogger, Logger } from "@open-pioneer/core";

export class LoggerTestExample {
    private logger: Logger;
    constructor() {
        this.logger = createLogger("example-package:LoggerTestExample");
    }

    testMethod() {
        this.logger.warn("example message", { testLog: 123, text: "this is a text" });
    }
}

Or as a shared logger at module scope:

import { createLogger } from "@open-pioneer/core";
const LOG = createLogger("example-package");

License

Apache-2.0 (see LICENSE file)

Keywords

FAQs

Last updated on 11 Mar 2024

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc