Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hursey013/above-cville
What's flying over the City of Charlottesville, Virginia?
https://github.com/hursey013/above-cville
ads-b firebase firebase-realtime-database firebase-storage twitter-api twitter-bot
Last synced: 3 months ago
JSON representation
What's flying over the City of Charlottesville, Virginia?
- Host: GitHub
- URL: https://github.com/hursey013/above-cville
- Owner: hursey013
- Created: 2020-10-12T19:01:28.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2021-07-10T18:31:07.000Z (over 3 years ago)
- Last Synced: 2024-04-23T23:06:55.165Z (9 months ago)
- Topics: ads-b, firebase, firebase-realtime-database, firebase-storage, twitter-api, twitter-bot
- Language: JavaScript
- Homepage: https://twitter.com/abovecville
- Size: 352 KB
- Stars: 5
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# above-cville
> What's flying over the City of Charlottesville, Virginia?
## Introduction
Twitter bot which uses the [ADS-B Exchange](https://www.adsbexchange.com/) API to spot aircraft within a 2.5nm radius of the City of Charlottesville, VA ([38.0375, -78.4863](https://goo.gl/maps/sySAUH9KeKCYCrtG9)). Timestamps for each spotting are persisted to a Firebase Realtime Database.
## Initial setup
### Clone this repo
- Clone or download this repo and open the `above-cville` directory.
### Create a Firebase project
- Create a Firebase Project using the [Firebase Developer Console](https://console.firebase.google.com)
- Install [Firebase CLI Tools](https://github.com/firebase/firebase-tools) if you have not already, and log in with `firebase login`.
- Configure the bot to use your project using `firebase use --add` and select your project.### Install dependencies and add environment variables
- Install dependencies by running: `npm install`
- Provide the following environment variables in your .env file:```
ADSBX_KEY="api-key-here"FIREBASE_PROJECT_ID="my-app"
FIREBASE_PRIVATE_KEY="private-key-here"
FIREBASE_CLIENT_EMAIL="[email protected]"
DB_URL="https://my-app.firebaseio.com"TWITTER_ACCESS_TOKEN="access-token-here"
TWITTER_ACCESS_TOKEN_SECRET="access-token-secret-here"
TWITTER_CONSUMER_KEY="consumer-key-here"
TWITTER_CONSUMER_SECRET="consumer-secret-here"
```Further reading:
- [Setting up a Firebase project and service account](https://firebase.google.com/docs/admin/setup)
- [Twitter API credentials](https://developer.twitter.com/)
- [Accessing Data Collected by ADS-B Exchange](https://www.adsbexchange.com/data/)
- [Airport-Data.com API Documents](https://www.airport-data.com/api/doc.php)### Update configuration
There are a number of variables which can be customized by modifying `config.js`
- `actionPhrases` - short phrases to add to the beginning of the tweet
- `refreshSeconds` - how often to call the ADS-B endpoint
- `cooldownMinutes` - amount of time that should pass before spotting the same aircraft
- `maximumAlt` - filter out aircraft above this altitude
- `abbreviations` - abbreviations that should be kept uppercase
- `articles` - exceptions where a plane type should be an `An` instead of an `A` and vice versa
- `airport.dataUrl` - URL for thumbnail endpoint
- `adsbx.url` - URL for ADS-B endpoint
- `adsbx.lat` - latitude value used for geolocation
- `adsbx.lon` - longitude value used for geolocation
- `adsbx.radius` - radius for search in nautical miles### Download databases
`above-cville` relies on two static JSON files for aircraft types (`storage/aircrafts.json`) and operators (`storage/operators.json`) data. These files are regularly updated and can be downloaded from https://github.com/Mictronics/readsb-protobuf/tree/dev/webapp/src/db manually or through a cron job.
## Usage
To start the bot, run the following in the project directory:
```
npm start
```To run the included unit tests:
```
npm test
```## Inspiration
- [AboveTustin](https://github.com/kevinabrandon/AboveTustin) - ADS-B Twitter Bot. Uses dump1090-mutability to track airplanes and then tweets whenever an airplane flies overhead.