This project will create a matching service to connect placement students with potential employers. Using a “dating” service metaphor, the site will allow employers to post details of placements available and students to apply for placements. The aim of the project is to create a database-driven mobile-friendly website to encourage employers and students to engage in year-long paid industrial placements as part of an honours degree programme.
The project comprises three main elements:
- placement descriptions;
- student capabilities;
- matching algorithm.
Users (employers and students) will need to be able register with the site and store details of placements and capabilities. Some persistent storage will be required to retain placement details, student capabilities, and user credentials.
The project will be made available with an MIT license.
Julian M. Bass
Senior Lecturer (Associate Professor) of Software Engineering at the University of Salford, Manchester, UK
The project will follow a SCRUM-like agile method, which includes defining a SCRUM Master, a Product Owner and a Development Team. This definition of roles creates an initial distinction in tasks and duties for a successful delivery of the final software.
Name | Role | University | |
---|---|---|---|
William Nordberg | Product Owner | Mälardalen University | [email protected] |
Bassam Zabad | Developer | Mälardalen University | [email protected] |
Alice Casali | Developer | Politecnico di Milano | [email protected] |
Fabrizio Siciliano | SCRUM Master | Politecnico di Milano | [email protected] |
Aida Denisa Opîrlesc | Developer | Politecnico di Milano | [email protected] |
Anna Bergamasco | Developer | Politecnico di Milano | [email protected] |
Anđela Zorić | Developer | Mälardalen University | [email protected] |
Please make sure to satisfy the following requirements before the frontend setup:
- Flutter is installed on your machine. If not, you can follow this guide here;
- Your Flutter environment has to have web development enabled. You can do this by entering the following commands in your command line prompt of choice or follow this step by step guide:
flutter channel beta
flutter upgrade
flutter config --enable-web
Once the requirements have been completed, please go ahead and follow the next steps:
- Open a command line prompt on your local machine and type
cd <path_to_project>/frontend
; - Run the following command:
flutter build web
; - Whenever you need to debug your application, you can use the following command:
flutter run -d chrome
(make sure to have Chrome installed).
Please make sure to satisfy the following requirements before the backend setup:
- Install Node.js and npm from this link here;
Once the requirements have been completed, please go ahead and follow the next steps:
- Open a command line prompt on your local machine and type the following commands:
cd <path_to_project>/backend
npm i
npm start
- You should be able to check your backend by opening your browser of choice and navigating to the URL that is prompted after the
npm start
Please make sure to satisfy the following requirements before the backend setup:
- Install PostgreSQL from this link here;
- NB: Take careful note of the password that you're going to give to postgres in the wizard while installing!
- Install PGAdming4 from this link here;
- Make sure to have installed the
knex
package globally by running the following command in your prompt of choice:
npm i -g knex
Once the requirements have been completed, please go ahead and follow the next steps:
- Create a new database:
- Configure Node.js
- Open the backend folder of this project and create a new file called
.env
; - Fill in the document with the following information by replacing the information with your own, keep the values in the double quotes:
- Open the backend folder of this project and create a new file called
DEV_DB_HOST="localhost"
DEV_DB_NAME="name_of_your_database"
DEV_DB_USR="your_username"
DEV_DB_PORT="port_of_your_database"
DEV_DB_PWD="your_password"
PLADAT_ENV="development" #do not change this
GPLACES_APIKEY="your_gplaces_api_key" #ask to our devs or create on of your own at https://developers.google.com/places/web-service/overview
ACCESS_TOKEN_SECRET="your_secret"
ACCESS_TOKEN_LIFE="your_token_life_in_seconds" #e.g. 2592000 = 30 days
- Check that everything is correct by doing the first migration:
cd <project_folder>/backend
knex migrate:latest
Make sure to have previously run the following commands:
cd <project_folder>/backend
npm i
Once the requirements have been completed, please go ahead and run npm test
. All tests will be automatically run and you will be able to see the results on your prompt.
The backend comes together with a coverage checking function that can be easily run with npm run coverage
. The results of it can be found inside the ./backend/.nyc_output
folder.
- When testing the application from the dev branch, remember to run the frontend with the following command:
flutter run -d chrome --dart-define=API_ENDPOINT=https://pladat-staging.herokuapp.com/
- If you're using VSCode and you wish to debug with just the push of a button, you can use the following in your launch.json file:
{
"version": "0.2.0",
"configurations": [
{
"name": "Local frontend",
"cwd": "${workspaceFolder}/frontend",
"request": "launch",
"type": "dart",
"args": ["--web-hostname=127.0.0.1", "--web-port=8200"]
},
{
"name": "Local backend",
"request": "launch",
"cwd": "${workspaceFolder}/backend",
"runtimeArgs": [
"run-script",
"serve",
],
"runtimeExecutable": "npm",
"skipFiles": [
"<node_internals>/**"
],
"type": "pwa-node"
},
{
"name": "PlaDat frontend staging",
"cwd": "${workspaceFolder}/frontend",
"request": "launch",
"type": "dart",
"args": [
"--web-hostname=127.0.0.1",
"--web-port=8200",
"--dart-define=API_ENDPOINT=http://pladat-staging.herokuapp.com"
]
},
{
"name": "PlaDat frontend production",
"cwd": "${workspaceFolder}/frontend",
"request": "launch",
"type": "dart",
"args": [
"--web-hostname=127.0.0.1",
"--web-port=8200",
"--dart-define=API_ENDPOINT=https://pladat.herokuapp.com"
]
}
],
"compounds": [
{
"name": "Pladat development",
"configurations": ["Local frontend", "Local backend"]
}
]
}