ABAX API client built using Typescript for Node.js. This SDK is used by multiple
integrations with the ABAX API, but it is still in early development.
Features
- Built with Typescript
- Uses undici (Faster requests 🚀)
- Pure ESM
The endpoints currently supported are:
- GET v1/vehicles
- GET v1/trips
- GET v1/trips/odometerReadings
- GET v1/trips/expense
- GET v2/equipment
- GET v2/equipment/{id}
- GET v2/equipment/usage-log
Installation
pnpm add abax-node-sdk
Usage
import { AbaxClient } from 'abax-node-sdk';
const client = new AbaxClient({
apiKey: 'xxxxx',
});
client.getVehicles().then(vehicles => {
console.log(vehicles);
});
Authentication
If you don't know how to authenticate with the Abax API, you should consult
their documentation. This SDK comes packed with AbaxAuth
which helps you solve the authentication part.
When using Authorization Code Flow
The first step is to create an instance of AbaxAuth
and pass in your
clientId
and clientSecret
. You can then use the getAuthorizationUrl
method
to get the URL you need to redirect the user to. After the user has authorized
your application, they will be redirected to the redirectUri
you specified
when creating the AbaxAuth
instance. The redirectUri
will contain a code
query parameter which you can use to get an access token.
import { AbaxAuth } from 'abax-node-sdk';
const auth = new AbaxAuth({
clientId: 'xxxxx',
clientSecret: 'xxxxx',
redirectUri: 'https://example.com/auth/callback',
});
const authorizationUrl = auth.getAuthorizationUrl();
After the user has authorized your application, they will be redirected to the
redirectUri
you specified when creating the AbaxAuth
instance. The
redirectUri
will contain a code
query parameter which you can use to get an
access token.
import { AbaxAuth } from 'abax-node-sdk';
const auth = new AbaxAuth({
clientId: 'xxxxx',
clientSecret: 'xxxxx',
redirectUri: 'https://example.com/auth/callback',
});
const authorizationCode = 'xxxxx';
await auth.getCredentialsFromCode(authorizationCode);
const client = new AbaxClient({
apiKey: () => auth.getAccessToken(),
});
When using Client Credentials Flow
import { AbaxAuth } from 'abax-node-sdk';
const auth = new AbaxAuth({
clientId: 'xxxxx',
clientSecret: 'xxxxx',
});
await auth.getCredentialsFromClientCredentials();
const client = new AbaxClient({
apiKey: () => auth.getAccessToken(),
});
Saving and loading credentials
If you want to save the credentials to a database, you can use the
getCredentials
method on AbaxAuth
. This will return the credentials as an
object, which you can then store in your database. Alternatively does both
getCredentialsFromCode
and getCredentialsFromClientCredentials
return the
credentials, so you can also store them from there.
import { AbaxAuth } from 'abax-node-sdk';
const auth = new AbaxAuth({
clientId: 'xxxxx',
clientSecret: 'xxxxx',
});
const credentials = await auth.getCredentialsFromCode(authorizationCode);
When you want to load the credentials from the database, you can use the
setCredentials
method on AbaxAuth
. This will set the credentials on the
import { AbaxAuth } from 'abax-node-sdk';
const auth = new AbaxAuth({
clientId: 'xxxxx',
clientSecret: 'xxxxx',
});
auth.setCredentials(credentialsFromDatabase);
const client = new AbaxClient({
apiKey: () => auth.getAccessToken(),
});
Setting scopes and automatic refreshing
You can set the scopes you want to request when authenticating with the Abax
Identity API. You can do this by passing the scopes
option to AbaxAuth
.
import { AbaxAuth } from 'abax-node-sdk';
const auth = new AbaxAuth({
clientId: 'xxxxx',
clientSecret: 'xxxxx',
scopes: ['open_api', 'open_api.equipment'],
});
Note: Automatic refreshing of the access token is only supported when using
the offline_access
scope. As far as we know, this does not give access for
longer than 30 days, so you will have to re-authenticate after 30 days.
See the scopes available in the Abax Identity API documentation on
scopes.
Contributing
We love contributions! Please read our Contributing Guide to
learn how to contribute to this project.