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 🙏

© 2024 – Pkg Stats / Ryan Hefner

esi-little-helper

v1.1.0

Published

A Fetch wrapper to interact with the EVE Online API

Downloads

16

Readme

esi-little-helper

This module provides a simple way to execute calls towards ESI, the EVE Online API, handling automatically API error limits and pagination.

It's built on top of the javascript's Fetch API, so for more details on the returned Response and Headers objects please refer to the Fetch documentation.

Disclaimer: this module has no built in throttling, so in case of pagination all the requests to get the remining pages will be dispatched at the same time with a single call.


CallBuilder

An helper class to compose the parameters for the ESI call.

let params = new CallBuilder(
    method,   // required (ex. 'GET')
    path,     // required (ex. '/v4/universe/systems/30000142/')
    token,    // optional, depending on the API endpoint
    body      // optional, depending on the API endpoint
);

Esi

Execute the call using the Esi's call method, if pagination is detected it calls automatically all the pages, throw in case of API error, or in case the ESI object has broken the error limit and it's still within the same error window.
Returns a Result object.

Ideally a single instance of the Esi class should be used for all the calls, to better keep track of API errors and share the same error window information.

let esi = new Esi('my user agent');
result = esi.call(params);

Result

Get the JSON of the API call, in case of pagination the bodies are merged together in a single JSON.

result.json()
    .then(data => console.log(data))
    .catch(e => console.error(e));

Get the Headers object of the response, in case of paginated call returns the Headers object of the first response.

result.headers()
    .then(data => console.log(data))
    .catch(e => console.error(e));

Get the Response object of the response, in case of paginated call returns the first response.

result.response()
    .then(data => console.log(data))
    .catch(e => console.error(e));

Example

First initialize the Esi class and create the specific parameter object containing the necessary properties, such as method and path.

let esi = new Esi('my app name');
let params = new CallBuilder(
    'GET',
    '/v4/universe/systems/30000142/'
);

Then execute the calling the Esi call() method passing to it the parameter object created previously.

The call method return a Result object, from which you can access the resulting json as soon as the response (or all the responses, in case of pagination) is resolved.

esi.call(params).json()
  .then(data => console.log(data.name))
  .catch(e => console.error(e));

// -> Jita