Skip to content

Latest commit

 

History

History
151 lines (148 loc) · 4.95 KB

README.md

File metadata and controls

151 lines (148 loc) · 4.95 KB

Forex-Rest-Api

Description

Forex-Rest-Api is a simple Rest API which scraps the data from https://www.investing.com and sends it to the user whenever call to the API is made. Please visit https://forex-rest-api.herokuapp.com/ for quick testing


Requirements

  • Python 3
  • pip3
  • compatible chromedriver (according to your operating system)

Dependencies

To install all the dependencies of the project run the following command while in project directory

pip3 install -r requirements.txt

Usage

  • Running it locally

    1. Clone this repo or zip download it.
    2. Install all the dependencies
    3. Download compatible chromedriver (according to your operating system)
    4. Copy the path where you have downloaded the chromedriver and run following command in the terminal or cmd:
      • For Windows:
        set path=<path to your chromedriver>
      • For macos and linux
        export path=<path to your chromedriver>
    5. Open a terminal or cmd at downloaded or cloned folder directory.
    python3 app.py
    1. This step will start a flask server at the localhost port 3000, Now go to http://localhost:3000/
    2. Test the API using provided Swagger UI or make a postman GET request to http://127.0.0.1:3000/api/forexInfo/
  • Testing it on my Heroku server


Design Decisions

  1. In forex_scraper/fetch_html_source.py file, I made the decision to select the Option via Value instead of index, Because the index is prone to change if a new currency is add or a currency is removed from the list. So for that reason choosing by Value made more sense to me.
  2. In forex_scraper/fetch_html_source.py file, I have implemented a design in which my webdriver waits for the specific content to load before scraping the page source and returning. I choose to do this because I saw that when we select an option from the select menu, The server loads that data via Ajax requests, Which means sometimes it takes just few seconds to completely load that data on the page. For that reason I wait on the web page until a specific content is not loaded up. If that particular content takes more than 10 seconds to load a timeout exception is raised (the time to be waited for can be increased to any arbitrary number)

Output

Output is sent back in json format, may look something like:

{
  "EUR/AUD": {
    "ask": "1.6557",
    "bid": "1.6547",
    "change": "+0.0058",
    "change_percent": "+0.35%",
    "high": "1.6586",
    "low": "1.6497",
    "timestamp": 1602881992,
    "title": "EUR/AUD - Euro Australian Dollar"
  },
  "EUR/CAD": {
    "ask": "1.5461",
    "bid": "1.5451",
    "change": "-0.0017",
    "change_percent": "-0.11%",
    "high": "1.5511",
    "low": "1.5437",
    "timestamp": 1602881996,
    "title": "EUR/CAD - Euro Canadian Dollar"
  },
  "EUR/CHF": {
    "ask": "1.0729",
    "bid": "1.0721",
    "change": "+0.0015",
    "change_percent": "+0.14%",
    "high": "1.0731",
    "low": "1.0699",
    "timestamp": 1602881993,
    "title": "EUR/CHF - Euro Swiss Franc"
  },
  "EUR/GBP": {
    "ask": "0.9075",
    "bid": "0.9070",
    "change": "+0.0010",
    "change_percent": "+0.12%",
    "high": "0.9110",
    "low": "0.9044",
    "timestamp": 1602881992,
    "title": "EUR/GBP - Euro British Pound"
  },
  "EUR/INR": {
    "ask": "86.0990",
    "bid": "86.0380",
    "change": "+0.1235",
    "change_percent": "+0.14%",
    "high": "86.1335",
    "low": "85.7720",
    "timestamp": 1602881992,
    "title": "EUR/INR - Euro Indian Rupee"
  },
  "EUR/JYP": {
    "ask": "123.55",
    "bid": "123.47",
    "change": "+0.08",
    "change_percent": "+0.06%",
    "high": "123.73",
    "low": "123.12",
    "timestamp": 1602881992,
    "title": "EUR/JPY - Euro Japanese Yen"
  },
  "EUR/NZD": {
    "ask": "1.7746",
    "bid": "1.7729",
    "change": "-0.0004",
    "change_percent": "-0.03%",
    "high": "1.7775",
    "low": "1.7716",
    "timestamp": 1602881995,
    "title": "EUR/NZD - Euro New Zealand Dollar"
  },
  "EUR/SEK": {
    "ask": "10.3779",
    "bid": "10.3598",
    "change": "-0.0184",
    "change_percent": "-0.18%",
    "high": "10.4087",
    "low": "10.3458",
    "timestamp": 1602881996,
    "title": "EUR/SEK - Euro Swedish Krona"
  },
  "EUR/USD": {
    "ask": "1.1721",
    "bid": "1.1717",
    "change": "+0.0013",
    "change_percent": "+0.11%",
    "high": "1.1746",
    "low": "1.1694",
    "timestamp": 1602881992,
    "title": "EUR/USD - Euro US Dollar"
  },
  "USD/EUR": {
    "ask": "0.8535",
    "bid": "0.8532",
    "change": "-0.0006",
    "change_percent": "-0.08%",
    "high": "0.8552",
    "low": "0.8514",
    "timestamp": 1602881992,
    "title": "USD/EUR - US Dollar Euro"
  }
}