This is a role-based authentication server built using Go and Fiber. It provides user registration, authentication, role management, and role-based access control. Users can sign up, log in, and be assigned different roles with specific permissions.
Getting Started
Prerequisites
Installation
Usage
API Endpoints
Features
Contributing
License
These instructions will help you set up and run the authentication server on your local machine for development and
testing purposes.
Visit the blog for step-by-step tutorial
https://medium.com/@tanveeshs/creating-an-role-based-authentication-server-using-golang-and-fiber-3367341cf7c5
You will need the following software and services installed:
- Go
- MongoDB
- Redis
- Clone the repository:
git clone https://github.com/Tanveeshs/Go-Auth-Server
- Navigate to the project directory:
cd auth-server
shell
- Install Go dependencies:
go mod tidy
-
Update the configuration:
Make sure your MongoDB and Redis server configurations are correctly set in the main.go file. -
Run the application:
go run main.go
The server should now be running at http://localhost:3000.
This section provides an overview of the server's features and how to use them.
The following API endpoints are available:
- POST /signup: Register a new user.
- POST /login: Authenticate and receive a JWT token.
- POST /addPermission: Add a new permission to a user.
- POST /adminTestRoute: An example route that requires admin access.
The authentication server uses industry-standard security measures, including:
- Password hashing for user credentials.
- JWT-based authentication and authorization.
- Role-based access control.
- Protection against common web vulnerabilities like SQL injection and XSS.
- Make sure to set strong and unique values for the SecretKey and any other sensitive configuration variables.
I welcome contributions to this project. To contribute:
- Fork the repository.
- Create a feature branch.
- Make your changes and commit them.
- Push to your fork and submit a pull request.
- Please ensure your code follows the project's coding standards and includes appropriate tests and documentation.
This project is licensed under the MIT License - see the LICENSE file for details.