Skip to content

Pulls and calculates adjective fire danger for San Luis Obispo County using data from the RAWS weather stations. It also stores the data for the last 90 days and creates graphs to represent the trends of fire danger within the county.

Notifications You must be signed in to change notification settings

SLUGIS/adjective_fire_danger

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Cal Fire Logo

Smokey the Bear/Adjective Fire Danger

View the final product here!

Pulls Data from the RAWS (Remote Automated Weather Stations) and uses the most recent adjective fire rating to determine fire danger for that specific day.

Workflow

Using a github actions cron command an action occurs every hour that runs scripts/xml_parser.py then pushes all new data to the github server. At 9 am on the local server another script gets run that updates the google sheet that creates the graph.

index.html

Start page of the adjective fire danger, uses bootstrap to manage all the different divisions.

index.js

This code grabs the data from the XML folder to display the correct Smokey the Bear image. Using the JavaScript library Leaflet it creates a map that shows the fire danger for all of the RAWS in SLO.

Functions

  • updatePage() - Initializes the map and legend then loops through all the stations that the website handles.
  • parseStation() - Gets the XML of the given station and sets the corresponding Smokey to it.
  • updateImg() - Tests to make sure the image reference isn't null then updates the correct Smokey based on it.
  • loadFile() - Opens the file and gets the text for the data required of Smokey.
  • createCircle() - Creates a circle on the map with the appropriate color, location and label

xml_parser.py

This script is run through an Ubuntu machine hosted by github. It uses the date and predefined station numbers to retrieve and store XML data from the WIMS web service to be processed later

Functions

  • main() - Retrieves and stores XML data for the current day and previous day to determine the adjective fire danger at each station listed: [LA_PANZA, LAS_TABLAS, SLO, SAN_SIMEON, BRANCH_MOUNTAIN, CARRIZO]
  • parse_xml() - Parses the XML tree for the adjective fire danger ratings that we want, writes data to file as well as print to console
  • get_xml() - Creates a url from the given variables to pull adjective fire rating data
  • get_dates() - Gets dates for today and yesterday as well as time in PST, Formats dates for correct usage in the URL

update_sheet.py

This code functions to update a google sheet that produces a graph representing the last 30 days of fire danger

Functions

  • main() - Updates the google sheet with the data pulled from the XML parser, gets run every day at 9 am locally on the x-drive
  • get_date_and_rating() - Gets the date and adjective fire rating for a particular station
  • get_sheet() - Gets the first sheet of the workbook that holds the fire danger rating
  • get_formatted_date() - Gets the formatted current date for checking correct data

update_database.py

A short script for updating the fire danger in the database connects to the Firestore Database then updates the documents that hold the adjective fire danger for the unit app

Functions

  • main() - Gets the database credentials, time and calls for an update to the database
  • update_document() Updates the documents in the Firestore that hold the Smokey Bear data

update_fire_danger.sh

This is the file that gets run on the x-drive every morning at 9 am and grabs the prediction for the adjective fire danger on that day. It runs scripts/xml_parser.py and scripts/update_sheet.py to update the google sheets that create the graphs for the last 30 and 90 days

sheets_update.bat

Old batch file, still can be used to update the google sheets manually if need be. Runs xml_parser and update_sheet to create the graphs for the last 30 and 90 days

Notes

  1. In order for you to use scripts/update_sheet.py you must have the fire_danger_secrets.json in the root directory for the project. DO NOT PUT THIS FILE ON GITHUB!
  2. In order for you to use the scripts/update_databse.py you must have the unitapp_admin.json in the root directory for the project. DO NOT PUT THIS FILE ON GITHUB
  3. The github actions script updates the text files in the github repo once an hour but does not do anything to update the google sheet. The x-drive runs the same xml_parser script once a day then uses that data to update the google sheet.
  4. Look on "Madonna" for more information.

About

Pulls and calculates adjective fire danger for San Luis Obispo County using data from the RAWS weather stations. It also stores the data for the last 90 days and creates graphs to represent the trends of fire danger within the county.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • HTML 47.7%
  • Python 26.6%
  • JavaScript 15.8%
  • CSS 5.6%
  • Shell 3.4%
  • Batchfile 0.9%