@dvcol/withings-http-client
v1.1.3
Published
Simple fetch based http client for Withings API with full typescript support (request and response).
Downloads
9
Maintainers
Readme
Simple fetch based http client for Withings API with full typescript support (request and response).
Prerequisites
- pnpm >=9.0.0
- node >=20.0.0
Install
pnpm install
Usage
pnpm add @dvcol/withings-http-client
Modular endpoint bundling
withings-http-client is designed to be modular and flexible. Although it uses static classes, endpoints are instantiated at runtime and can be easily omitted, extended or overridden. If your bundler does not support tree-shaking, you can omit unused endpoints by only importing the ones you need.
By default we provide a full api object with all supported endpoints, as well as a minimal api object with only the essential authentication endpoints. You can also import any endpoint by common scope.
import { WithingsClient } from '@dvcol/withings-http-client';
import { withingsApi } from '@dvcol/withings-http-client/api';
import { minimalWithingsApi } from '@dvcol/withings-http-client/api/minimal';
import { sleep } from '@dvcol/withings-http-client/api/sleep';
import { Config } from '@dvcol/withings-http-client/config';
import type { WithingsClientSettings } from '@dvcol/withings-http-client/models';
export const api = {
...minimalWithingsApi,
sleep
};
export const settings: WithingsClientSettings = {
client_id: '<Your client ID>',
client_secret: '<Your client secret>',
endpoint: Config.endpoint,
redirect_uri: '<Your redirect uri>',
};
const authenticaiton = {}
const client = new WithingsClient(settings, authenticaiton, api);
Features
- Built-in cache support (per client, endpoint, or query)
- Extensible cache store (in-memory, local storage, etc.)
- Event observer (request, query, auth)
- Built-in cancellation support
- Built-in cors proxy support
Documentation
See Withings API documentation for more information.
Author
- Github: @dvcol
📝 License
This project is MIT licensed.