Skip to content

Latest commit

 

History

History
106 lines (67 loc) · 3.66 KB

README.md

File metadata and controls

106 lines (67 loc) · 3.66 KB

GitHub Stats

Tech Stack: Node.js, Typescript, Nest.js

Requirements

  • Node v16.13.2 or higher

Run Application Locally

$ git clone
$ npm install
$ create a .env file in the root of the project with a variable named GITHUB_API_KEY. The value will be sent by Turtle platform.
$ npm run start:dev

API Docs

[Swagger] http://localhost:300/api-docs

Tests

# unit tests
$ npm run test

# test coverage
$ npm run test:cov

Linter and formatting

# find problems
$ npm run lint

# find and fix problems automatically
$ npm run lint:fix

# format code
$ npm run format

Architecture design

  1. The endpoints are organized following Nest.js standard structure of Modules, Controllers and Services. The entry point module is the app.module that imports the other needed modules to make the endpoints available. This structure wraps all the endpoint dependencies inside a module and applies the singleton design pattern when creating objects (done by nest.js in the background).

  2. The src/core folder contains shareable resources that are used throughout the application and are not related to a specific functional requirement.

Error handling and logging

Errors are handled by a global nest interceptor created in src/core/request-interceptor/request.interceptor.ts and configured in src/main.ts. This interceptor catches any error thrown in the application and makes sure that is going to be returned in a standard format.

This same interceptor is also responsible for logging operation start, end and error with relevant data.

Input validation

All the input typings carry its own validations using class-validator decorators. The validations are triggered by a global nest.js validation pipe created in src/core/api-validation-pipe.ts and configured in src/main.

Folder Structure

The API design follows the basic Nest.js structure with modules, controllers and services. Clients are used to interact with external APIs. Nest.js interceptors are used to monitor the request flow, catch errors and log operations. Nest.js validation pipes are used to validate input to API endpoints.

> src
  > clients                         (clients to interact with external APIs, ex: GitHub API)
  > core                            (files that are used all over the API)
     > error                        (files to do the error handling and format API errors)
     > request-interceptor          (Nest.js interceptor to catch errors and do API logging)
     > api-validation.pipe.ts       (Nest.js pipe to validate DTOs)
     > swagger-response.ts          (abstraction to add and reuse swagger responses)

  > modules             (the modules of the application separated by domain, ex.: commits)


  > typings             (contains all the API typings)
  > main.ts             (application entrypoint)

> test
  > integration      (integration tests mocking github external api)
  > mocks            (mocks used all over the tests)
  > unit             (unit tests)


Improvements

Interaction with GitHub API: a personal token with read-only permission to public repos is being used to interact with the GitHub API. A better solution here would be having this token stored in a secrets manager or in a vault, and in the local environment using a environment variable.

Performance: limiting the periods for searches or receiving pagination parameters in the backend could avoid performance issues.

Dates: validating the date formats could avoid internal errors.