Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mansi1309/vrv-security-s-backend-developer-intern-assignment


https://github.com/mansi1309/vrv-security-s-backend-developer-intern-assignment

Last synced: about 1 month ago
JSON representation

Awesome Lists containing this project

README

        

# Role-Based Access Control (RBAC) UI

VRV Security’s Backend Developer Intern Assignment

## Deployment

-> To deploy this project run

```bash
npm install
```

-> Database Used Mongodb|| so start Mongodb service and import admin db using STUDIO 3T

#### OR CREATE

| DB NAME | ADMIN COLLECTION
| :-------- | :------- |
| `RBAC` | `admin` |

#### in admin Collection insert this data or create Like

```
{
"name" : "admin",
"email" : "[email protected]",
"password" : "$2b$10$Q4RBLd86dgJO1sFJjDxJa.jpahPgftOIuPzqX4DI1G2KY3AoSyjeC",
"role" : "admin"
}
```
### (GIVEN PASSWORD HASH VALUE IS 1 )

## Environment Variables

To run this project, you will need to add the following environment variables to your .env file (and manually added to this repo if unable to clone .env use this)
```
DB_URL=mongodb://localhost:27017/
DB_NAME=RBAC
USER_COLLECTION=users
ADMIN_COLLECTION=admin
MODERATOR_COLLECTION=moderators
JWT_SECRET=this-is-my-secret-key
SALT_ROUND=10`
```

-> TO RUN PROJECT

```
npm start

```
-> URL

```
http://localhost:3000/

```
## Reference

#### Methods
#### User Methods

```
GET / [root]seted as login
```

```
POST /
```
```
GET /signup
```
```
POST /signup
```
```
GET /dashboard
```
```
GET /logout
```
#### Admin Methods

```
GET /admin
```
```
POST /admin
```

```
GET /admin/dashboard
```
```
GET /admin/updateUser?
```

## Features

- USER PASSWORD HASHING AND AUTHENTICATION
- JWT AUTHERISETION
- MANAGE USER ROLES
- ROLE DASED ACCESS

## Tech Stack

**Client:** HandleBars, Bootstrap, TailwindCSS

**Server:** Node, Express,Mongodb,ExpreessGenartor,Bcript,JWT,

## Screenshorts
![image](https://github.com/user-attachments/assets/deb934fb-c7c1-4ed2-9f6d-942e84dc4fe0)

#### WHY OTHER REST API METHOD NOT USED ?

This is UI BASED ASSESSMENT SO OTHER METHODS NOT AVAILABLE IN MOST OF BROWSERS

#### Is Additionally can use OTHER METHODS?

Yes, by adding NEEDED ROUTES on project Routes wecan use other REST methods and also pass jwt token as barear Token for verify autherisation and authentication