Package Exports
- sunburst.js
- sunburst.js/src/lib/encoding/base64/browser.js
- sunburst.js/src/lib/encoding/base64/node.js
- sunburst.js/src/lib/request/browser.js
- sunburst.js/src/lib/request/node.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (sunburst.js) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
sunburst.js
Sunburst API client library for JavaScript
This library provides authorization handling and methods for accessing the Sunburst API from SunsetWx.
- Supports Node.js, React Native, and popular web browsers.
Platform Support
Platform | Version |
---|---|
Node.js | 6.5+ |
React Native | 0.54+ |
Installation and usage
JavaScript in-browser script tag usage:
- Place
dist/sunburst.iife.js
into your website's files.
<!-- The library is exposed as a global variable: SunburstJS -->
<script src="assets/js/sunburst.iife.js"></script>
Installation using npm:
npm i sunburst.js
Node.js 8.10+ usage:
const SunburstJS = require('sunburst.js');
Node.js 6.5+ usage:
const SunburstJS = require('sunburst.js/dist/sunburst.node.js');
Usage with React Native or your favorite module bundler:
import SunburstJS from 'sunburst.js';
Getting started
Create a session pair. Also known as clientId
and clientSecret
, which are our API keys:
(async () => {
try {
const sunburst = new SunburstJS();
const session = await sunburst.createSession({
email: 'example@example.com',
password: 'hunter2',
type: 'permanent',
scope: ['predictions']
});
console.log(session);
} catch (ex) {
// Handle general network or parsing errors.
return console.error(ex);
}
})();
Now you can make API requests:
let sunburst = new SunburstJS({
clientId: 'f78fe615-8eb1-48c4-be21-e5f4f437e8ba',
clientSecret: '18qwl0htsPX|[!NGQ@[qK{X;[&^EVzaH',
scope: ['predictions']
});
Here is an example of making four quality prediction requests:
(async () => {
try {
const now = new Date();
const thisTimeTomorrow = now.setDate(now.getDate() + 1);
const resp = await sunburst.batchQuality([
{
geo: [40.7933949, -77.8600012],
type: 'sunrise'
},
{
geo: [40.7933949, -77.8600012],
type: 'sunset'
},
{
geo: [40.7933949, -77.8600012],
type: 'sunrise',
after: thisTimeTomorrow
},
{
geo: [40.7933949, -77.8600012],
type: 'sunset',
after: thisTimeTomorrow
}
]);
resp.forEach(({ collection, error }) => {
if (error) {
// Handle individual query errors separately,
// as some queries may have still succeeded.
return console.error(error);
}
collection.features.forEach(({ properties }) => {
console.log(properties);
});
});
} catch (ex) {
// Handle general network or parsing errors.
return console.error(ex);
}
})();
More examples, for each endpoint: https://sunburst.sunsetwx.com/v1/docs
License
The source code is available under the ISC License.