Prepared by Brassat Alexandru, Duca Alexandru, Popa Stefan
Link-ul videoclipului: https://youtu.be/FASqCQmM0mc
- Introduction
- 1.4 Product Scope
- Overall Description
- External Interface Requirements
- 3.1 User Interfaces
- 3.3 Software Interfaces
- System Features
- 4.1 Filling out the form
- 4.2 Creating a form
- 4.3 Editing a form
- 4.4 Viewing form statistics
- 4.5 Viewing Created Forms
- 4.6 Explore Forms
- Other Nonfunctional Requirements
A Web application that allows logged in users to create feedback forms for a certain "thing" (event, person, geographic place, product, service, artistic artifact, etc.) and view statistics about the responses. The responses are collected in an anonymous manner from users who do not need to have accounts.
Our app is based on microservices, thus being both flexible and scalable.
Some major functionalities of the application are the creation of accounts for users, the creation and completion of forms and the visualization in an attractive way of the statistics generated based on the completion of forms.
Anonymous users who can only fill out forms and users who have a created account and can create forms.
Frontend was build using HTML, CSS and JAVASCRIPT and the backend server was implemented in Python.
Landing Page: Sign up: Log in: View Forms: Explore Forms: Create Form: Complete Form: View Statistics:
PostgreSQL for Database to keep user accounts, forms and their resposes.
The user fills in the form using the Plutchick wheel and/or expressing himself in his own words.
The user can use the dedicated Start, Next, Finish and Back buttons to navigate through the form. The user answers the questions by clicking on the corresponding emotions on the wheel or by entering actual phrases in the "Write what you think" section. If you have changed your mind about the emotion chosen for a certain question, you can deselect it by clicking again on the emotion that wants to be deleted from the list. You can see the emotions already selected in the "What you feel" section. At the end of the form, a "Back to Explore" button will appear, which when pressed will redirect the user to the list of public forms .
The user will not be able to submit the form if he has not answered at least one question. An answer to the question is valid if at least one emotion is chosen on the wheel.
The LOGGED IN user can create a form.
Fields such as name, tags and questions can be filled in. To create a field for a question, press the "Add Question" button. To delete a field for a question, press the "Delete Question" button. After completing the form, press the "Done" button. When pressed, a check will be made for each field and if all meet the requirements then the form will be created, otherwise a notification will appear telling you which field was wrong. Another field that can be chosen is a set of questions meant to understand the user better (this information is also used to generate relevant statistics based on age, marital status etc.).
The form is valid and can be sent if it meets the following conditions : the name of the form and body of the questions must the specified character limits, there should be at least one question in the form and a maximum of 15 questions. If the "Done" button has been pressed and the form has been validated, a notification will appear saying that the form has been created and will redirect you to the forms page that the user can manage.
The LOGGED IN user can edit a form that he created.
The interaction is the same as the "Creating a form" page, but the difference is that the already existing data of the form will be automatically loaded into the fields, and the user can change them at will, respecting the requirements of each field.
Same as 4.2.3
The LOGGED IN user can view the statistics of an own form.
The quiz owner will be able to see the statistics in the form of a list of "interesting things". The algorithm will present some interesting statistics, which accounts for user groups, negative/positive emotions and time of form completion. Different appropriate representations of the data will be displayed. The user will be able to export the statistics in HTML, CSV or JSON format.
The user must be logged in.
The User will be able to view their drafts, published or closed forms.
The User will interact with the "admin" page, which will list all of their forms. Those can be grouped in the three categories mentioned above, and can be sorted by category by using a series of buttons on the left side of the page. For all forms, the user will be able to perform certain actions (such as edit, publish, close, view statistics, delete), according to the state the forms are in (draft, active, closed).
The user must be logged in to view their forms.
All users (anonymous or not) will be able to participate in public forms made by other users. The forms will be grouped by multiple criteria.
The User will browse the page and, when a certain form catches their attention, will be able to join the form.
In order for this page to be functional, it requires a number of public forms. In the case when there are none, an informative message will be shown.
Any user has the option to create an account, but it's not mandatory as the user can use the app and explore forms without an account. Creating an account allows the user to acces other features like Creating forms or Viewing Statistics about his completed forms.
If he wants to have permission to the features mentioned before, the user can easily and fast create an account by pressing the button 'Sign up' on the Landing page. He will be asked to enter an email address, an username and a password and then he will be redirected directly to his admin page, giving him acces to the features.
To be able to access the 'Sign up' option, the user must not already be connected to an account in the application first and then must enter a valid email address and a username and a password of at least 8 characters.
If the user has created an account in the application, he will always be able to access it through the 'Log in' feature. It will also be possible to disconnect from the account using the 'Log out' option.
Every time the user wants to access his created account, he will be able to do it easily by entering either the username or the email. The data entered by him will be retained to keep him connected all the time to his account until he logs out.
To be able to acces the 'Log in' and 'Log out' features, the user should first create an account using the 'Sign up' feature.
By escaping and verifying user input, we want to prevent the most common attacks such as cross-site scripting, SQL injection.
We check user session ids and data access rights in order to prevent bypassing authorisation and view other users data.
We also verify session ids for every request and delay error messages in order to prevent bruteforce attacks.
The database stores encrypted passwords in order to prevent password stealing.
A planned future enhancement for our application is the development of a Natural Language Processing (NLP) microservice. This microservice will use various techniques to analyze text and predict the emotions contained within. The NLP microservice will take a string of text as input and return a prediction of the associated emotion as output. This may involve the emotions such as 'joy', 'fear', 'sadness', 'anger', 'surprise', 'disgust', etc.
An upcoming enhancement that we're planning to add to our system is a mailing microservice. This microservice will be responsible for all email-related functionalities, including sending notifications, account activation instructions, password recovery instructions, and user updates.
We are planning to add an IP - Session mapping feature using Redis on our Gateway service. This will enhance the security and performance of our system by efficiently managing user sessions and controlling the rate of requests.
- Ease of Participation: Customers can provide feedback without the hassle of creating an account, making the process quick and straightforward.
- Anonymity: The assurance of anonymity encourages honest and candid feedback, allowing customers to express their true feelings without fear of repercussions.
- Enhanced Service and Product Improvements: By sharing emotional feedback, customers contribute to tangible improvements in products and services they use, leading to better overall experiences.
- User-Friendly Interface: The application is designed to be intuitive and easy to use, ensuring customers can effortlessly provide their input.
- Typeform: This is known for its user-friendly interface and interactive feedback forms. It allows users to create customized forms with various question types.
- Google Forms: This is a web-based application for creating surveys, quizzes, and data collection forms.