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

anslo

v0.1.1

Published

A json serializer/parser that can remember state.

Readme

Anslo

A serializer/deserializer that can serialize pointer references and remember context.

npm install --save anslo

How does it work?

const Anslo = require("anslo");

/**
 * Create an instance
 **/
let anslo = new Anslo();


/**
 * Create an instance of something
 * you would like to serialize
 **/ 
let user = new User();

/**
 * Do cool things like self referencing
 **/
user.self = user;

/**
 * Serialize data down to a string
 **/
let string = anslo.down(user)

/**
 * Deserialize back to original state
 **/
let newUser = anslo.up(string);

/**
 * Done!!
 **/
console.log(newUser === newUser.self); //outputs: true

What about remembering context? Let's use the same example.

const Anslo = require("anslo");

/**
 * Create an instance
 * 
 * [Context]
 * Provide an object of constructors that
 * you would like to have Anslo remember, 
 * and when they are revived, the pointer
 * will be an instance of the context provided
 **/
let anslo = new Anslo({ User });


/**
 * Create an instance of something
 * you would like to serialize
 **/ 
let user = new User();

/**
 * Do cool things like self referencing
 **/
user.self = user;

/**
 * Serialize data down to a string
 **/
let string = anslo.down(user)

/**
 * Deserialize back to original state
 **/
let newUser = anslo.up(string);

/**
 * Done!!
 **/
console.log(newUser === newUser.self); //outputs: true

Security Considerations

Serializing state down to a string and reviving it to its original state raises strong security concerns. If there are any questions at all about where serializations come from, use encryption and a signature to verify you made it. Moreover, we are soon to be living in an time where quantum computing is available; use a post-quantum algorithm.

Caveats

  • Properties that are functions will be serialized to null. Use classes with methods to provide functionality.

What does the serialized string look like?

Let's say we were to run this bit of code...

let data = [{
    name: "something",
    date: new Date()
}]

/**
 * The second argument is the number of
 * spaces used to beautify the serialization.
 */
let string = anslo.down(data, 4)
console.log(string);
{
    "pointers": [
        [],
        {},
        "something",
        {}
    ],
    "graph": {
        "r": 0,
        "t": "array",
        "c": {
            "0": {
                "r": 1,
                "t": "object",
                "c": {
                    "name": {
                        "r": 2,
                        "t": "string"
                    },
                    "date": {
                        "r": 3,
                        "t": "date",
                        "v": "2018-12-10T06:36:05.620Z"
                    }
                }
            }
        }
    }
}

Minified, it would look like this.

{"pointers":[[],{},"something",{}],"graph":{"r":0,"t":"array","c":{"0":{"r":1,"t":"object","c":{"name":{"r":2,"t":"string"},"date":{"r":3,"t":"date","v":"2018-12-10T06:40:51.342Z"}}}}}}