The purpose of this repository is to have a tested MERN app template with user authorization setup implemented, which could be used as a starting code for further app developments.
Functionally wise, app template includes the user registration and login forms, navigation bar, empty pages for app description, user profile, main app page, settings.
Registration form checks that email, password and family name are entered correctly and match standard patterns. Email address is supposed to be unique, so app checks whether entered email is already registered.
Login form allows user to actially login and to remember username so this would not to be necessary to enter it the next time user visits the app. Email input does the same email pattern check in order to prevent typos and useless initally wrong API calls.
Navigation bar provides pretty standard functionality - before login it provides the possibility to navigate to the app description, register and login pages. After login, it has the following destinations: user profile, app settings, log out, app itself. Currently all the destinations except login and registration forms are simply empty pages.
The app is dockerized. Please pay attention to the related explanations regarding environmental variable in backend chapter.
Please find below the list of components used in the projects and some remarks about software structure, logic.
This is pretty standard Express app with the following additional packages:
- Express itself. Currently only 2 routes are partially implemented - users and user roles. There is a script in the folder "config" which is called every app startup, which checks / automatically creates admin user, user roles. Do not forget to modify or delete it if you do not need it. Admin role, as well as Developer and Recruiter roles are just names. The only difference is that admin user can get all the app roles including admin role, others cannot.
- Passport, JWT strategy. There is a separate file in the folder keys which is not called in the main program - it can be used to generate new pair of keys. So far there is no special reason to use asyncronous cyphering with private and public keys, but I decided to have it for future options not to refactor the code later.
- Mongoose, MongoDB, dotenv. Please find below the list of environmental variables as well as please check database initialization config file which is called every time app starts. The idea behind is to get right URI string to the MongoDB depending on the way app is started. Therefore there are several options in the package.json file, which start the app with different environmental variables. The example of env file is supposed to look like this: PORT=5000 DEV_DB_URL=mongodb://localhost:27017 PROD_DB_URL=mongodb://localhost:27017 DOCKER_DB_URL=mongodb://mongo:27017 COOKIE_TIMEOUT=600 DB_NAME=webapp_template
- Jest, Supertest npm packages for API tests.
- Jest-puppetier, Puppeteer npm packages for e2e tests.
The following components are tested in the app:
- All the API calls, which follow the logic of the app - registering the new user with right / wrong / existing data, login with right / wrong credentials, getting "admin" resourses with admin / normal user.
- End-to-end test with full cycle of user actions including: navigation, registration of a new user, login, logout.
Frontend is based on the standard React app with the following additional packages:
- Axios - all the API requests are organized using this npm package. In order to be more flexible in maintaining changes in API, hosting of the app, I decided to put networking and API settings, addresses to a separate folder and file. Even API routes are split and assembled into a final string gradually as it is needed in the app.Please check setting folder fo rthe details.
- React-Redux - currently there are two main slices in the template: user data and app state. The idea is to have central storage for the current user data and to be able to get it from any part of the app. App state is used to organize navigation in the app. Standard React Router looked not convenient for the app strategy I decided to place the name of the currently rendered component in Redux store. Now navigating to the other part of the app is very simple - it is necesary just to dispatch the name of the component to be navigated to.
- MUI CSS styles, components and icons - I like their flexibility and integration with React.
- React-cookie - so far only the following information is stored in the cookies website: whether user has confirmed cookies policy, user email (in case user chooses the option to remember it) to avoid entering it every time user visits site, JWT token after successful login
- Axios mock adapter npm package - convenient package for mocking API calls.
- Redux mock store npm package - to mock Redux store calls.
The testing is coded using native react testing library and small additional packages mentioned above. The following components are tested in the app:
- Functions, which check the correctness of the email, password, user family name and generate helper text for input fields
- Navbar - test checks the availability of all the options on the screen and the correctness of the dispatch calls for the navigation purposes.
- Login, Register components - test checks the availability of elements within component, the correctness of helper text depending on user input, the correctness of API calls and dispatch calls.
The following features are under development right now:
- Currently JWT tocken has a predefined lifetime and can be received / renewed only during login procedure. The intention is to update it automatically as long as browser window is opened. Another option is to renew it with any action user takes on a website. Necessary API is already implemented, frontend is yet to be updated.
- User profile component with the possibility to edit own data, delete own profile
- Admin panel admin to be able to see the list of al users, to delete users, to assign admin rights to other users.
Here are some screenshots of the app: