Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mendahu/rocket-launch-live-client
A Node.JS library for interacting with the RocketLaunch.Live API
https://github.com/mendahu/rocket-launch-live-client
nodejs rocket rockets
Last synced: 3 months ago
JSON representation
A Node.JS library for interacting with the RocketLaunch.Live API
- Host: GitHub
- URL: https://github.com/mendahu/rocket-launch-live-client
- Owner: mendahu
- License: agpl-3.0
- Created: 2023-01-25T23:20:58.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-08-15T15:57:00.000Z (5 months ago)
- Last Synced: 2024-10-28T13:33:18.135Z (3 months ago)
- Topics: nodejs, rocket, rockets
- Language: TypeScript
- Homepage:
- Size: 216 KB
- Stars: 5
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# rocket-launch-live-client
## Table of Contents
- [Requirements](#reqs)
- [Simple Usage](#simple)
- [Client Configuration](#config)
- [Endpoints](#endpoints)
- [Response Types](#types)
- [Companies](#companies)
- [Launches](#launches)
- [Locations](#locations)
- [Missions](#missions)
- [Pads](#pads)
- [Tags](#tags)
- [Vehicles](#vehicles)
- [Watcher](#watcher)
- [Methods and Properties](#watcher_props)
- [Options](#watcher_options)
- [Events](#watcher_events)This package is a fully-typed, promise-based, zero-dependency Node.JS JavaScript/TypeScript library for interacting with the [RocketLaunch.Live](https://www.rocketlaunch.live) API.
## Requirements
This package is tested on and supports Node 14.18 or higher. It is fully CommonJS/ESM compatible and has Typescript support built in.
## Simple usage
```js
// Import package
import { rllc } from "rocket-launch-live-client";// Get API Your Key
const RLL_API_KEY = process.env.RLL_API_KEY;// Create client
const client = rllc(RLL_API_KEY);// Call endpoints
const launches = await client.launches();
```## Client Configuration
RLL Clients require an API key as the first parameter, and will throw if one is not present.
The client can be configured with an optional second parameter using the following keys:
```js
const options = {
// Defaults to false.
// API Key is normally passed in the Authorization Bearer header
// Set to true to pass your API key as a query parameter instead (not recommended)
keyInQueryParams: true,
};const client = rllc(RLL_API_KEY, options);
```## Endpoints
All endpoints return the following response format, where `T` is an array of results:
```ts
type RLLResponse = {
errors?: string[];
valid_auth: boolean;
count: number;
limit: number;
total: number;
last_page: number;
result: T;
};
```All endpoints return a maximum of 25 results per page. A `page` argument can be passed to retrieve incremental results.
```js
const response = await client.launches({ page: 2 });
// Also accepts page number as a number-parseable string like "2"
```For complete API Documentation on parameters, be sure to visit [RocketLaunch.Live](https://www.rocketlaunch.live/api)
### Response Types
All entity response types are browseable in the [GitHub Repository](https://github.com/mendahu/rocket-launch-live-client/tree/main/src/types).
### Companies
```js
const response = await client.companies(options);
```Optional search parameters:
```js
const options = {
// Company numeric id
// Also accepts number parseable strings like "1"
id: 1,// Company name
name: "SpaceX",// Company country
// ISO 3166 Alpha 2 Country Code
country_code: "US",// For defunct companies
inactive: true,
};
```### Launches
```js
const response = await client.launches(options);
```Optional search parameters:
```js
const options = {
// Launch numeric id
// Also accepts number parseable strings like "1"
id: 1,// COSPAR
// Format YYYY-NNN
cospar_id: "2022-123",// Show launches only before this date
// JS Date Object - Anything more precise than day is ignored
// Also accepts any date string which can be used to create a valid Date object in JavaScript
before_date: new Date("2023-01-31"),// Show launches only after this date
// JS Date Object - Anything more precise than day is ignored
// Also accepts any date string which can be used to create a valid Date object in JavaScript
after_date: new Date("2023-01-31"),// Show launches that have had data updated since this date
// Useful for checking for changes since your last API call
// JS Date Object
// Also accepts any date string which can be used to create a valid Date object in JavaScript
modified_since: new Date("2023-01-31T06:00:00Z"),// Launch location id
// Also accepts number parseable strings like "1"
location_id: 1,// Launch pad id
// Also accepts number parseable strings like "1"
pad_id: 1,// Launch provider id
// Also accepts number parseable strings like "1"
provider_id: 1,// Launch tag id
// Also accepts number parseable strings like "1"
tag_id: 1,// Launch vehicle id
// Also accepts number parseable strings like "1"
vehicle_id: 1,// US State
// ISO 3166-2 US State Code Abbreviation
state_abbr: "FL",// Country of launch
// ISO 3166-1 Alpha 2 Country Code
country_code: "US",// Search string
// Also accepts numbers like 2020
search: "Starlink",// Unique launch slug as used on RocketLaunch.live
slug: "ses-20-ses-21",// Limit amount of launches returned
// Must be between 1 and 25
// Also accepts number parseable strings like "10"
// Note: this param is safely ignored when using in conjuction with a Watcher (see below)
limit: 10,// Sort order (by date) of results
// Accepts either "asc" or "desc"
// If left unfilled, API defaults to "asc"
direction: "asc",
};
```### Locations
```js
const response = await client.locations(options);
```Optional search parameters:
```js
const options = {
// Location numeric id
// Also accepts number parseable strings like "1"
id: 1,// Location name
name: "Cape Canaveral",// Location State (US)
// ISO 3166-2 US State Code Abbreviation
state_abbr: "FL",// Location country
// ISO 3166 Alpha 2 Country Code
country_code: "US",
};
```### Missions
```js
const response = await client.missions(options);
```Optional search parameters:
```js
const options = {
// Mission numeric id
// Also accepts number parseable strings like "1"
id: 1,// Mission name
name: "Juno",
};
```### Pads
```js
const response = await client.pads(options);
```Optional search parameters:
```js
const options = {
// Pad numeric id
// Also accepts number parseable strings like "1"
id: 1,// Pad name
name: "SpaceX",// Pad State (US)
// ISO 3166-2 US State Code Abbreviation
state_abbr: "FL",// Pad country
// ISO 3166 Alpha 2 Country Code
country_code: "US",
};
```### Tags
```js
const response = await client.tags(options);
```Optional search parameters:
```js
const options = {
// Tag numeric id
// Also accepts number parseable strings like "1"
id: 1,// Tag text
text: "Crewed",
};
```### Vehicles
```js
const response = await client.vehicles(options);
```Optional search parameters:
```js
const options = {
// Vehicle numeric id
// Also accepts number parseable strings like "1"
id: 1,// Vehicle name
name: "Atlas V",
};
```## Watcher
The `rocket-launch-live-client` has the ability to monitor the `launches` endpoint on a regular basis and return changes as they happen live.
```js
// Instantiate a new watcher
// See below for options
const watcher = client.watch(5, options);// Define event handlers
watcher.on("new", (newLaunch) => {
// handle new launch
});// Start monitoring
watcher.start();// Stop monitoring
watcher.stop();
```### Watcher Options
A new watcher takes up to two arguments:
1. Interval - (optional) (default: 5) - a duration, in minutes, between calls to the API. Adjust this based on the frequency you wish to stay up to date. To avoid needlessly querying the API, this client will now allow any option less than 1 minute.
2. Query Options - (optional) - The exact same query options that can be submitted to the [`launches`](#launches) endpoint. _NOTE:_ the "limit" param is ignored on the `watcher`.Query options cannot be altered on a running watcher. In order to change your search conditions, you'll need to stop the watcher and start a new one.
### Watcher Methods and Properties
#### Start
Begin watching the `launches` endpoint using the interval and query options provided during watcher instantiation.
```js
watcher.start();
```#### End
Stop watching the `launches` endpoint.
```js
watcher.stop();
```#### On
Set an event handler for a Watcher event. Extends the Node Event Emitter `on` method. Takes an event name (see below) and a callback.
```js
watcher.on("ready", (launches) => {
// handle event
});
```#### Launches Data
Access the launches data cache. The data is stored in a [JavaScript Map](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map) and has all the methods associated with Maps.
```js
watcher.launches; // Map of all launches in cache
watcher.launches.size // Count of launches in cache
watcher.launches.get(1) // Get launch with launch_id of 1
watcher.launches.forEach((launch, launchId) => /* Do something to each launch */ )
```Note: We recommend not altering the `launches` cache directly (such as by using Map's `set` or `delete` methods). The watcher will notice the discrepancy on the next API call and trigger appropriate `new` or `change` events to set it back. This may not be the behaviour you expect.
### Watcher Events
Watcher events are triggered when the client recieves a response to a query to `launches` using the `modified_since` parameter. The client will compare the changes to a cached version of the launch and trigger the appropriate event.
If there are multiple changes on a single API call, the appropriate events will be triggered more than once, so have your callbacks handle a single event.
#### New
A new launch has been added! The Watcher will provide the new launch data as the first argument to your callback.
```js
watcher.on("new", (newLaunch) => {
// Handle the new addition here
});
```The `newLaunch` argument will be an `RLLEntity.Launch` object, the same shape as what is received from the `launches` endpoint (but not wrapped in the standard response).
#### Change
An existing launch has had information change. The Watcher will provide the old and new versions of the launch object to do your own comparisons.
```js
watcher.on("change", (oldLaunch, newLaunch) => {
// Handle changes here
});
```The `oldLaunch` and `newLaunch` will be the cached version and the new version of an `RLLEntity.Launch` object, the same shape as what is received from the `launches` endpoint (but not wrapped in the standard response).
#### Error
There was an error on an API call. The error will be passed as the first argument of the callback.
```js
watcher.on("error", (err) => {
// Handle error here
});
```The `err` object will have the following shape, and is accessible via TypeScript as `RLLError`:
```js
const err = {
error: "Error title";
statusCode: 404; // HTTP status code or null if no response
message: "Could not find this resource"; // Custom error string from RLLC
server_response: { } // error passed through from server, can be null if no response
}
```#### Ready
The watcher has completed its initial API calls and built a cache of launches. The initial cache of launches is passed as the first argument. The client is now monitoring the API.
```js
watcher.on("ready", (launches) => {
// Handle ready here
});
```#### Initialization Errors
The watcher has experienced a problem setting up its initial cache and is has not started monitoring.
```js
watcher.on("init_error", (err) => {
// Handle error here
});
```The `err` object will have the following shape, and is accessible via TypeScript as `RLLError`:
```js
const err = {
error: "Error title";
statusCode: 404; // HTTP status code or null if no response
message: "Could not find this resource"; // Custom error string from RLLC
server_response: { } // error passed through from server, can be null if no response
}
```#### Call
The watcher also emits a `call` event every time it makes a request, passing in the query parameters it used in the Node URLSearchParams format. Use this to monitor or diagnose how often the API is being queried.
```js
watcher.on("call", (params) => {
// Handle call here
});
```