Skip to content

Full-Stack project created during the JLT Bootcamp Program (2023) – a web application focused on facilitating dog adoption.

Notifications You must be signed in to change notification settings

Afek-Sakaju/dog-adopters

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Dog Adopters

This full-stack project was developed as a practice exercise to deepen my understanding of specific technologies and concepts. It served as the final project during my time at Just Like That (2023). The project focuses on creating a mock web application for dog adoption.

Frontend

Command lines:

  • First enter the 'client' folder

  • npm install
    Install all the necessary packages for running and developing the project.

  • npm run start
    For running the project.

  • npm run storybook
    To run all the stories for the components used in this project as part of the design system.


Get a glimpse of the app in action

Short.Demo.mp4

The technologies used in this project include:

  • ReactJS : the project is built on the ReactJS framework.
  • Webpack The project was built using Webpack.
  • Material-UI The project's design system is implemented using MUI components library.
  • Styled-Components : the project's styling is implemented using styled-components.
  • Redux-toolkit : by employing Redux-toolkit, the project achieves resilient state management, enabling seamless data flow and heightened functionality.
  • React-router-dom : enabling the creation of multiple pages and configuring different page for each path.
  • i-18n : The project utilizes i18n to enable a robust infrastructure for multi-language support, ensuring smoother text management and implementation.
  • Formik : all the forms logic have been implemented using the Formik package.
  • yup : implemented forms validation logic using yup.

Additional technologies used as development tools include:

  • Storybook : The project's design system is integrated with stories, enabling the use and debugging of components' UI and functionality through Storybook.
  • ESLINT : the project adheres to the ESLint guidelines and follows the best practices recommended by airbnb.

In addition, the project incorporates the following features:

  • Responsiveness: the application is intentionally designed to adapt to screens of various sizes.
  • Integration with cloudinary API: for background removal of uploaded products’ images to enhance the UI and overall aesthetics.

Back-End


The project stores data in a database and provides access through REST APIs, these APIs are developed using NodeJS, typescript, and express ts.

For authentication and users For dogs data
+ Register user + Get dog by id
+ Login user + Get dog list with filters and sorting options
+ Logout user   - Authentication is required
+ Get user by id   - Pagination included in the response
  - Authentication is required + Create new dog
  - Authentication is required
  - Owner id is auto-assigned from the authenticated user
+ Update exists dog data
  - Authentication is required
  - Only owner/admin allowed to operate
+ Delete exists dog
  - Authentication is required
  - Only owner/admin allowed to operate
+ upload dog profile image file
  - Authentication is required
  - Only owner/admin allowed to operate
+ get available dog breeds in db for future filters
  - Authentication is required
  - Only owner/admin allowed to operate

In addition, the project boasts extensive Swagger API documentation, covering all the REST APIs mentioned above, accessible at:
http://localhost:3000/swagger

NOTE: Certain APIs necessitate authentication, requiring users to log in before executing them. These authenticated APIs are denoted by a lock symbol.
APIs that require authentication


Command lines

  • First enter the 'server' folder

  • The command to init and install project

    • npm install
  • The command to run the project

    • npm run start
      (executing migrations, building the TypeScript code, and running the compiled JavaScript project)
  • Additional commands that are optional

    • npm run migrationDB
      (runs only migration)
    • npm run dev
      (runs typescript code for development with nodemon)
    • npm run test
      (runs only tests with jest + supertest for APIs tests)

Test Coverage:

coverage

The technologies used in this project include:

  • Nodejs : the project is javascript based.
  • Express : used for the server side routers, middlewares, controllers, and services.
  • Typescript : the project has been implemented using typescript interfaces, <filenames>.d.ts declarations files, etc..
  • DotEnv : utilizes dotenv files to manage environment variables, and incorporates dotenv-expand to enhance flexibility in the env files.
  • logger : utilizes colorized Winston logs with request ID (UUID) for recording server activities stored in daily rotating files (winston-daily-rotate-file).
  • Passport : authentication with passport-local strategy {username, password} for request body.
  • MongoDB : utilized with the mongoose library for defining schemas and models, which are then utilized in the controllers and services.
  • Bcrypt : user passwords are securely encrypted in accordance with best practices to ensure data security.
  • Swagger : the /swagger URL provides comprehensive API documentation and instructions for testing and debugging APIs,this functionality is available in non-production environments (for development), the project also utilizes mongoose-to-swagger to transform mongoose models into Swagger schema docs.
  • mongo-migrate : the migrations ensure that the MongoDB database has the latest updates of the data before running the project, they also handle important database initializations, including users creation and mocked dogs data.
  • express-rate-limit : to prevent cyber attacks like brute-force on the login API, user requests to specific APIs are restricted with a maximum number of attempts.

Additional technologies used as development tools include:

  • nodemon : watches for typescript file changes and compiles them in real-time.
  • Jest : Comprehensive typescript tests with extensive coverage, including password encryption, models, services, and router APIs, have been implemented using the supertest package.
  • mongodb-memory-server : running tests on an in-memory database, allowing for efficient and isolated testing.

In addition, the project incorporates the following features:

  • aggregations : a fully featured aggregate request filters dogs based on query parameters, populates the dog by its creator, and supports data limiting, offsetting, and sorting options.
  • transactions : the project does not incorporates multiple operations for a single process action, despite being aware of the concept.
  • server side pagination : the project implements pagination for the aggregation result data, enabling fetching a limited number of items based on the provided page number and items per page parameters.
  • Integration with cloudinary API: for easier saving of the dogs images.
{
"pagination": {
    "totalItems": 487,
    "page": 5,
    "itemsPerPage": 20,
    "totalPages": 25
},
"data": [...]
}
  • passport authentication : user authentication in the project follows best practices by comparing the encrypted password with the plaintext password provided.
  • override toJSON data : exclude the password from the user object when it is returned as JSON.
  • mongoose schema hooks : incorporates a pre-save hook that encrypts the user's password before creating a new user.
  • status code : HTTP request responses return the appropriate and correct status codes.
  • jest : comprehensive tests for thorough validation of all services and functions.
  • postman : postman collection for simplified testing and interaction with the project's APIs :
    dog_adopters_rest_api.postman_collection.json

Author

:octocat: Afek Sakaju

About

Full-Stack project created during the JLT Bootcamp Program (2023) – a web application focused on facilitating dog adoption.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published