1.1.4 • Published 2 years ago
@gigwage/client v1.1.4
@gigwage/client
Node client library for accessing the Gig Wage API.
Installation
NPM
npm i @gigwage/clientYarn
yarn add @gigwage/clientUsage
Create a new Gig Wage client and use it to access APIs from the documentation. The client is used to automatically handle the complex API authentication.
import { createGigwageClient } from "@gigwage/client";
// consider using `dotenv` to pull in environmental variables from a .env file
import "dotenv/config";
// Create a new client
const client = createGigwageClient({
  apiKey: process.env.GIGWAGE_API_KEY,
  apiSecret: process.env.GIGWAGE_SECRET,
});
// Call endpoints from the Gig Wage API using this client.
const response = await client.get("/api/v1/contractors")
// Pass the payload for the second argument for POST and PATCH methods.
const postResponse = await client.post("/api/v1/contractors",{/** new contractor payload*/})Accessing Response Data
@gigwage/client uses axios under the hood, so all HTTP method responses will return the same format as an axios response would.
try{
  const response = await client.get("/api/v1/contractors")
 
  response.data.contractors // array of contractors
}catch(e){
  // error
}Using Typescript
Types are included with this package, but the individual API calls are to be included in a future release. For now, you can pass the expected response data type as a generic.
const response = await client.get<{contractors:[]}>("/api/v1/contractors")
Array.isArray(response.data.contractors) // true