Express.js backend application that retrieves the BSE India Bhav Copy and employs various APIs to deliver diverse results.
- 
Download and install PostgreSQL (v13.11) and pgAdmin4 (v7.2) in your system. 
- 
Download and install Redis. 
- 
Download and install Git in your system. 
- 
Open your psql terminal and create a DB in your postgres engine named stocks. Use postgres as your user. - 
psql -U postgres -d postgres
- 
CREATE DATABASE stocks;
- 
\c stocks
 After this you will be connected to the stocksDB.
- 
- 
Clone this repo in your system and open in your IDE (eg: VSCode). 
- 
Run npm installin your root directory to install all the necessary dependencies.
- 
Run the following command in root directory to run the schema migration: - npx knex migrate:latest --env development
 
- 
Open bash terminal and change directory to ./src/scripts/.
- 
Run the following scripts in your bash terminal to perform the corresponding actions: - 
./downloadAndLoad.sh DDMMYY: Downloads, unzips and loads the data in DB of the Bhav Copy for the specified date.For example: ./downloadAndLoad.sh 220124.
- 
./lastFiftyDays.sh(optional): Downloads, unzips and loads the data of the Bhav Copies for the last 50 days in the DB.Note: Running this more than once will result in numerous duplicate data. 
 
- 
- 
Now, in your root directory, run the command npm run devto start the server.
- 
Finally, use Postman to test the APIs. 
First the API looks for data in the cache. When there will be a cache miss, it will fetch data from the DB.
Base Url: http://localhost:8080.
- 
GETroute to get the top 10 stocks for a particular date.- Endpoint: /top-stocks/YYYY-MM-DD.
- Example: http://localhost:8080/top-stocks/2024-01-01.
 
- Endpoint: 
- 
GETroute to find stocks by name.- 
Endpoint: /stocks.
- 
Example: http://localhost:8080/stocks?name=A.SARABHAIorhttp://localhost:8080/stocks?name=ARE%26M. Here %26 denotes '&'.Will return an array objects for the provided name for all the dates present in DB. 
 
- 
- 
GETroute to get stock price history list for UI graph. Takes json object as body with keys name (array of stock names), from (date YYYY-MM-DD) and to (date YYYY-MM-DD) (from <= to). If the date range from and to are not provided, it will return the price history for the given stocks for the last 10 days.- 
Endpoint: /stocks/history.
- 
Example: http://localhost:8080/stocks/history.JSON object in body: { "name": ["A.SARABHAI", "NUVOCO", "ARE&M", "BOM DYEING"], "from": "2024-01-19", "to": "2024-01-19" }. This will return result for the given date range. JSON object in body: { "name": ["A.SARABHAI", "NUVOCO", "ARE&M", "BOM DYEING"], }. This will return result for the last 10 days. 
 
- 
- 
POSTroute to add a stock to favourites.- Endpoint: /stocks/favourite/:sc_code.
- Example: http://localhost:8080/stocks/favourite/543334.
 
- Endpoint: 
- 
GETroute to see favourite stocks.- Endpoint: /stocks/favourites.
- Example: http://localhost:8080/stocks/favourites.
 
- Endpoint: 
- 
DELETEroute to remove a stock from favourites.- Endpoint: /stocks/favourite/:sc_code.
- Example: http://localhost:8080/stocks/favourite/543334.
 
- Endpoint: 
- 
./lastFiftyDays.sh: Will download, unzip, process and load the data of the Bhav Copies for the last 50 days (if available). Will fail for those dates for which data are not present on the BSE India website. Example: Just run the script as it is.
- 
./downloadAndLoad.sh: download, unzip, process and load the data of the Bhav Copy for the specified date (if available). Will fail for those dates for which data are not present on the BSE India website. Example:./downloadAndLoad.sh 200124(Write the date in the format DDMMYY).
- 
npx knex migrate:latest --env development: To update the schema to the latest schema.
- 
npx knex migrate:make <XXX_feature_name>: To create a new migration schema file. Convention followed: XXX should increase serially after the last file present in migrations directory.
- 
npx knex migrate:rollback: To rollback(undo) the current schema.
- 
curl --location 'http://localhost:8080/top-stocks/2024-01-18' 
- 
curl --location 'http://localhost:8080/stocks?name=a.sarabhai' 
- 
curl --location --request GET 'http://localhost:8080/stocks/history' 
 --header 'Content-Type: application/json'
 --data '{ "name": ["A.SARABHAI", "NUVOCO", "ARE&M", "BOM DYEING"], "from": "2024-01-19", "to": "2024-01-23" }'curl --location --request GET 'http://localhost:8080/stocks/history' 
 --header 'Content-Type: application/json'
 --data '{ "name": ["A.SARABHAI", "NUVOCO", "ARE&M", "BOM DYEING"] }'
- 
curl --location --request POST 'http://localhost:8080/stocks/favourite/543334' 
- 
curl --location 'http://localhost:8080/stocks/favourites' 
- 
curl --location --request DELETE 'http://localhost:8080/stocks/favourite/543334'