Repo includes both backend and frontend code. Backend is made with nodejs 8.13.0, express, Jest for testing and includes middleware functions for role checking.
#Folder structure
- build: Compiled files for frontend. More info in Installation.
- api: Main API folder
- config: Stores the endpoints configuration
- middleware: Includes the pre made server responses for API and some helper functions like find, verify and hasAccess
- find: Generic logic to find/filter information inside the legacy endpoints
- verify: First check for required headers
- hasAccess: Role control
- roles: Main role configuration
- routes: Includes all the routes for the API (User and Policies)
- test: Test files to be executed by Jest
- public: Main html file to be executed by frontend
- src: React source files
#General comments
The following are comments or observations related to the code and delivery:
- Frontend
- React-virtualized was analyzed but then discarded due to compatibility issues with Material UI. After doing pagination the performance was acceptable and not needed.
- Snapshot testing could be added to further increase the unit testing.
- Test Coverage could also be added. (Preferred platform is Istanbul)
- API
- Babel could be implemented in API but implementation effort was not deemed necessary to only transpile import/export.
- Roles should be loaded async from database.
- Client endpoints should not be used in production environment since the information for authorization is inside the same response. Security issue.
- x-user header should be a token and /login endpoint should exist. Authentication in this API is mostly cosmetic and for demostration. Has no real use in production since it is easily bypassed.
#API
##Intro
API can be installed by either npm or yarn. Package has specific version codes and has tested with node 8.13.0
##Installation and Execution
- Execute npm i or yarn inside api folder
- Execute yarn start or npm start
##Examples
User by ID
curl -X GET \
http://localhost:3005/v1/user/id/a0ece5db-cd14-4f21-812f-966633e7be86 \
-H 'Postman-Token: 1d972e80-109c-4872-8f3d-9669c4f15006' \
-H 'cache-control: no-cache' \
-H 'x-user: Britney'
User by Name
curl -X GET \
http://localhost:3005/v1/user/name/Barnett \
-H 'Postman-Token: c81dca87-286a-460c-94ab-60713e6dba84' \
-H 'cache-control: no-cache' \
-H 'x-user: Britney'
User Policies
curl -X GET \
http://localhost:3005/v1/user/name/Britney/policies \
-H 'Postman-Token: f0f59166-9c19-4a2c-ad4e-378fb4f8b148' \
-H 'cache-control: no-cache' \
-H 'x-user: Britney'
User by Policy
curl -X GET \
http://localhost:3005/v1/user/name/none/policies \
-H 'Postman-Token: 4c39101c-6a9f-4dff-9943-1a7ff14072a0' \
-H 'cache-control: no-cache' \
-H 'x-user: Britney'
Not Authorized Example
curl -X GET \
http://localhost:3005/v1/policy/4f744ead-f4ff-498e-9d5f-fd6819cd4c77/user \
-H 'Postman-Token: b4aa8b35-f8b9-4c5e-96b2-93f99a387e59' \
-H 'cache-control: no-cache' \
-H 'x-user: Barnett'
##Testing
Jest unit testing is included in repo. Just execute 'npm test' or 'yarn jest' from inside the api folder. Should take around 30 seconds.
#Frontend
##Intro
Frontend has been done with React, Webpack, and Material UI. Material UI was chosen in order to provide a quick UI layour consistent with Material Design. Create-React-App was used for the app skeleton with a webpack blackbox setup.
##Installation and Execution
- Execute npm i or yarn inside root folder (altran-app)
- Execute yarn start or npm start
- Wait for the code to compile and open the browser or go into http://localhost:3000/
##Features
Since the JSON consist of more than 1300 records a pagination approach was used, in order to minimize the DOM size and improve performance.
Table can be sorted (Initially sorted by name asc) and search within records. The fields that will be searched are: name, age, weight, height, hair color and professions.
When clicking on each table record a modal will appear. Two collapsible sections (Friends and Professions) will be available there that are not fitted in the table.
##Testing
Jest unit testing is included in repo. Just execute 'npm test' or 'yarn jest' from inside the root folder. If the test dont run because they dont detect changes, press 'a'