First you will need to make a copy of the .env.example
file and rename it to .env
.
This file contains most of the environment variables that the project needs to run.
cp .env.example .env
Fill out the required variables in your .env
file.
Tip
For the AUTHBROKER_CLIENT_ID
, AUTHBROKER_CLIENT_SECRET
and AUTHBROKER_URL
variables, ask a member of the team to assist you in getting the values from the dev
environment.
In a terminal run the make setup
command from the project’s root directory.
make setup
Note
This command will run the initial migrations, create stub data and test users. A database named "fido" will be automatically created.
Open a second terminal and run the following to set up the frontend.
# install the dependencies
npm install
# start the dev server
npm run dev
You should now be able to access the application at http://localhost:8000/.
If you want full admin access, you can elevate your by running:
make elevate
Tip
Don't forget to refresh the page.
If you can connect to the dev environment but still have issues such as; 403 - Forbidden Error
on your local, there are few steps you can follow to resolve this:
-
Using dev tools on your browser, go to Application tab and clear data for Local Storage, Session Storage and Cookies.
-
If the problem persists you may need to temporarily pause your VPN while you work on FFT on your local.
docker-compose run --service-ports
We use Django Guardian for model instance level permissions https://github.com/django-guardian/django-guardian
Django Guardian should not be used directly. There is a set of wrapper functions in forecast.permission_shortcuts
These add an additional permission check for the user being able to view forecasts at all.
When adding data or non-auto generated migrations, please use the convention:
[number]_data_[date]_[time]
for example:
0004_data_20200501_1345
Run the chrome container:
docker compose up -d chrome
Build the frontend assets:
npm run bdd
Run the tests:
make bdd
4 management commands have been added to make dealing with user cost centre easier:
- add_user_to_cost_centre
- cost_centre_users
- remove_user_from_cost_centre
- user_permissions
The names of the management commands denote their function.
- Access Chart of Account Gifts and Hospitality Register
- Upload budget and Oracle actuals file
- Download Oscar report file
- View forecast (permission to view all forecast data)
- Edit 1 - n cost centres (specific user can edit cost centre data)
- Take the system off line
- Add username field to HistoricalUser table (max length 150, allow null)
- Amend the custom_usermodel table to be the same as the new User app one
- Add the user app initial migration to the list of django migrations that have been run
- Deploy new codebase
Add environment variable in your .env file
ENABLE_DEBUGPY=True
Create launch.json file inside .vscode directory
{
"version": "0.2.0",
"configurations": [
{
"name": "Python Debugger: Remote Attach",
"type": "debugpy",
"request": "attach",
"connect": {
"host": "0.0.0.0",
"port": 5678
},
"pathMappings": [
{
"localRoot": "${workspaceFolder}",
"remoteRoot": "/app/"
}
]
}
]
}