/flyberry_task

Federal Reserve Site Mining API

Primary LanguagePython

FOMC Site Mining API

###Test Server

http://jimhagan.us/fed/fomc

Commonly used URLS

http://jimhagan.us/fed/fomc/calendar?stringify=False&transpose=False

http://jimhagan.us/fed/fomc/pace_of_firming?stringify=False&meeting_name=FOMC_2014_MARCH,FOMC_2014_JUNE

###Developer's Notes

This exercise was fun and engaging I spent about 8 to 10 hours in total I got the service stood up and about 70% of the parsing written prior to leaving for vacation. I then was not able to get back to the task until the 18th of January. I would suggest the following refactors...

  • sqlite should be replaced by mongo or some other scalable data store
  • a scheduled asynchronous job should be used to refresh the data. Currently I'm using a hack that checks for refresh on the web view function which is not a production level practice.
  • I would also like to use something like an MD5 signature against each scraped page so that I could tell if the current page were identical to one previously scraped. If so, I wouldn't bloat th data store with previously scraped data.
  • Finally, I'd like to improve the data shaping of the JSON version of the projection tables.

###Usage

The basic URL prefix for all queries is: /fed/fomc Calling this prefix without any other paramters will return the version info for the service.

For example...

{"status": "ok", "version": "1.0", "data":  
"{"last revised": "January 7, 2015",   
"source repository\": "https://github.com/JimHagan/flyberry_task.git\","description": 
"Federal Reserve Information API\", "author":  
"Jim Hagan"}"}

If a query is successful, an "ok" response will be returned with HTTP response code 200:

{ "status": "ok", "version": "version_num","data": "" }

If a query is unsuccessful, an "error" response will be returned:

{ "status": "error", "code": "short_code","message": "A longer description of the error" }

For example, entering an unknown URL will return the fact that a 404 error occcured in our custom JSON format.

Example...

{"status": "error", "message": "404 Error", "code": "404"}

###Sample URLs

#####Calendar Method

http://jimhagan.us/fed/fomc/calendar?transpose=false&stringify=false

http://jimhagan.us/fed/fomc/calendar?transpose=false&stringify=false&columns=scrape_date,meeting_name,projections,statement

http://jimhagan.us/fed/fomc/calendar?columns=meeting_name,projections,scrape_date

http://jimhagan.us/fed/fomc/calendar?columns=meeting_name,projections,scrape_date&transpose=false&stringify=false

http://jimhagan.us/fed/fomc/calendar?transpose=false&stringify=false&columns=scrape_date,meeting_name,statement_url

http://jimhagan.us/fed/fomc/calendar?transpose=false&stringify=false&columns=projections,scrape_date,meeting_name,projections_html_url,projections_pdf_url

#####Pace Of Firming Method

http://jimhagan.us/fed/fomc/pace_of_firming

http://jimhagan.us/fed/fomc/pace_of_firming?stringify=False

http://jimhagan.us/fed/fomc/pace_of_firming?stringify=True&meeting_name=FOMC_2014_MARCH,FOMC_2014_JUNE

http://jimhagan.us/fed/fomc/pace_of_firming?meeting_id=4326

http://jimhagan.us/fed/fomc/pace_of_firming?meeting_id=4326,4328

http://jimhagan.us/fed/fomc/pace_of_firming?begin_release=1401595200000.0

http://jimhagan.us/fed/fomc/pace_of_firming?begin_release=1401595200000.0&end_release=1404172800000.0

http://jimhagan.us/fed/fomc/pace_of_firming?begin_scrape=1420848000000.0

http://jimhagan.us/fed/fomc/pace_of_firming?end_scrape=1420848000000.0