CS1530-Project

CS1530-Project

CS1530-Project

Trello Board
UML Diagrams
SRS Document
SRS Document V2
Live Website
Heroku
Currency API- Fixer.io




Project Proposal

What

The Travel Expense Tracker is a web application aimed at simplifying and enhancing the travel experience for users by providing robust expense tracking, budget management, and financial analysis tools. With the increasing popularity of travel and tourism worldwide, it has become essential for travelers to manage their expenses effectively and make informed financial decisions while exploring new destinations. The Travel Expense Tracker addresses this need by offering a user-friendly platform for recording, categorizing, and analyzing travel expenses, thereby empowering users to stay within budget, track spending patterns, and optimize their travel finances.

Why

The importance of the Travel Expense Tracker lies in its ability to address common pain points faced by travelers, such as overspending, budgeting challenges, and difficulty in tracking expenses across different categories. By providing users with a centralized platform to manage their travel finances, the application streamlines the expense tracking process and helps users make smarter financial decisions during their trips. Additionally, the Travel Expense Tracker promotes financial awareness and accountability among users, encouraging responsible spending habits and ensuring a more enjoyable and stress-free travel experience.

How

The Travel Expense Tracker will be constructed using modern web development technologies and best practices to ensure reliability, scalability, and user satisfaction. The frontend of the application will be built using HTML, CSS, and JavaScript, with frameworks like React.js or Angular for dynamic user interfaces. The backend will be developed using Node.js with Express.js for server-side logic and API development. Data storage and management will be handled using MongoDB or MySQL databases, allowing for efficient storage and retrieval of user data, expense records, budget information, and authentication details. Additionally, the application will integrate with third-party APIs for currency conversion, financial data integration, and authentication to enhance functionality and provide users with a seamless experience. Overall, the Travel Expense Tracker will be constructed with a user-centric approach, prioritizing usability, functionality, and data security to deliver a valuable tool for travelers worldwide.


Functional Requirements

User Registration

Nonfunctional Requirements

Performance

Software Interfaces

User Registration

Use Case List

| Use Case ID | Primary Actor | Use Case | |————-|—————|————————| | UC-3.3.1 | End User | Register a New User | | UC-3.3.2 | End User | User Login | | UC-3.3.3 | End User | Create Budget | | UC-3.3.4 | End User | Edit Budget | | UC-3.3.5 | End User | Manage Settings | | UC-3.3.6 | End User | Download Budget Report |

Register a New User

| | | |————————————–|————————————————| | Use Case ID: | UC-3.3.1 | | Use Case Name: | Register a New User | | Created By: | Henry Uz | | Last Updated By: | Henry Uz | | Date Created: | 2/9/2024 | | Last Revision Date: | 2/9/2024 | | Actors: | The primary actor will be the end user | | Description: | The reason for this use case is so that the user may register for a new account on the system. This is useful because it allows them to save their budget, making future changes easier. The outcome will be adding the user to the underlying database and allowing them budget their traveling.| | Trigger: | The trigger for this event will be the user entering a username and password to create an account on the appropriate page.| | Preconditions: | 1. User will not already have an account with their desired username. | | Postconditions: | 1. User has an account created and registered.
2. User is notified that this process was successful and prompts them to login.

If unsuccessful:
1. User account is not created.
2. User is notified of what the error is regarding their entry.| | Normal Flow: | 1. User enters their desired username.
2. User enters their desired password.
3. Check if the username and password meet required credentials as specified.
4. Register the new user. | | Alternative Flows: | 3a. In step 3 of normal flow, the user entries does not meet the specified criteria.
1. The user is notified that they must fulfill the criteria specified for the password.
2. The use case restarts and awaits another attempt to register.

4a. In step 4 of normal flow, if user does not enter any text.
1. The system will alert the user that they must populate the fields.
2. Use case restarts and awaits another user attempt.

4b. In step 4 of the normal flow, if an account with this name already exists
1. Notify the user that this username is already taken.
2. Use case restarts and awaits another user attempt. | | Exceptions: | 4a. In step 4 of the normal flow, if the database is not initialized
1. The registration will not be completed.
2. An error will be presented, alerting host machine of this issue.
3. Use case must abort until error is corrected by host | | Includes: | This use case will not call other use cases. | | Frequency of Use: | This use case will be executed only once per new user. | | Special Requirements: | The username and password will need to be checked for special characters and criteria specified in this SRS. | | Assumptions: | The assumptions made are that the user is entering English text. | | Notes and Issues: | As of creating this use case there are no details; TBD. |


User Login

| | | |————————————–|————————————————| | Use Case ID: | UC-3.3.2 | | Use Case Name: | User Login | | Created By: | Henry Uz | | Last Updated By: | Henry Uz | | Date Created: | 2/12/2024 | | Last Revision Date: | 2/12/2024 | | Actors: | The primary actor will be the end user.| | Description: | The reason for this use case is so that the user may access their existing account. This is useful because it allows them to access their budget, making future changes easier. | | Trigger: | The trigger for this event will be the user running the program. | | Preconditions: | 1. User will not already have an account with their desired username. | | Postconditions: | 1. User successfully logs in. 2. User is shown the home page displaying all existing trips.

If unsuccessful:
1. User is not logged in.
2. User is notified of what the error is regarding their entry.| | Normal Flow: | 1. User enters their username. 2. User enters their password. 3. User clicks “Login” button. 4. User is taken to the home page.| | Alternative Flows: | 3a. In step 3 of normal flow, the username does not exist in the system.
1. The user is notified that they have inputted a nonexistent username.

3b. In step 3 of normal flow, the username exists but their password is incorrect.
1. The user is notified that the password is incorrect.
| | Exceptions: | None | | Includes: | This use case will not call other use cases.| | Frequency of Use: | This use case will be executed once for every time a user initiates a session. | | Special Requirements: | None | | Notes and Issues: | As of creating this use case there are no details; TBD. |


Create Budget

| | | |————————————–|————————————————| | Use Case ID: | UC-3.3.3 | | Use Case Name: | Create Budget | | Created By: | Henry Uz | | Last Updated By: | Henry Uz | | Date Created: | 2/12/2024 | | Last Revision Date: | 2/12/2024 | | Actors: | The primary actor will be the end user.| | Description: | This is the primary function of the program. The user will input their budget and add expenses, allowing them to see all important financial data related to their trip in one place. | | Trigger: | The trigger for this event will be the user pressing “Create Budget” on the home page. | | Preconditions: | 1. User has successfully logged in to their account. | | Postconditions: | 1. Budget has successfully been created 2. Budget will now show on the home page| | Normal Flow: | 1. User will click “Create Budget” 2. User will be taken to a page to list their trip name and budget 3. User will select next and enter their expenses 4. User will select “Save” when complete | | Alternative Flows: | 1. User will click “Create Budget” 2a. User clicks the arrow buttons to change previously submitted info 2b. User clicks “Cancel” to return to the home page without saving the trip| | Exceptions: | User’s budget is <= 0 | | Includes: | This use case will not call other use cases. | | Frequency of Use: | Likely medium-high use (at the discretion of the user)| | Special Requirements: | None | | Notes and Issues: | As of creating this use case there are no details; TBD. |


Edit Budget

| | | |————————————–|————————————————| | Use Case ID: | UC-3.3.4 | | Use Case Name: | Edit Budget | | Created By: | Henry Uz | | Last Updated By: | Henry Uz | | Date Created: | 2/12/2024 | | Last Revision Date: | 2/12/2024 | | Actors: | The primary actor will be the end user.| | Description: | The purpose of this use case is to allow the user to edit the budget and/or expenses of an existing trip. | | Trigger: | The trigger for this event will be the user selecting the “Edit Budget” button. | | Preconditions: | 1. User has successfully logged in to their account. 1. User has selected an existing trip. | | Postconditions: |1. Changes to the budget are saved to the system| | Normal Flow: |1. User selects the “Edit Budget” button 2. User makes desired changes and uses arrow buttons to navigate between pages 3. User clicks “Save Changes” to finalize edits| | Alternative Flows: |1. User selects the “Edit Budget” button 2. User clicks “Cancel” to return to the home page without saving edits| | Exceptions: | User’s budget is <= 0 | | Includes: | This use case will not call other use cases. | | Frequency of Use: |Likely low-medium use (at the discretion of the user) | | Special Requirements: | None | | Notes and Issues: | As of creating this use case there are no details; TBD. |

