@aaxis/lokka-transport-http

Isomorphic HTTP Transport for Lokka with Expose handle Request and Response

Usage no npm install needed!

<script type="module">
  import aaxisLokkaTransportHttp from 'https://cdn.skypack.dev/@aaxis/lokka-transport-http';
</script>

README

@aaxis/lokka-transport-http

Isomorphic HTTP Transport Layer with Expose handle Request and Response


This is a compatible transport layer for Lokka.

Basic Usage

Install the package:

npm i --save @aaxis/lokka-transport-http
npm i --save lokka
import HttpTransport from '@aaxis/lokka-transport-http';
const transport = new HttpTransport('http://graphql-swapi.parseapp.com/');
transport.send(`
    {
      allFilms {
        films {
          title
        }
      }
    }
`).then(response => {
    console.log(JSON.stringify(response, null, 2));
});

Send Custom Request & Response

It's possible to send custom headers like this:

const headers = {
    'my-headers': 'some-value'
};
const transport = new HttpTransport('/graphql', {
    headers,
    buildOptions: () => {
      // build you custom header here
    },
    formatResponse: (response) => {
      // format you response here
    }
})

Authentication

This package does not handle authentication information for you. But it'll let you interact with your app's existing authentication mechanism.

Error Handling

By default it will create and throw a new Error object using the first GraphQL error. Error handling can be customized with the handleErrors option. Check the deafult error handler in lib/index.js for an example.