iss_node
iss_node is a module that generates a readable stream based on a given satellite's location in orbit. All data comes from the wheretheiss.at API: http://wheretheiss.at/w/developer, and is wrapped using Node's stream.Readable API.
This project was an exercise in learning about the Node streaming API. It works, and has test coverage, but there may be bugs. Please submit pull requests for any issues you may come across.
This repo also contains documentation for a Batch animation class, unrelated to ISS. This documentation is in assignment_3.md
Installation
(Assumes you have Node and NPM installed)
-
Clone this repository locally and
cd
into it -
Type
npm pack
, which will create a .tgz of the repo in the same directory -
cd
to the top-level directory for your project where you are using iss_node -
Type
npm install path/to/filename.tgz
, which will install the module in your node_modules folder, or it will create the folder if none exists. -
You can equally run the example files within this repo. from your command line.
Use
Require the module, and set it equal to a constructor, i.e: var SpaceStream = require('iss_node')
A stream takes two parameters:
- Satelite ID (the NORAD id for a satelite: They are available at http://www.celestrak.com/pub/satcat.txt)
- Frequency (The number of times per minute to request new data from the wheretheiss.at API: e.g. 30 = one request every .5 seconds, .5 equals one request every two minutes. Must be greater than 0, less than 60).
- Consume the stream however you wish. Please refer to Node's documentation for more info: http://nodejs.org/api/stream.html.
- Refer to the two examples in the "examples" folder for more implementation details.
Examples
- streamDemo.js --- Creates a new stream for the ISS (25544), makes requests 30 times/minute, and pipes the result to process.stdout
- deltaLatLong.js --- Implements a Transform stream that changes a satelite location object into a new object that shows the rate of change per minute of latitude, as well as the rate of change per minute of longitude. Calculation details are in the file.
Tests
(Assumes you have mocha installed globally)
Tests for this module are written in Mocha, are located in the test/ directory, and can be run from the top level of the iss_node directory with:
npm test
Contact
If you have any questions or concerns, you can reach the developer at taylor.harwin@gmail.com, or on Twitter: @taylorharwin