Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yolgesanchez/typescript_user_api_template
Nodejs, JWT, Express, Typescript, Zod, MongoDB, Jest, Supertest
https://github.com/yolgesanchez/typescript_user_api_template
expressjs jest jwt mongodb mongoose nodejs supertest typescript zod
Last synced: 2 months ago
JSON representation
Nodejs, JWT, Express, Typescript, Zod, MongoDB, Jest, Supertest
- Host: GitHub
- URL: https://github.com/yolgesanchez/typescript_user_api_template
- Owner: YolgeSanchez
- License: mit
- Created: 2024-10-01T21:59:29.000Z (4 months ago)
- Default Branch: master
- Last Pushed: 2024-11-11T17:17:59.000Z (3 months ago)
- Last Synced: 2024-11-11T18:25:32.724Z (3 months ago)
- Topics: expressjs, jest, jwt, mongodb, mongoose, nodejs, supertest, typescript, zod
- Language: TypeScript
- Homepage:
- Size: 138 KB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# TypeScript Reusable User API Template
Welcome to the TypeScript Reusable User API Template! This project provides a robust foundation for building user management systems in your Node.js applications. Whether you're starting a new project or looking to integrate user authentication into an existing one, this template has got you covered.
## π Features
- User registration and login
- User authentication with email and password
- User management (CRUD operations)
- Role-based access control (RBAC) (optional)
- Logout feature
- Comprehensive test suite## π Quick Start
### Clone the Repository
```
git clone https://github.com/YolgeSanchez/typescript_user_api_template.git
cd typescript_user_api_template
```### Install Dependencies
```
npm install | npm i
```### Configure Environment Variables
Create a `.env` file in the root directory and add the following:
```
PORT =
DB_URI = ""
JWT_SECRET = ""
```### Run the Application
```
npm start
```The server will be running on the port you specified in your .env file.
### Run Tests
The project includes tests to ensure that the functionality is working correctly. To run the tests:
```
npm test src/tests/users.test.ts && npm test src/tests/auth.test.ts
```## π Usage
This template provides a solid foundation for user management in your API. You can build upon this base to create your specific product features, tasks, or any other functionality your project requires.
### Role-Based vs. Non-Role-Based Models
By default, this template includes role-based access control (RBAC). However, if you prefer a simpler model without roles, you can easily switch to the non-role-based version:
```
git checkout v1.0-not-role-based-api-model
```In case that you want to return to the role-based access control (RBAC) you can easily return to it with:
```
git checkout v2.0-role-based-access-control-model
```Alternatively, if you want to start with the non-role-based model from the beginning:
```
git clone -b v1.0-not-role-based-api-model https://github.com/YolgeSanchez/typescript_user_api_template.git
```## π» Getting Started for Development
1. Follow the Quick Start guide to set up the project.
2. Make sure you have Node.js (version 18 or later) and npm installed.
3. For development, you can use the following command to run the server with hot-reloading:```
npm run dev
```4. To build the project for production:
```
npm run build
```## ποΈ Project structure
This project follows a modular structure, which helps in organizing code for scalability and maintainability. The modular approach allows us to separate different concerns of the application, like user management, authentication, utilities, and middleware, into specific folders. Here's an overview of the structure:
```
βββ src/
β βββ config/ # Database configurations
β βββ middlewares/ # Custom middleware for authentication, validation, etc.
β βββ modules/
β β βββ auth/ # Authentication logic (login, registration)
β β βββ users/ # User management (CRUD operations, roles)
β βββ tests/ # Test cases for the API
β βββ types/ # TypeScript type definitions
β βββ utils/ # Utility functions (e.g., encryption, admin initialization)
β βββ app.ts # Main app configuration and middleware setup
β βββ server.ts # Server entry point, starts the application
β
βββ .env # Environment variables for development
βββ .env.example # Sample environment file for setup
βββ jest.config.ts # Jest testing configuration
βββ tsconfig.json # TypeScript configuration
βββ package.json # NPM dependencies and scripts
βββ .gitignore # Ignored files for Git
```### Why Modular?
The modular structure keeps the code organized, making it easier to scale and maintain. Each feature (like users or authentication) is in its own folder, allowing for quick updates or changes without affecting the rest of the app. It also promotes reusabilityβcommon functions and middleware can be shared across the project, avoiding duplication. Overall, this structure makes the project cleaner and more efficient to work with as it grows.
## π API Endpoints
Here's a brief overview of the main API endpoints:
[ only in role model ]
- POST /api/auth/register: Register a new user
- POST /api/auth/login: Authenticate a user
- GET /api/users: Get all users (requires authentication) [ admin & user ]
- GET /api/users/:id: Get a specific user (requires authentication) [ admin & user ]
- POST /api/users/ Create a new user (requires authenticatino) [ admin only ]
- PUT /api/users/:id: Update a user (requires authentication) [ admin only ]
- DELETE /api/users/:id: Delete a user (requires authentication) [ admin only ]## π οΈ Technologies Used
- Node.js
- TypeScript
- Express.js
- MongoDB
- Mongoose
- ZOD (for data validation)
- JSON Web Tokens (JWT)
- Jest and Supertest (for testing)## Customization
Feel free to modify and extend this template to fit your specific needs. The modular structure allows for easy additions and modifications.
## π€ Contributing
Contributions, issues, and feature requests are welcome! Feel free to check [issues page](https://github.com/YolgeSanchez/typescript_user_api_template/issues).
## π License
This project is [MIT](https://opensource.org/licenses/MIT) licensed.
---
Happy coding! If you find this template useful, please consider giving it a star on GitHub. For any questions or support, please open an issue on the GitHub repository.