Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@globalfishingwatch/api-client

Package Overview
Dependencies
Maintainers
3
Versions
78
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@globalfishingwatch/api-client

Simply pure js library to help on the GFW API with:

  • 3.0.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
34
decreased by-26.09%
Maintainers
3
Weekly downloads
 
Created
Source

GFW API CLIENT

Simply pure js library to help on the GFW API with:

  • login/logout steps
  • fetch authenticated resources
  • download authenticated resources

Install

yarn

yarn add @globalfishingwatch/api-client

npm

npm i @globalfishingwatch/api-client --save

Initialize

Just include the basic config in the .env when no extra configuration is needed. API_GATEWAY_URL | REACT_APP_API_GATEWAY_URL=https://gateway.api.dev.globalfishingwatch.org

import GFW_API from '@globalfishingwatch/api-client'
// use where needed

Some configuration is exposed to be changed at any moment:

GFW_API.setConfig( {
	debug: boolean
	baseUrl: string
})

Login

The url to the SSO is exposed used the getLoginUrl helper, which needs the following params:

  • callback url
  • client (optional, using gfw by default)
import GFW_API from '@globalfishingwatch/api-client'
const url = GFW_API.getLoginUrl('your_callback_url_here', 'client_optional')
  1. On the very first usage time the library needs the access-token to generate the session token and the refreshToken but it won't be useful anymore.
try {
  const user = await GFWAPI.login({ accessToken: 'acces_token_here' })
  console.log(user) // returns user data
} catch (e) {
  console.warn('Something happened on the login', e)
}
  1. Once it was logged for first time you can login using your refreshToken:
try {
  const user = await GFWAPI.login({ refreshToken: 'refresh_token_here' })
  console.log(user) // returns user data
} catch (e) {
  console.warn('Something happened on the login', e)
}
  1. If you want the library to use the stored keys in the localStorage just use:
try {
  const user = await GFWAPI.login()
  console.log(user) // returns user data
} catch (e) {
  console.warn('Something happened on the login', e)
}

Set dataset

As most of the endpoints are below the dataset prefix the client allows you to set the dataset version and be used in all request using:

GFWAPI.setConfig({ dataset })

Fetch resources

  1. Once the initialization and the login were good to you will be able to consume Global Fishing Watch endpoints data using:
try {
  const data = await GFWAPI.fetch('your_relative_url_here')
  console.log(data) // returns the desired data
} catch (e) {
  console.warn('Something happened on the gfw api fetch', e)
}

Download resources

  1. Download resources using your logged account is easily done using the endpoint to download and the file name to store with its extension
try {
  await GFWAPI.download('your_download_url_here', 'downloaded-file-name.csv')
} catch (e) {
  console.warn('An error on the download happened', e)
}

Logout

  1. To remove invalidate the current session and removed stored token and refreshToken just use:
try {
  const logged = await GFWAPI.logout()
  console.log(logged) // returns true when logout was good
} catch (e) {
  console.warn('Something happened on the logout', e)
}

Use it locally

Send local:true in the FetchOptions and ensure you have the following .env variables

REACT_APP_LOCAL_API_USER_ID=
REACT_APP_LOCAL_API_USER_TYPE=
REACT_APP_LOCAL_API_USER_EMAIL=

FAQ

Do you need the token or the refreshToken in your app ?

Just use:

GFWAPI.getToken()
// or
GFWAPI.getRefreshToken()

Do you need the debug the requests?

Use your own instance of the API client including this param:

const GFWAPI = new GFW_API({
	....
	debug: true
})

Use it with React

The library exposes a react hook to make the login as easy as possible:

import GFWAPI from '@globalfishingwatch/api-client'
import useGFWLogin from '@globalfishingwatch/api-client/dist/react-hook'

function App() {
  const { loading, logged, user, error } = useGFWLogin(GFWAPI)
}

Development

  1. Install dependencies
yarn install
  1. Start the project with watcher to recompile
yarn start
  1. Run the tests
yarn test
  1. Build it!
yarn build
  1. Prepare the release!
npx release major|minor|patch
  1. Publish the new version and update the documentation
npm publish
npm publishdoc

FAQs

Package last updated on 11 Aug 2021

Did you know?

Socket

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
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc