Skip to main content
Version: 0.3

Observations

Overview

Observations Flow orchestrates the retrieval and management of live SkyPath turbulence observations. This page provides a detailed understanding of the flow architecture and how to use it.

Observations display on the maps

Startup and Initialization

Upon instantiation, Observations Flow sets up initial configurations and prepares the system for data fetching based on provided map polygon and other settings. It immediately subscribes to internal events to handle periodic updates and user-triggered changes.

To crate Observations Flow call createObservationsFlow factory method from sdk object.

See example:

// Initialize SDK
const sdk = await createSkyPathSDK(...);

// Create Observations Flow
const observationsFlow = sdk.createObservationsFlow()

The createObservationsFlow() method doesn't take any arguments, all configuration for the flow is provided with updateConfig() method.

Lifecycle Management

  • Start: Allocates resources, setting up intervals and listeners for data updates;
  • Update: Triggers an update of the data, fetching new data for relevant areas and settings;
  • Stop: Temporarily stops all operations, keeps resources, and pauses updates / fetches;
  • Terminate: Completely stops all operations, releases resources, and removes all listeners, effectively shutting down the flow;

Data Retrieval Process

Under the hood, observations flow abstracts the complexity for communication with SkyPath platform API in efficient way handling necessary data transformations, mappings and access management:

  • Data fetching: The data for the whole world map is being fetched based on the map polygon and settings set. It handles concurrent loading and ensures that only relevant data is fetched and in performant way;
  • Data Merging: New data may be merged with already loaded areas of a world map, appending it to the stored values to reduce network load and computation time;
  • Data enrichment: Once new data is available on the back-end side, the old data is being enriched with the fresh data;
info

Data update process is triggered automatically by the flow, but can also be triggered manually by the user by calling updateConfig() method.

Automatic updates are triggered periodically every 1 minute.

Once data update is triggered and successfully completed, the flow emits data update event, which can be listened to by the user to update the UI or perform any other necessary actions. This can be done by subscribing to the event using onData method that takes a callback function as an argument and returns ObservationsData object for current and previous data:

observationsFlow.onData((data, previousData) => {
// Use the data to update the UI
})

If an error occurs during the update process, the flow emits an error event, which can be listened to by the user to handle the error. This can be done by subscribing to the event using onError method that takes a callback function as an argument and returns an Error object:

observationsFlow.onError((error) => {
// Handle the error
})

Tracking the processing status of the flow can be done by subscribing to the onIsProcessingChange event. This event is emitted when the flow starts or stops processing data. The event returns a boolean value indicating the processing status:

observationsFlow.onIsProcessingChange((isProcessing) => {
// Handle the processing status
})

Configuration

To update the flow with new settings, call updateConfig method:

observationsFlow.updateConfig(config)

The updateConfig(config: Config) method takes the following arguments where the polygon is a custom area on a world map and settings are the configuration for the flow:

PropertyDescriptionTypeDefault
polygonMap viewport rectangle or a route corridor polygonPolygonnull
aircraftCategoryAircraft categoryAircraftCategory"C60"
isCorridorModeFlag to indicate if the polygon is a route corridor or notbooleanfalse
info

Please note, that all properties are optional. If you provide partial configuration, for missing properties previous or default values will be used.

Example: If you first set aircraftCategory to C10 and then update the configuration without providing aircraftCategory, the value will remain C10.

You may also erase certain properties by setting them to null if the flow supports it.

undefined values are ignored and will not trigger any changes.

Requirements

We apply some requirements to the polygon size to ensure the performance of the flow. Depending if the polygon is a corridor or not, the flow will handle the polygon differently.

Default Mode

When dealing with default mode, meaning isCorridorMode is false, flow relates polygon to 1 of 3 sizes:

  • Small: smaller than continental U.S.
  • Medium: from small to large
  • Large: larger than the 2x continental U.S.

For each size, the flow applies different handling strategies to ensure the performance of the flow.

  • All severity data is loaded.
  • Full polygon is loaded.

handlingSmallPolygon

Corridor Mode

When dealing with corridor mode, meaning isCorridorMode is true, there are only one limitation - the polygon size should be less than 2,500,000 nautical miles, otherwise, the flow will not load the data and will emit an error.

  • Smooth severity data is excluded.
  • Corridor polygon is loaded.

corridorPolygon

Examples

Basic usage

// Import the SDK 
import createSkyPathSDK from "@yamasee/skypath-sdk-web";

// Init with your credentials
const sdk = await createSkyPathSDK(...);

// Create Observations Flow
const observationsFlow = sdk.createObservationsFlow()

// Subscribe to the data update event
observationsFlow.onData((data) => {
// Use the data to update the UI
})

// Subscribe to the error event
observationsFlow.onError((error) => {
// Handle the error
})

// Start the flow when needed
observationsFlow.start()

// Later in the code update the configuration
observationsFlow.updateConfig({
polygon: [
[ -64.816, -18.751 ],
[ -64.816, -28.452 ],
[ -51.672, -28.452 ],
[ -51.672, -18.751 ],
[ -64.816, -18.751 ]
],
aircraftCategory: "C60",
})

// Later in the code terminate the flow when jobs are done
observationsFlow.terminate()

Advanced usage

For advanced examples check the React Demo Application.