New Research: Supply Chain Attack on Axios Pulls Malicious Dependency from npm.Details →
Socket
Book a DemoSign in
Socket

bufferfy

Package Overview
Dependencies
Maintainers
1
Versions
43
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

bufferfy

Fast and efficient buffer serialization.

latest
Source
npmnpm
Version
4.0.3
Version published
Weekly downloads
19
137.5%
Maintainers
1
Weekly downloads
 
Created
Source

bufferfy

A serialization and deserialization library that space-efficiently packs data into buffers.

  • Supports all javascript data types.
  • Provides accurate typescript types.
  • Serializes to a significantly smaller buffer than message pack and JSON stringify.
  • Performs at the same speed as message pack and JSON stringify.
  • Encode and decode transforms for streams.

3.0.0 Update

This module is now browser compatible, due to this the following changes have been made:

  • When handling bytes, Uint8Arrays are now used instead of node buffers.
  • Node style streams have been replaced by WebApi streams.

Install

npm i bufferfy

Usage

import { Codec } from 'bufferfy';

export const ExampleCodec = Codec.Object({
	id: Codec.String("hex", 32),
	relatedIds: Codec.Array(Codec.String("hex", 32)),
	createdAt: Codec.VarInt(),
	updatedAt: Codec.VarInt(),
	deletedAt: Codec.Optional(Codec.VarInt()),
});

type ExampleData = CodecType<typeof ExampleCodec>;

const example: ExampleData = {
   // ... values
}

const buffer = ExampleCodec.encode(example)

const data = ExampleCodec.decode(buffer) // returns ExampleData

// Streams
const encoder = ExampleCodec.Encoder(); // Takes values and outputs buffer chunks

encoder.pipe(stream);
encoder.write(value);
encoder.end();

const decoder = ExampleCodec.Decoder(); // Takes buffer chunks and outputs values

decoder.on("data", (data) => {
	// ... logic
});

stream.pipe(decoder);

API

All codecs provide a standard set of methods.

buffer = AnyCodec.encode(data, target?, offset?)

Returns the data serialized into a buffer. A buffer and offset can be provided, otherwise a new buffer will be created.

data = AnyCodec.decode(buffer, start?, end?)

Returns the unserialized data from a buffer.

number = AnyCodec.byteLength(data)

Returns the byte length of the data if it were serialized.

boolean = AnyCodec.isValid(data)

Returns true if the codec is able to serialize and unserialize provided data.

Type = CodecType<typeof codec>

Returns the value type of the provided codec.

Types

  • Abstract
  • Any
  • Array
  • BitField
  • Boolean
  • Bytes
  • Constant
  • Float
  • Int
  • Object
  • Record
  • String
  • Transform
  • Tuple
  • UInt
  • Union
  • VarInt

Utilities

Union Codec Ordering

Codec.Union() tests codecs sequentially. First match wins.

Order specific → general. Put Codec.Any() last (matches everything).

// Correct
Codec.Union([Codec.Constant("active"), Codec.String(), Codec.Any()])

// Wrong - Any() shadows everything
Codec.Union([Codec.Any(), Codec.String()])

Benchmarks

Values used for benchmarks can be found here.

Spread of Types

bufferfy.size                   50
msgpack.size                    149
JSON.size                       221

Common Types

bufferfy.size                   1050
msgpack.size                    1706
JSON.size                       1775

Keywords

protobuf

FAQs

Package last updated on 30 Oct 2025

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