Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@rbxts/rlog

Package Overview
Dependencies
Maintainers
0
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@rbxts/rlog

Context-based server-side logging solution for ROBLOX projects.

  • 0.8.0
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
1
decreased by-66.67%
Maintainers
0
Weekly downloads
 
Created
Source



rlog


Context-based server-side logging solution for ROBLOX projects.

GitHub release (latest by date) GitHub last commit (branch) GitHub issues GitHub code size in bytes GitHub



Demo

import { rLog } from "@rbxts/rlog";

const logger = new rLog();

logger.debug("User purchase made", {
  user: {
    id: 123,
    purchase: {
      id: 15,
      details: {
        item: "Nuke",
        result: Enum.ProductPurchaseDecision.PurchaseGranted,
        position: new Vector3(10, 15, 20),
        rotation: new CFrame(),
      },
    },
  },
});

ROBLOX console output

Installation

Install rLog with your preferred package manager.

npm

npm install @rbxts/rlog

pnpm

pnpm add @rbxts/rlog

yarn

yarn add @rbxts/rlog

Overview

rLog is a Context-based server-side logging framework for ROBLOX, designed to help organize and structure your logging process.

Utilizing Correlation IDs via rLog's LogContext, you can create logging infrastructure that mirrors more enterprise-like systems; facilitating easier debugging and external auditing.

Documentation

Quick Start

API Reference

Fast Breakdown

Basic Guides

Advanced Guides

Features

Basic Logging

  • Log data to the console according to different severity levels.
  • Utilize tags (or prefixes) for individual logging instances.

Serialization

  • Attach data to your log entries that gets serialized before being sent; ensuring the data is properly visible.
  • Support for deeply nested roblox data types that don't typically translate well (e.g., CFrames).
  • Support for encoding custom classes and functions.
  • Customizable class serialization.

Log Context

  • Attach Correlation IDs to your logs, creating a linkage between logs in individual flows.
  • Differiate between multiple of the same log in the same function.
  • Automatically generate unique IDs when needed.
  • Optionally configure a custom method for providing your own ID generation.
  • Share configuration settings between context consumers, optionally unique to each invocation.
  • Optionally "suspend" logs until they're needed (i.e., a WARNING or ERROR occurs.); facilitating verbose logs for easier debugging without taking up resources until they're needed.

Source Context

  • Attach data to your logs to identify which file the log was sent from.
  • Attach data to your logs to identify what line number in the file the log was sent from.
  • Attach data to your logs to identify which function the log was sent from, or optionally the nearest named function on the stack (in the case of anonymous functions).
  • In the case of anonymous functions, identify the nearest named function from where the log was sent.

Sinks

[!TIP] rLog provides an in-house sink for sending logs to the Google Cloud Logging platform.

Learn more about it by giving the Using rLog with Google Cloud Logging guide a read!

  • Define callbacks that can conditionally decide to filter logs from reaching any output.
  • Define callbacks that can send logs to external services for storage and auditing.
  • Recursively define callbacks through a hierarchy of logger instances and configurations; allowing you to provide callbacks for individual flows.
  • Define dynamic callbacks that change according to arguments (e.g., the player).

Enrichers

  • Define callbacks that can conditionally mutate or add data to logs.
  • Recursively define callbacks through a hierarchy of logger instances and configurations; allowing you to provide callbacks for individual flows.
  • Define dynamic callbacks that change according to arguments (e.g., the type of data being sent).

Configuration

  • Extensive configuration options for toggling various serialization settings, and overriding encoding behavior when needed.
  • Optionally configure the minimum log level that gets output to the console.
  • Optionally provide custom methods for formatting data in the roblox console, or directing how it reaches the console.

Getting Started

So you're ready to get started with rLog!

You can either checkout our Quick Start guide, read through our list of Basic Guides, or jump straight into our API Reference.

[!TIP] If you're already familiar with logging libraries, you can give our Fast Breakdown a read to get a quick overview of what rLog provides, and where it differs from others.

Roadmap

  • Add social preview to github repo after going public
  • Add publishing for wally
  • Add docs for lua usage
  • Separate provided sinks into a sub package
  • Support google cloud console logging
  • Migrate tests to individual files
  • Implement workflow for test coverage
  • Implement tests for provided workflows
  • Implement more refined serialization/assertions lib
  • Add workflow for checking API diff and version bumping according to semver
  • Add note in contributing about checking the api diff

Contributing

If you're interested in contributing to rLog, give the CONTRIBUTING doc a read.

License

Apache 2.0

Keywords

FAQs

Package last updated on 01 Sep 2024

Did you know?

Socket

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
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc