The front-end for the project is displayed on a mobile application built using flutter and dart, state management for the same has been done using riverpod.
The connections to the database have been set up using a flutter package called mysql1, this is a library that allows connecting to our mysql database and querying it. To know more about this package, please check the link: https://pub.dev/packages/mysql1
All database connections have been set up in a separate folder named "database" in the "lib" folder of the application. The sql queries have been written in separate folders for authentication and data manipulation, called sql_auth.dart and sql_data.dart respectively.
The app allows both the students and college admins to login and access user-specific pages. The flow of the app is as shown:
data:image/s3,"s3://crabby-images/689fd/689fdcd8f3cc0bb545ab03b0d11d39c9bff3f444" alt=""
data:image/s3,"s3://crabby-images/bea78/bea7886715bdebf1392882b33a9b33a7415eb4aa" alt=""
data:image/s3,"s3://crabby-images/d34b9/d34b913c02800ea670346e897d2267c1388829a9" alt=""
A student can access the app by logging in with their credentials or creating a new account if they haven’t previously registered. This adds a new entry into the user and student table in the database.
data:image/s3,"s3://crabby-images/596d4/596d47a073b3aebd75947c13ae3b9e67d06301b8" alt=""
data:image/s3,"s3://crabby-images/2e0a7/2e0a7497690f75db43646f1d4d5013d3cfa69e79" alt=""
Upon successful login or registration,the student dashboard is visible, wherein they can either set their college allotment preference or view their profile and see their current preference list or update their details.
data:image/s3,"s3://crabby-images/27352/27352bb18247151092d0c50bd118b3ccf80d4390" alt=""
data:image/s3,"s3://crabby-images/a4be0/a4be0fc19dadb461f37cee718edb7a102695e1d2" alt=""
data:image/s3,"s3://crabby-images/22195/22195e3a4c11a47e613dc47094445273e30b7f44" alt=""
A college administrator can access the app by logging in with their credentials or creating a new account if they haven’t previously registered. This adds a new entry into the user and collegeadmin table in the database.
data:image/s3,"s3://crabby-images/8e6cd/8e6cd270605ecf1cb2e05d37c877865556583f9f" alt=""
data:image/s3,"s3://crabby-images/10299/1029975c4ba488a1cd264eb07c7966ef45e11e59" alt=""
data:image/s3,"s3://crabby-images/0d77b/0d77ba7cc98b672c31e512020ac5c3ecacb5281b" alt=""
Upon successful login or registration, the admin dashboard is visible, wherein they can either add a course to the list of courses the college offers or allocate students that have applied to their college (based on cut-off scores and preferences). In the next screen, the admin can view the list of students allocated to their college and the total allocations done in all colleges so far.
In order to run the application, you must first ensure that your MySQL connection settings have been reset according to the port connected to the app. In order to do this, please right click on the connection on your workbench and click on ‘Edit Connection..’
data:image/s3,"s3://crabby-images/36d5c/36d5cc2101816bf2c9e4b0faecb28beb675b1817" alt=""
This will open a dialog box with your current connection configuration. Please ensure all entries are filled out as shown in the image below (and also given as text).
Connection Name: localhost Connection Method: Standard (TCP/IP) Hostname: localhost Port: 3306 Username: root
data:image/s3,"s3://crabby-images/12329/12329becd34835bd18f97f30c972aa2ed47b16b2" alt=""
After having changed your username to ‘root’ in the previous step, please use the following commands to change your password to ‘password’. USE mysql; SET PASSWORD FOR 'root'@'localhost' = ‘password’; FLUSH privileges; If the commands given above are not compatible with your MySQL version then please check the following links to find commands specific toyour version.
https://dev.mysql.com/doc/refman/8.0/en/alter-user.html
https://www.javatpoint.com/change-mysql-user-password
Note: Please ensure your MySQL server is running when using the app and that you have run the script named ‘masterScript.sql’ beforehand to create the database and fill relevant entries.