@ovotech/apollo-datasource-axios
TypeScript icon, indicating that this package has built-in type declarations

2.0.1 • Public • Published

AxiosDataSource for Apollo

A rest datasource that uses axios under the hood. This allows adding generic interceptors, adapters etc. Integrates with cache and cache policies. Supports Interceptors.

Using

yarn add @ovotech/apollo-datasource-axios
import { AxiosDataSource } from '@ovotech/apollo-datasource-axios';

interface User {
  name: string;
}

export class MyDataSource extends AxiosDataSource {
  users(id: string) {
    return this.get<User>(`/users/${id}`);
  }
}

const dataSource = new MyDataSource({ baseURL: '...' });

Interceptors

You can pass interceptors to axios declaratively with the interceptros property.

import { Interceptor } from '@ovotech/apollo-datasource-axios';
const logger: Interceptor = {
  response: {
    onFulfilled: res => {
      console.log(res);
      return res;
    },
    onRejected: err => {
      console.log(err);
      return err;
    },
  },
};

const dataSource = new MyDataSource({ baseURL: '...', interceptors: [logger] });

Advanced types

If you want to be more exact on the types passed to and from axios, you can fill in the optional types. This is useful if some of your interceptors are adding properties to the config.

import { AxiosDataSource, AxiosDataSourceConfig } from '@ovotech/apollo-datasource-axios';

interface Context extends AxiosDataSourceConfig {
  version: string;
}

export class MyDataSource extends AxiosDataSource<Context> {
  users(id: string) {
    return this.get(`/users/${id}`, { version: '123' });
  }
}

Running the tests

You can run the tests with:

yarn test

Coding style (linting, etc) tests

Style is maintained with prettier and tslint

yarn lint

Deployment

Deployment is preferment by lerna automatically on merge / push to master, but you'll need to bump the package version numbers yourself. Only updated packages with newer versions will be pushed to the npm registry.

Contributing

Have a bug? File an issue with a simple example that reproduces this so we can take a look & confirm.

Want to make a change? Submit a PR, explain why it's useful, and make sure you've updated the docs (this file) and the tests (see test folder).

License

This project is licensed under Apache 2 - see the LICENSE file for details

Dependencies (5)

Dev Dependencies (12)

Package Sidebar

Install

npm i @ovotech/apollo-datasource-axios

Weekly Downloads

4

Version

2.0.1

License

Apache-2.0

Unpacked Size

20.9 kB

Total Files

15

Last publish

Collaborators

  • ovox
  • oep-accounts-bot
  • ovo.backstage.admins
  • bookings-team
  • orion-bot
  • bizval-bot
  • oeptariffs
  • props
  • metering-reads-health-bot
  • ovotech-identity
  • paceteamkaluza
  • trading-and-dispatch
  • retail-payg-tech
  • accrecovo
  • ovo.trading.tech
  • qe-team
  • ovotech-smart-thermostat
  • rise-team
  • engagement-insights
  • myovo-self-serve-service-account
  • mars-rover
  • ape-team
  • kaluza-devex
  • ohs-aurora
  • kaluza-rnr
  • ipa-bot
  • kawbot
  • data.discovery.ovo
  • ovotech-sg
  • ovotech-qs
  • ovoenergyapps
  • homemoves
  • ovo-oot-bot
  • cp-ui-tooling
  • ovo-bit-tech
  • sir_hiss