Socket
Socket
Sign inDemoInstall

@ovotech/apollo-datasource-axios

Package Overview
Dependencies
95
Maintainers
77
Versions
8
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    @ovotech/apollo-datasource-axios

Datasource using axios


Version published
Weekly downloads
8
increased by60%
Maintainers
77
Install size
4.69 MB
Created
Weekly downloads
 

Readme

Source

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

FAQs

Last updated on 06 Jun 2019

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc