palauth-iam-node/README.md
2024-01-16 13:39:03 +00:00

1.6 KiB

PalAuth IAM client for Node JS

This uses the Fetch API, so technically it could work in the browser too. This is not recommended due to the need to handle PalAuth Client Secret tokens for the requests, as well as CORS restrictions.

Supported features

Currently, only the /check method is supported. This checks if a given user has a given permission, returning a simply boolean answer.

Installation

Because NPM is evil, this package is instead hosted within this Gitea repo.

Installing it isn't too hard! Just follow these simple steps.

Create (or modify) a .yarnrc.yml file (either in your home directory to configure globally, or in the root of the package where you want to install):

npmScopes:
 paltiverse:
   npmRegistryServer: "https://gitea.palk.me/api/packages/paltiverse/npm/"

You will now be able to install any public @paltiverse packages (either for all projects if you added this to your home directory, or just for the current project if you added it there).

In the package where you want to install the client, run:

yarn add @paltiverse/palauth-iam-node

For more details, see the Gitea docs.

Usage

import PalAuthIAMClient from "@paltiverse/palauth-iam-node"

const client = new PalAuthIAMClient({
    clientID: "abcdef",
    clientSecret: "abcdef",
    // If not using auth.palk.me:
    baseURL: "https://<my-palauth-instance>/iam",
})

const isAllowed = await client.checkPermission({
    userId: "abcdef",
    permission: "repositories.issues.create",
})

License

GNU GPL 3.0. See LICENSE.md.