Manage Settings

| | | |————————————–|————————————————| | Use Case ID: | UC-3.3.5 | | Use Case Name: | Manage Settings | | Created By: | Henry Uz | | Last Updated By: | Henry Uz | | Date Created: | 2/12/2024 | | Last Revision Date: | 2/12/2024 | | Actors: | The primary actor will be the end user.| | Description: | This use case allows the user to edit the program settings. One example is changing the graph type output on the budget report. | | Trigger: | The trigger for this event will be the user pressing the “Settings” button. | | Preconditions: | 1. User has successfully logged in to their account. | | Postconditions: | 1. User is shown the settings page
2. If user changes settings and selects “Save Changes” button, the settings are changed
2a. If the user selects the “Exit” button, no changes are made to the settings.
3. The user is returned to the home page. | | Normal Flow: | 1. User selects the “Settings” button 2. User changes the desired settings 3. User selects the “Save Changes” button | | Alternative Flows: | User views settings: 1. User selects the “Settings” button 2. User selects the “Exit” button
User changes settings but does not save them: 1. User selects the “Settings” button 2. User changes the desired settings 3. User selects the “Exit” button| | Exceptions: | None | | Includes: | This use case will not call other use cases. | | Frequency of Use: | Likely low use (at the discretion of the user) | | Special Requirements: | None | | Notes and Issues: | As of creating this use case there are no details; TBD. |


Download Budget Report

| | | |————————————–|————————————————| | Use Case ID: | UC-3.3.6 | | Use Case Name: | Download Budget Report | | Created By: | Henry Uz | | Last Updated By: | Henry Uz | | Date Created: | 2/12/2024 | | Last Revision Date: | 2/12/2024 | | Actors: | The primary actor will be the end user.| | Description: | The purpose of this use case is to allow the user to export the budget report. This would be useful for having quick access to the report or sending it to someone. | | Trigger: | The trigger for this event will be the user pressing the “Download Budget Report” button.| | Preconditions: | 1. User has successfully logged in to their account. 2. User has saved at least one trip. | | Postconditions: | 1. User successfully downloads the trip’s budget report | | Normal Flow: | 1. User selects a trip from the home page. 2. User presses the “Download Budget Report” button.| | Alternative Flows: | None | | Exceptions: | None | | Includes: | This use case will not call other use cases. | | Frequency of Use: |Likely medium-high use (at the discretion of the user) | | Special Requirements: | None | | Notes and Issues: | As of creating this use case there are no details; TBD. |




Classes and Objects

User

Attributes: Username, email, password, notification preferences
Behaviors: Register, login, update profile, change password, manage settings

Expense

Attributes: Date, amount, category, description, currency
Behaviors: Add, update, delete

Budget

Attributes: Overall budget, budget allocations for expense categories
Behaviors: Set overall budget, allocate budget for expense categories, update budget

Settings

Attributes: User settings
Behaviors: Update profile

Notification

Attributes: Notification type, content
Behaviors: Send message

CurrencyCoverter

Attributes: Exchange rates
Behaviors: Convert between currencies

Architectural Patterns

  1. MVC Pattern
  2. Pipe and Filter

MongoDB Information

To access Mongo Shell from command line: mongosh “mongodb+srv://mrk133:ovlP6h4epIrWyDcq@cluster0.o58ssex.mongodb.net/?retryWrites=true&w=majority&appName=Cluster0”