This is an app for stock queries, it's composed by two services: service api and stock service, the both were made in NestJS Framework
The service api uses Mongo DB to register the users and stock queries data.
The communication between the both services is through HTTP synchronous request.
The basic requirements were made, as well the following:
- Use JWT instead of basic authentication for endpoints
- Use containers to orchestrate the services.
- Use OpenAPI/Swagger to document the API.
- Add endpoint to reset user password sending an email with the new password.
The following features were made
- User register with email and role (user or admin). Password is generated and returned by API
- JWT authentication. Token duration is 1h
- Stock query search by symbol. Each successful request is stored with the user id
- Query history from each user (a user can only view the own historic)
- Stats data with the number of times that each stock was queried (just for admin users)
POST /register
POST /reset-password
POST /login
GET /stock
GET /history
GET /stats
The API specification with endpoints and parameters can be found in the Open API doc. Once the API is running, just access localhost:{port}/api. The default port is 3000.
The /reset-password
endpoint accepts a JSON like { "email": "[email protected]" }
. The SMTP used is Ethereal Mail. It's not a real SMTP. The sent emails won't be received by addressee, instead of that, the email will be received by Ethereal. To access this fake mail box, access Ethereal Mail and log in with email [email protected]
and password yaDWrSd2NaERx9sP9R
. Once logged in, go to the messages tab. The SMTP infos can be changed in docker-compose file.
The following features were made
- Research in external api to get stock queries
- Formats response as JSON
GET /?stock={stock}
This endpoint receives the stock query symbol and returns a formatted json with data. Returns status code 400 when the stock query is not found
The default port for this service is 3001
- First, a user is registered and get a password
- The registered users are stored in mongo db
- A registered user does login and get a 1 hours valid access token
- With the bearer access token, the user does a query for certain symbol
- The API Service calls Stock Service
- Stock Service calls the external API, get the response, format it, and return it to API Service
- If the result is found, API service responds the user request, and store the search data with the user id in mongo db
- A logged user can request by your stock queries search historic, which is retrieved from mongo db
- A user with an admin role can request by the symbols querieds and its number of solicitations. This is retrieved from mongo db
The services as well mongo db can be started with docker-compose. Just call docker-compose up
from the project root. The variables used by the services, as secrets, db credentials and urls, are all defined in docker-compose.yaml file, in the environment
section for each container. The services also can be runned outside docker, for that, run npm install && npm start
in the service project directory. In this case it is necessary to use a .env file to pass the environment variables.
Mongo container creates a directory .docker/ in the project root directory to persist data through a volume. It's necessary writing permission in the project root directory, or just remove the volume from docker-compose.yaml file in the mongo section
In addition to services and mongo, docker-compose also ups a mongo-express instance. It just provides a web graphical interface to mongo db. For use it, access localhost:8081