Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/raminmammadzada/tracking-api
Tracking API with an endpoint that accepts HTTP requests to identify unique users.
https://github.com/raminmammadzada/tracking-api
api-rest cookie-parser mocha mocha-chai nodejs
Last synced: about 1 month ago
JSON representation
Tracking API with an endpoint that accepts HTTP requests to identify unique users.
- Host: GitHub
- URL: https://github.com/raminmammadzada/tracking-api
- Owner: RaminMammadzada
- Created: 2022-04-23T12:34:52.000Z (almost 3 years ago)
- Default Branch: develop
- Last Pushed: 2022-04-27T08:42:28.000Z (over 2 years ago)
- Last Synced: 2024-12-07T16:24:39.153Z (about 2 months ago)
- Topics: api-rest, cookie-parser, mocha, mocha-chai, nodejs
- Language: TypeScript
- Homepage:
- Size: 293 KB
- Stars: 0
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Tracking API
It is a tracker API with 2 endpoints. It accepts HTTP requests and identifies unique users who have clicked the http://localhost:3000 url.
The structure of the project:
- `Route` configuration is done to define the requests our API can handle
- `Service` for tasks such as connecting to our database models, and doing queries is done. They can be connected to external services that are required by the specific request if needed.
- `Middleware` is added for running specific request validations before the final controller of a route handles its specifics.
- `Model` is added for defining visitors to facilitate data storage and retrieval.
- `Controller` is created for separating the route configuration from the code that finally (after any middleware) processes a route request, calls the above service functions if necessary, and gives a response to the client.I have also implemented [reporter app](https://github.com/RaminMammadzada/tracking-report-app) with Angular, which you can see the statistics of visitors in the user interface and can download it as a CSV file on demand. To test it out, you should up and run this API project first.
### Current architecture of the application
![alt text](./docs/images/diagram1.png)
### Architectural sketch of possible entire application with highly available API design
![alt text](./docs/images/diagram2.png)
### Built with the following tech stack
- Typescript
- NodeJS v14.18.x
- npm v6.14.x
- ESlint
- ES6+ module system is used.
- Mocha, Chai for unit testing.
- Sequelize ORM
- MySQL### Prerequisites
You will need to have the following tech stack installed in your local environment.- MySQL Ver 8.0.28
- NodeJS v14.18.x
- npm v6.14.x
- Typescript### Setup
Clone the repo by typing
```
git clone https://github.com/RaminMammadzada/tracking-api.git
```Cd into the project
```
cd tracking-api
```Install packages with
```
npm install
```Create .env file at the root of the project and fill in with the following information:
```
DB_NAME='tracking_api_dev'
DB_USER='your_mysql_username'
DB_HOST='localhost'
DB_DRIVER='mysql'
DB_PASSWORD='your_mysql_password'
```Create a database with the Sequelize-cli command
```
npx sequelize-cli db:create
```Migrate models with Sequelize-cli command
```
npx sequelize-cli db:migrate
```If all is set, you will have a database with the name `tracking_api_dev` created and 1 table called Visitors inside it.
Start server with:
```
npm run start
```For development you can use the following script:
```
npm run dev
```It will start running in PORT 3000.
You can test the following endpoints in the http://localhost:3000 url:The REST endpoints
```
/GET http://localhost:3000/
/GET http://localhost:3000/visitors
```### Unit tests
Run the following command to run the unit tests:
```
npm run test
```### Running with dockerfile
It is in TODO stage now.
It has a bug which is needed to be fixed.
For the sake of time I skipped it.## Author
👤 **Ramin Mammadzada**
- Github: [@raminmammadzada](https://github.com/raminmammadzada)
- Twitter: [@raminmammadzada](https://twitter.com/raminmammadzada)
- Linkedin: [Ramin Mammadzada](https://www.linkedin.com/in/raminmammadzada/)### Contributing
Contributions, issues, and feature requests are welcome!
Feel free to check the [issues page](https://github.com/RaminMammadzada/tracking-api/issues)
### Show your support
Give a star if you like this project!