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

@inversable/hasura-js-sdk

v5.2.1

Published

Inversable Hasura JS SDK

Downloads

5

Readme

Hasura JS SDK

The Hasura JS SDK is a JavaScript package that can be used to streamline communication with the Inversable Hasura Backend (IHB). It exposes two classes: Auth and Storage, used for authentication and storage requests respectively.

The Hasura JS SDK was forked from the Nhost JS SDK commit f0086438.

Install

To install the Hasura JS SDK run the following command:

$ npm install @inversable/hasura-js-sdk

Not every version of the Hasura JS SDK is compatible with every version of the IHB. Please refer to the compatibility matrix:

| Hasura JS SDK version | IHB version | | --- | --- | | >= 4.x.x | >= 3.x.x | | >= 4.1.x | >= 3.5.x | | >= 5.x.x | >= 5.x.x | | >= 5.1.x | >= 5.1.x |

Note that in December 2022 the version numbers of the Hasura JS SDK and IHB were bumped to match eachother

Updating the Hasura JS SDK

Because the Hasura JS SDK is used by multiple projects in the Inversable ecosystem developers should make sure that minor / patch updates do not introduce any breaking changes. Breaking changes are only allowed in major updates, and requires approval of at least another developer that is familiar with the Hasura JS SDK.

Before you continue to make any changes make sure that your development environment (e.g. VSCode) applies the rules specified in .eslintrc.json. If you develop in VSCode the folder .vscode should take care of this, but please verify.

When working on a new feature/update, make sure you follow these steps:

  1. Make clear issues on GitLab describing what it is you want to achieve, why this is necessary and how you are going to do this. Please link any existing issues in you issue that have (partial) overlap
  2. Make a new branch from the latest version of the master. Make sure you have the latest version of the master branch before you create your branch.
  3. Work on your feature in your branch. Make sure you assign yourself to an issue so others know what you are working on, and which parts of the IHB might be subject to change.
  4. When your feature request is completed, make a merge request and assign one of the other Hasura JS SDK developers to approve the merge request. As of writing this @bverkuil is the main developer of the Hasura JS SDK.
  5. Deploy your new feature (see Deployment)

Easy development with npm link

To quickly test changes you work locally without the need of deployment you can use npm link. Npm link will create a symlink to a global folder that links to the package where the npm link command was executed. This folder ends up in {prefix}/lib/node_modules/<package>. You can find the path of {prefix} using this command: npm prefix -g. Run the following steps to symlink the Hasura JS SDK to your front-end for testing.

  1. Make sure you have the version of the Hasura JS SDK open on your machine which you want to use. Navigate to the root of the folder.
  2. Run npm link. This creates (or overwrites) an entry for the package in {prefix}/lib/node_modules/<package>. The <package> is taken from package.json name, and is @inversable/hasura-js-sdk for this project.
  3. Navigate to a front-end where you want to test the Hasura JS SDK changes. If you are not working on any particular front-end, the Example Project can be used.
  4. Open a terminal in the root folder op the front-end directory and run npm link <package>. For the Hasura JS SDk this command will be npm link @inversable/hasura-js-sdk. The front-end should now use the content of your local copy of the Hasura JS SDK

Please note that even though the code for the Hasura JS SDK is written in TypeScript your browser only understands JavaScript. Run npm run build in the Hasura JS SDK directory every time you made changes to .ts files

If you have trouble with npm link, sometimes manually deleting the global package found at {prefix}/lib/node_modules/<package> solves this issue. Make sure to run steps 1-4 again afterwards.

Deployment

The IHB is deployed as a pacakge on npm. The deployment is done via a CI/CD pipeline. The npm package can be found online: @inversable/hasura-js-sdk .

Please make sure you update the version number in package.json before you run the CI/CD pipeline!

If everything is ready for publish click on CI/CD in the left menu, find your merge into the master branch (probably the first entry in the list) and run the publish-on-npm pipeline.

Then, go to Repository --> Tags in GitLab and create a new tag. Make sure the tag name matches the version you specified in package.json.

Finally create a new release. Go to Deployments --> Releases and add a release matching the tag you created in the step before. Enter what things you changed here, including any additions and (breaking) changes.