Univeristy Scheduler
Student | Virghileanu Teodor |
---|---|
Group | 30431 |
Frontend documentation is here.
Contents
- Univeristy Scheduler
Project specification
The University Scheduler is a platform dedicated for scheduling university related tasks and events while also allowing administrators to manage its teachers, staff members and students. Of course, each actor can independently manage its own adequate resources.
The current delivery model envisioned is Hosted Software, not SaaS.
Domain model
Person Domain
classDiagram
direction TB
FacultyPerson "1" --> "*" Role : Has
Role --> Student
Role --> Teacher
Role --> Staff
University "1" --> "*" Faculty : Contains
Faculty "1" --> "*" Course
Course "1" --> "*" Task
FacultyPerson "1" --> "*" Enrollment
Enrollment "1" --> "1" Faculty
Teacher --> Student : Assign course
Teacher --> Staff : Assign course
Admin --> "*" FacultyPerson : Assign role
Admin --> "1" University : Create
Admin --> "*" Faculty : Create
FacultyPerson "1" --> "1" Calendar : View
Calendar "1" --> "*" Task : Display
class Admin { }
class FacultyPerson { }
class Teacher { }
class Staff { }
class Student { }
class Enrollment { }
class University { }
class Faculty { }
class Course { }
class Task { }
class Calendar { }
Usecases
University onboarding
Level | Main actor |
---|---|
Administrator-Goal | Admin |
This usecase is aimed for the onboarding of the application itsef. Before having users and managing resources, the administrator needs to create a university, its faculties, its courses and optionally have a yearly schedule set up. The latter step is optional because other users can be assigned to this task (such as teachers with higher privileges).
Success scenario:
- Admin accesses the panel.
- He sees the application onboarding page, since the app is not yet set up.
- He completes the forms sequentially.
- He sets up the university details.
- He creates empty faculties.
- He creates empty courses.
- He sets up Faculty-Course relations.
- He optionally sets up the schedule for each course.
User role assignation
Level | Main actor |
---|---|
Administrator-Goal | Admin |
This usecase covers invitations to the platform as well. Once an actor is invited, it also receives a platform invitation followed by a mandatory profile onboarding. Role assignation is important because functionality on the platform is permission driven. Teacher, Student and Staff are just permission presets.
Success scenario:
- Admin accesses the panel and visits the user management page.
- Admin invites a new user to the platform.
- Admin assigns roles prior to the new user onboarding.
- New user can do specific role workflows.
Assigning tasks
Level | Main actor |
---|---|
Teacher-Goal | Teacher |
Since permissions exist, the administrator is not the only one capable of creating and assigning tasks. Because of this, a different actor name will be used to describe the user which is able to create tasks.
Success scenario:
- Teacher selects a course.
- Teacher invites one of his Students to the selected course.
Every task of the course will now be visible for each student of the course.
Calendar check
Viewing the calendar and inspecting tasks is the target of the application. This action is not targetted to any kind of actor specifically, every user has the base privileges to view the calendar.
Success scenario:
- User accesses the calendar
- User inspects the weekly view
- Student cries
Users and stakeholers
The stakeholders of this application are university leading members. They are the one who benefit from the platform and they can be positively or negatively affected by the business. They manage all resources on the platform.
As a consequence, the users of the application are students, whose presence on the platform is also optional.
Architecture Design
The Design principle for this web app's backend is a 3 Layer Architecture
.
- A controller’s sole purpose is to receive requests for the application and deal with routes.
- The service layer should only include business logic. For example, all the CRUD operations and methods to determine how data can be created, stored and updated.
- The data access layer takes care and provides logic to access data stored in persistent storage of some kind. For example an ODM like Mongoose, or ORM like TypeOrm
The framework of choise is NestJS (docs) due to its modularity and powerset of awesome features.
The name is missleading, typescript will be used instead of plain javascript.
Key features:
Non-functional requirements
Security
User credentials will be encrypted, and tokens will be signed with a SECRET
.
The JWT token will encapsulate non sensitive user data and permissions which will later be used to reject unauthorized requests.
Scalability
This is a non-problem
due to the way NestJS is build. Being modular allows for easy and flexible scalability.
Responsive design
A mobile-friendly responsive design is a must!
The frontend will be built using SolidJS. The CSS frameworks of choice are TailwindCSS and Unocss. Only one css engine will be used after one is picked to be used.
This will allow for a quick and beautiful design, built in a mobile first breakpoint system.
Performance and perceived quickness
Webpages will be served quickly, packed as minimal as possible, and all requests will be asyncronous, so the user can enjoy a fast and smooth experience.
Design constraints
- Technical constraints will require the database
seeding
andmigrating
features, such that the database is kept up to date and be populated with initial data before the application onboarding. - A hash function is needed to encrypt user credentials.
- A UI library needs to be built before starting to implement the application design.
Database
erDiagram
Users ||--|{ Roles : has
Users ||--|| Profile: has
Users {
string username
string password
}
Roles {
string name
}
Profile {
string name
string email
string phone
string cnp
date birth
}
Users ||--|{ Enrolment : can_have
Enrolment {
int faculty_id
int user_id
}
Enrolment }|--o{ Faculty : part_of
University ||--|{ Faculty : contains
University {
string name
}
Faculty ||--|{ Courses : contains
Faculty {
string name
}
Courses ||--|{ Tasks : contains
Courses {
string name
string description
}
Roles ||--|{ Tasks : for
Tasks {
role target
string name
date start
date end
}
Sequence diagrams
The sequence diagrams exemplify the sequence of events to consider in a normal workflow for several use cases.
User roles
This usecase covers invitations to the platform as well. Once an actor is invited, it also receives a platform invitation followed by a mandatory profile onboarding.
sequenceDiagram
actor Student
actor Teacher
actor Admin
Admin ->> Teacher: Invite to faculty
Note right of Teacher: Accept invitation
Admin ->> Teacher: Assign courses
Teacher ->> Student: Invite to class
Student ->> Teacher: Accept invitation
Note over Student: ~ Profile Onboarding
From now on, users can use the platform independently of each other.
User permission
Some teachers can have different permissions on the platform. For example, a teacher can be an administrator given the right permissions.
The same goes for Staff members.
sequenceDiagram
actor Staff
actor Teacher
actor Admin
Staff ->> Teacher: Request a permission privilage
Teacher -->> Staff: Sorry, I don't have the privilege
Teacher ->> Admin: Request a permission privilage
Admin ->> Teacher: Validate permission request
Staff ->> Teacher: Request a permission privilage
Teacher ->> Staff: Validate permission request
Each actor can independently assign permissions to other actors if they have the required priviledges.
Faculty & Course creation
This usecase covers the admin creating a faculty for a university and assigning courses to it. Currently, courses are not independent of faculties, since we don't cover the case in which a teacher has activity across multiple universities. Each course is unique to a faculty.
sequenceDiagram
participant Course
participant Faculty
actor Admin
Admin ->> Faculty: Create
Admin ->> Faculty: Visit dedicated page
Admin ->> Course: Create
Note over Course, Faculty: Course is linked to Faculty
Task creation
Since permissions exist, the administrator is not the only one capable of creating and assigning tasks. Because of this, a different actor name will be used to describe the user which is able to create tasks.
sequenceDiagram
participant Task
participant Course
actor Scheduler
Scheduler ->> Course: Assert creation
Note over Scheduler, Course: The course is created
Scheduler ->> Course: Visit dedicated page
Scheduler ->> Task: Assert availability
Note over Task, Course: The task fits in the timeframe
Scheduler ->> Task: Create
Calendar page
Viewing the calendar and inspecting individual elements is trivial.
sequenceDiagram
participant Calendar
actor User
User ->> Calendar: Visit dedicated page
User ->> Calendar: Inspect monthly overview
User ->> Calendar: Inspect weekly overview
User ->> Calendar: Click date
User ->> Calendar: Inspect detailed tasks
Activity diagram
This diagram further illustrated the logic behind several usecases and sequence diagrams.
User roles and creation
flowchart LR
actor((Admin))
is_registered{registered?}
actor-- invite user --o is_registered
actor-- add role --o is_registered
actor-- invite faculty --o is_registered
actor-- add task --o is_registered
has_roles{Has roles?}
set_roles[Set roles]
is_registered -->|Yes| has_roles
has_roles -->|No| set_roles
has_roles -->|Yes| invite_faculty
send_invitation[Send invitation]
is_registered -->|No| send_invitation
send_invitation --> set_roles
invite_faculty[Invite to Faculty]
add_tasks[Add tasks]
set_roles --> invite_faculty
invite_faculty --> add_tasks
flowchart LR
actor((User))
is_registered{registered?}
actor-- calendar --o is_registered
actor-- view task --o is_registered
actor-- invite user --o is_registered
actor-- set roles --o is_registered
has_permission{permission?}
invite_user[Invite users]
set_roles[Set roles]
is_registered -->|Yes| has_permission
has_permission --> |Yes| invite_user
has_permission --> |Yes| add_task
invite_user -.-> set_roles
view_task[View task]
calendar[Calendar]
has_permission --> |No| calendar
calendar -.-> view_task
Package diagram
classDiagram
Model .. UI
Model .. Service
Service -- Controller
Service -- Repository
Validation .. Model
Validation --|> Service
EmailService --|> Service
RolesAndPermissions --|> Service
AuthService --|> Service
RolesAndPermissions .. AuthService
UI -- Controller
Class diagram
classDiagram
Enrollment --* "many" FacultyPerson : Contains
Faculty --* Enrollment
Faculty --* "many" University : Contains
Course --* "many" Faculty : Has
Task --* "many" Course : Has
DateRange --* Task
Faculty ..|> ContainsWork
Course ..|> ContainsWork
Faculty ..|> ContainsWork
Person <|-- FacultyPerson
FacultyPerson <|-- Student
FacultyPerson <|-- Staff
Staff <|-- Teacher
Student ..|> ContainsWork
Staff ..|> ContainsWork
Student ..|> Work
Staff ..|> Work
class Person {
<<abstract>>
-String name
-String email
-Date birthDate
-String phoneNumber
-String cnp
}
class FacultyPerson {
-List~Enrollment~ enrollments
}
class Work {
<<interface>>
+work()
+complete(Task) boolean
+isCompleted(Task) boolean
}
class ContainsWork {
<<interface>>
+hasWorkNow() boolean
+todoNow() Task
+todoToday() List~Task~
+todoWeek() List~Task~
+todoMonth() List~Task~
}
class Teacher {
+inviteStudent(Student)
+inviteStaff(Course)
}
class Staff {
+addTask(User)
}
class Student {
}
class Enrollment {
-String ID
-Faculty faculty
}
class University {
-String name
-List~Faculty~ faculties
}
class Faculty {
-List~Course~ courses
-String name
-String description
}
class Course {
-String name
-String description
-Set~Date, Task~ tasks
}
class Task {
-DateRange range
-String name
-String description
+onDate() Date
}
class DateRange {
-Date start
-Date end
+onDate() Date
}