Skip to content

Latest commit

 

History

History
104 lines (81 loc) · 4.91 KB

README.md

File metadata and controls

104 lines (81 loc) · 4.91 KB

CerbFinance System

CerbFinance is a expenses tracking system used companies to submit, track and approve expenses.

It has 5 different user roles:

  • User - regular users who submit expenses
  • Region Manager - managers of a particular region eg EMEA or NA
  • Finance - members of the finance team that approve expenses
  • Finance Manager - managers within the finance team
  • Admin - the IT team who manage the system

Inside the system there are 5 actions:

  • View an expense
  • View who approved an expense
  • Update an expense
  • Approve an expense
  • Delete an expense

The Server

This repo contains a basic node express app server which has a dummy database of users and expense resources (see db.js).

There are 3 versions of this server in seperate files, to run each:

  • node app.basic.js is the basic server with no permissiosn checks
  • node app.hardcoded.js is the server with permissions logic hardcoded into the app
  • node app.cerbos.js is the server with permissions being handled by Cerbos. This makes use of the Demo PDP from this playground instance which holds the policies.

Each server runs on port 8000.

Calling the service

Authentication is emulated via passing the user value in a Authorization header. The users built into the demo database are:

Users

User Roles Department Region
sajit ADMIN IT
sally USER Sales EMEA
joe USER Finance EMEA
jamie USER, MANAGER Finance EMEA

Expenses

Note: Relative created at values are based on server start time (in order to simulate conditions)

ID Created At Owner Region Amount Status
expense1 Two months ago sally EMEA $500 OPEN
expense2 Two hours ago sally EMEA $2500 APPROVED
expense3 Five minutes ago sally EMEA $1200 OPEN
expense4 2021-10-01 joe EMEA $2421 OPEN
expense5 Two hours ago sally EMEA $2500 REJECTED

An example cURL commands would be:

curl -X GET 'http://localhost:8000/expenses/expense1' -H 'Authorization: sally'
curl -X PATCH 'http://localhost:8000/expenses/expense1' -H 'Authorization: sally'
curl -X DELETE 'http://localhost:8000/expenses/expense1' -H 'Authorization: sally'
curl -X POST 'http://localhost:8000/expenses/expense1/approve' -H 'Authorization: sally'

Permissions Logic

These logic for who can do what is as follows:

Role View Expense View Expense Approver Update Expense Approve Expense Delete Expense
Admin
User IF they created the expense IF they created the expense AND it is APPROVED IF they created the expense AND status is OPEN IF they created the expense AND status is OPEN AND it was created in the last hour
Region Manager IF they are the manager for the region the expense was created for
Finance IF they did not create the expense AND amount <$1000
Finance Manager IF they did not create the expense

Expected Results

User/Expense Action expense1 expense2 expense3 expense4 expense5
sajit view
view:approver
update
approve
delete
sally view
view:approver
update
approve
delete
joe view
view:approver
update
approve
delete
jamie view
view:approver
update
approve
delete