Skip to content

Milestone 1 Report

omerfdeniz edited this page May 2, 2020 · 61 revisions

Executive Summary

Introduction

Getflix is an online commerce platform that helps users find a plethora of products they need and purchase them in an easy and straightforward way. Getflix removes the friction of the shopping experience by providing an easy-to-use interface on all major desktop and mobile platforms. Shoppers are able to find products with the means of semantic search, view product details and decide whether a product is worth it by reading comments by verified buyers. When their shopping cart is finalized, they can easily buy their products with debit/credit card. Getflix also gives the opportunity for buyers to track price changes so that they can strike better deals.

In Getflix there are four types of users: Guest, Customer, Vendor and Admins. Guest users are allowed to do basic operations such as searching products and viewing their details, as well as add products to their shopping cart. Customers are registered users that are allowed to continue with checking out process. They can also track their orders, ask for support from Admins and comment on products they have purchases. Vendors are allowed to setup an online shop where they can present their products on our platform. Admins maintain the system and make sure that operations go smoothly.

What we have done so far

The very first thing we did was, naturally, to get to know each other. We learned about each other's background, exchanged contact informations and started building the infrastructure necessary for future work together. During the first week, we setup our Github repo, agreed on a communication plan, created a Slack workspace where realtime communication could happen. Each one of us researched about how to use github, picked a favorite repository and explained what we liked about it.

Every week we would meet and discuss the assigned tasks. The major task we first accomplished was creating a requirements document based on the customer's needs. This required multiple meetings, both within our team, as well as with the customer in order to better understand their needs and remove any ambiguities from the requirements.

Once the requirements were reviewed and finalized, we started working on a more visual documentation. We prepared three scenarios based on three personas which describe the archetypes of users we are expecting to see on our platform. For each user scenario, we prepared a mockup that shows how that user would be able to achieve his/her end goal on our platform. Mockups are a series of images, either on our desktop or mobile app, that shows how the user interacts with our platform to achieve the desired effect.

The next step was to create three detailed diagrams: Use case diagrams, Class Diagrams, and Sequence diagrams. These diagrams help clarify the technical aspect of the platform. It fleshes out the use cases, the potential classes (in the object-oriented sense) we might use during implementation. This brings our overview of the system to a more concrete level.

In the final week, we took the time to produce a project plan that encompasses what we have done so far as well as a best guess estimation of the tasks we will have to do in the next course. This is materialized in the project plan and the RAM (Responsiblity Assignment Matrix)

Future work

In the next few weeks, we will practicing together as a team by implementing an API that could be used on this project. We will learn how to use git in a team setting, how to write good tests to make sure our code works as expected, and how to use AWS tools (EC2 for instance) in order to deploy our app in a production environment. Things take time, but we are perseverant and patient.

List and status of deliverables

Evaluation of the status of deliverables and its impact on project

Requirements

Requirements is arguably one of the most important parts in the project because it defines the project as a whole and it guides the direction a group is heading towards with their project. Documents such as class diagrams, sequence diagrams and use-case diagrams rely heavily on having a well-prepared requirements. As a group requirements was the one of the first things we prepared and it turned out to be quite useful in any situation where we needed to look up for a functionality of our project. Also having requirements is a must in terms of establishing a healthy communication with the customer.

Communication Plan

Communication Plan plays a very crucial part in communication between group members. Without a communication plan it is impossible to establish healthy interactions between team members because communication plan defines the mediums of interaction and guides group members to use those mediums according to the written purpose in the plan. Moreover communication plan also brings attention to communication and forces group members to think and reflect on how to establish communication in the group. Therefore communication plan brings full attention to communication and thus it maximizes the possibility of success. Our group have prepared a communication plan at the beginning of the semester and ever since it played a huge role on communication between group members and also with customer.

User Scenarios and Mockups

User scenarios should be real-life examples, understandable by everyone and show different kinds of people with various wishes in order to prove the usability and globality of the platform. We wrote three user scenarios which are tracking, purchasing and searching. We clearly identified the personal background of different users, what the users want, the preconditions, goals and acceptance criterias for these scenarios from the requirements. Thinking of the actions step by step for the scenarios helped us to come up with new design and feature ideas for our platform which will help users to use the platform in a more efficient way.

Mockups should be realistic, demonstrate the needed functionalities for specific scenarios and show all the steps of the users from the scenarios on the platform clearly. We created two web mockups and one mobile mockup for three scenarios we wrote. We paid attention to make all these three mockups look compatible with each other. Creating mockups helped us to test the usability of the platform. Additionally, as when writing scenarios, it helped us to come up with new design and feature ideas, because it really facilitates to visualize the platform and see our abstract ideas in a clear way.

Use-Case Diagram

The purpose of the Use-Case Diagram is to show the dynamic view of the system that is the users, the cases and the relationships among them. It is fundamentally designed considering the requirements of the project. In our Use-Case Diagram, we have 4 types of user Guest, namely the unregistered user, and Customer, Vendor and Admin which are registered users. The basic relationship among them is that registered users can do anything the Guest can do other than registering since they already did.

Class Diagram

A class diagram identifies the structure of a system by showing the system's classes, their attributes, operations, and the relation among objects. It models which classes are able to communicate with which and how ,what object we must implement, what behaviors an object is able to do and what information an object must know and manipulate in both convenient and compact way. It can be seen as a visual representation of our requirements. Furthermore, the design of a good class diagram also affects sequence diagrams. Therefore, we attach an importance of our class diagram to be comprehensive in order to not limit our feature works. There are 29 classes and 3 enumerations in our class diagram. User hierarchy is included and all systems are separated into controllers. Authentication and authorization system check permissions of end users determined in requirements. Classes called SearchEngine and RecommenderSystem implements the current technology to our project.

Sequence Diagram

We have created 10 sequence diagrams to show how and which classes interact in our application. Use cases to show in sequence diagrams are selected carefully considering selecting key use cases of our applicaton. All possible outcomes of these use cases are shown with detail in sequence diagrams. Our sequence diagrams clearly show interaction between various classes in chosen key use cases.

Project Plan

Creating a high level project plan that outlines the major activities and milestones helps us in a way that tracking our progress with our plan. The aim of the plan is to provide the work by estimating the effort and resources needed to complete the tasks and to compare the execution. Also in this way, we are able to evaluate how we are progressing.On the other hand, it helps to answer these kind of questions:Where are we now according to plan?Where actually should we be in our project according to plan?Is there any difference and if it is, how to make up the difference?

Responsibility Assignment Matrix

Responsibility assignment matrix is an efficient way to show all the contributions made by each group member on each task of the project. It is also very helpful while making new task distributions for next tasks by examining the matrix and realizing whether a member took too much or too few responsibilities. For a matrix to be well prepared, much attention should be paid to identifying and defining the roles well by examining the tasks and what is done so far. We created our matrix with four roles which are lead, support, reviewer and contributor, and defined these roles clearly. We paid attention to make it look compatible with project plan and Gantt chart. Since we continue to develop our project, our matrix will be also updated with new tasks and new responsibilities. Although we also identified future tasks and showed them both in Gantt chart and responsibility assignment matrix, they are open to change with changes in our task distribution or assignments we should do.

Evaluation of Tools and Processes

ProjectLibre (Reviewed by Mehdi Saffar)

ProjectLibre Logo

ProjectLibre is a free open-source project management software that helped me prepare the project plan as a Gantt chart. The desktop version is unfortunately very dated and buggy. There was no way to import the excel data containing the task_name, start_date, end_date, duration, predecessors, assignees of the project plan. It was also very finnicky to use, where errors are silent, behaviour unpredictable. I tried hacking away around its limitations, by for example imitating its copy & paste of the rows with more or less success. It also had nasty bugs where changing a cell of a row would for some reason also change the duration of a cell somewhere. This had me check each duration, and I found that almost 70% of them had changed value as I was updated the assignees column. The export to PDF also had its issues, notably the bad support of Turkish diacritics.

ProjectLibre did its job, but gave me headaches personally. I wouldn't recommend to use it in the future. Other solutions should be researched

Lucidchart (Reviewed by Aleyna Kara)

Lucidchart logo I have used Lucidchart to create the design of class diagram which includes functions, variables and classes of our project as an object oriented manner. Lucidchart has quick user interface and large amount of shapes and icons to be used in diagrams. On the other hand, you can use objects up to 60 and not be able to get much space to save documents if you don't upgrade to a paid account.

Balsamiq (Reviewed by Aleyna Kara)

Balsamiq logo

I have used Balsamiq to create designs of mockups that share the idea of a design to stakeholders without presenting a completed design. It supports a wide range of prototypes from web prototyping to mobile UI prototyping. Since it is easy to use, one does not need to be a design expert to create wireframes using Balsamiq

Zoom and Slack

Zoom and Slack are a part of the communication plan and they have been used heavily to communicate by our group members. Zoom is quite useful at conducting online meetings and it definitely helped our group to communicate faster than texting during covid-19 lockdown. Slack is a texting tool that offers a bunch of useful tools and it fits very nicely into group projects.

Excel (Reviewed by Aslı Aykan)

indir

I have used Excel to create the responsibility assignment matrix. Excel is a popular spreadsheet program which is developed by Microsoft and part of the Microsoft Office. Because it is intended for everyone to benefit easily, it’s really easy to learn to organize, sort and filter data in rows and columns, and also to create charts&graphs. With the help of this program, I have easily divided the tasks into subgroups and used different colors for different types of responsibilities. As we continue to develop our project, I will continue to use Excel for updating the RAM with new tasks and weekly task distribution.

Individual contributions by each member

Member Contribution
Mehdi Saffar Created communication plan, README.md and Wiki's home page. Wrote parts of the user requirement and the glossary, reviewed multiple times. Collected questions for the customer and arranged that meeting with the help of Furkan Nane. Wrote steps of the Search scenario, and reviewed Tracking and Search mockup. Helped with Class diagram and contributed initial draft of Use case diagram. Compiled project plan into a Gantt chart twice. Regularly did house keeping of the wiki and issues. Attended all meetings, lead a few of them. Wrote Executive summary part of the milestone and my section in Evalution of Tools and Processes. Created the scripts necessary to transform this milestone report from markdown to PDF file using imagemagick and pandoc.
A. Furkan Varol
Aleyna Kara First week, I have created Wiki home page. I have designed a logo to customize our home page. I have researched Github, markdown syntax and repository,namely Flutter. After my research, I have created my personal wiki page. Since my job was the revision of requirements, I have researched requirement engineering and then written important parts on my own words as a wiki page for better understanding at the second week. Then, I have styled requirements page with HTML. I have both added and changed some parts,e.g. catagory names, definitions in glossary. Then, I have designed searching mock up. After that, I have created tracking mock up due to the feedback and my experience with Balsamiq. Also, I have edited meeting notes like adding numbers of issues after same feedback. I have determined almost all classes, variables and functions of class diagram and then organized into a class diagram using LucidChart. Furthermore, I have contributed the design part of the project as creating four sequence diagrams. I have been contact with Aslı Aykan to help her to integrate our project as a new team member. Then, we created RAM with Aslı Aykan. I have reviewed not only issues but also all commits of my teammates in order to be fair. In addition, I have designed our new logo. Also, I am one of the person who cares the look of our wiki pages. So, I have tried to stay our wiki pages up-to-date adding some gifs etc. Last, I have written not only the evaluation part of class diagram but also review about Balsamiq and Lucidchart in Milestone 1 Report.
Aslı Aykan Joined the project group after the first 1.5 months of the spring term. Created my personal wiki page, contributed to Repositories We Liked and Git&Github page. Reviewed almost all the works done by my friends before joining the group which are requirements, glossary, scenarios, mockups, and diagrams. Read all the past feedbacks and contributed on the searching scenario accordingly. Created some logos for our e-commerce platform and opened a poll for all logo ideas of the group. Created responsibility assignment matrix with Aleyna Kara by reviewing project plan and Gantt chart, and continued to update it. Recreated the purchasing scenario mockup with Balsamiq to make it compatible with other mockups which are also created with it. Attended all the meetings after joining the group. Wrote the evaluations of scenarios&mockups and RAM, and also review of Excel for the Milestone 1 Report.
Burak Çetin
Furkan Nane I prepared the communication plan. I attended the customer meeting, created the user requirements part of the requirements and involved in revision of requirements. I created the tracking user scenario. I involved in creation of the class diagram. I involved in creation of the project plan. I attended all of the meeetings, tried to coordinate the group, tried to unfold the assignments by asking questions to the Meriç Turan. I wrote the evaluation of requirements,communication plan, zoom and slack parts of the Milestone 1 report.
Hande Şirikçi During the time that we were working on completing Milestone1, approximately whole semester; i attended all meetings and have taken meeting notes in most of them. The first task assigned to me was about Wiki Structure. I tried to classify things in wiki and learned how to use it. I reviewed and corrected project requirements, especially non-functional part of it.I created tracking scenario, by this way we have already prepared the break points of some cases. I attended diagrams ps in order to learn about them and inform other members about diagrams by sending my notes. I was involved in creation of class diagram, tried to decide on class hierarchies and had a meeting about it. I have also been assigned to create our high level project plan, regularly update it.I wrote the evaluation of Project Plan part of Milestone1 Report. I used sharable documents while working, opened issues for each task and created channels on slack for each task that we do together in order to synchronize with my group members, to keep in touch. I was always aware that this class is not just about completing tasks before deadlines but rather about good communication between us.
Hüseyin Seyyid Kaplan Determined the tags, labels and colors as 24 labels in addition to 9 default GitHub labels. Prepared my own wiki-page(to includes parts of About, Skills and Contact) on GitHub. Searched for useful Github repositories that most of people benefit from on web and when I skimmed over lists of repo’s I picked one of them that I liked. Created a page for GitHub repositories that I liked. Studied git as a version management system and watched a video that is recommended to us. Analysed the websites about commercial platform like N11, hepsiburada, Amazon, sahibinden. Created purchasing mockup via Mockflow. Created agenda files for adding issues of week on Wiki pages. Worked on designing a logo and searched several sites. Used brandmark.io to create a logo.
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Mehmet Umut Öksüz | I have prepared a doodle poll to decide out permanent meeting time in the very first week. I have written non-functional requirements part of requirements. And I also have reviewed functional requirements and given feedback to my team. I have contributed to Purchasing scenario of our project and reviewed mockups. I have also designed some logo ideas for my team and contributed to decision of project name. After we get the feedback of requirements v1.0, I have done some changes on requirements accordingly. I have drawn 4 of our sequence diagrams. I contributed to our project plan using ProjectLibre software. I have written evalution of sequence diagrams. I have attended most of our group meetings. | | Ömer Faruk Deniz | | | Özdeniz Dolu | Arranged meeting locations in CmpE building for first 2-3 meetings . Created my personal wiki page. Contributed to the System Requirements and Glossary. I have created a template for a mock-up, which then revised and made into a new mock-up. I have created two sequence diagrams and revised them later on considering the feedbacks. I have taken meeting notes for two meetings. I mainly attended the group meetings. Me and Hande Şirikçi have created the second half of the first part of the project plan|

Communication plan

Communication Channel Purpose Frequency Participants
Slack Will be used as main text and video call communication channel Open Channel Whole Team
Github Main channel where the project develops, includes all documentation Open Channel Whole Team
CMPE building Face to face meetings will be held here Once a week Whole Team
Piazza Communication with the customer will happen here Open Channel Communicatior
Zoom Online team communication and online education Appointed Whole Team

Requirements

1. Functional Requirements

    1.1. User Requirements
    • 1.1.1 Sign Up

      • 1.1.1.1 Customer, Vendor users shall be able to sign up to the system via one of the following methods:

        • 1.1.1.1.1 Regular sign up
        • 1.1.1.1.2 Google sign up
      • 1.1.1.2 Customer, Vendor and Admin users shall be able to use regular sign up by providing the following required information:

        • 1.1.1.2.1 Username
        • 1.1.1.2.2 Password
        • 1.1.1.2.3 E-mail
        • 1.1.1.2.4 Name
        • 1.1.1.2.5 Surname
        • 1.1.1.2.6 Location (not mandatory for customers)
      • 1.1.1.3 Vendor users shall enter at least one location, while Customer shall be able to enter location information if they wish to

      • 1.1.1.4 Customer and Vendor users shall verify their account via a link sent by the system to their e-mail account before being able to checkout a cart.

      • 1.1.1.5 Guest users must read and accept the Terms of Services to be able to sign up.

    • 1.1.2 Login

      • 1.1.2.1 Registered Users who signed up with their Google account shall be able to login with their Google account

      • 1.1.2.2 Registered Users who signed up with a regular signup shall be able to login by providing the following information.

        • 1.1.2.1.1 Username
        • 1.1.2.1.2 Password
    • 1.1.3 Search

      • 1.1.3.1 Guest and Registered Users shall be able to perform a semantic search for a product over:
        • 1.1.3.1.1 Name of the product
        • 1.1.3.1.2 Description of the product
        • 1.1.3.1.3 Type of the product
        • 1.1.3.1.4 Vendor of the product
      • 1.1.3.2 Filter

        • 1.1.3.2.1 Guest and Registered Users shall be able to filter the products according to:

          • 1.1.3.2.1.1 Product's Average customer review (Product rating)
          • 1.1.3.2.1.2 Product vendor
          • 1.1.3.2.1.3 Product brand
          • 1.1.3.2.1.4 Product price range
      • 1.1.3.3 Sort

        • 1.1.3.3.1 Guest and Registered Users shall be able to sort the products according to:

          • 1.1.3.3.1.1 Best sellers
          • 1.1.3.3.1.2 Newest arrivals
          • 1.1.3.3.1.3 Price
          • 1.1.3.3.1.4 Average customer review (Rating)
          • 1.1.3.3.1.5 Number of comments
      • 1.1.3.4 Guest and Registered Users shall be able to see the information below about the products they searched:

        • 1.1.3.4.1 Product type
        • 1.1.3.4.2 Product picture
        • 1.1.3.4.3 Price
        • 1.1.3.4.4 Product vendor
        • 1.1.3.4.5 Average Customer Review (Rating)
        • 1.1.3.4.6 Comments about the product
        • 1.1.3.4.6 Description about the product
      • 1.1.3.5 Guest and Registered Users shall be able to see the information below about the vendors they searched:

        • 1.1.3.5.1 Company name or personal name
        • 1.1.3.5.2 Company logo picture or personal picture
        • 1.1.3.5.3 Average customer review (Rating)
        • 1.1.3.5.4 Products of this vendor
        • 1.1.3.5.5 Comments about the vendor
      • 1.1.3.6 Guest and Registered Users shall be able to search a product by entering their name or type.

      • 1.1.3.7 Guest and Registered Users shall be able to search a vendor by entering their name.

    • 1.1.4 Product Details

      • 1.1.4.1 Guest and Customer users shall be able to see a product's or a vendor's information even if they did not search for the product. 1.1.3.4 and 1.1.3.5 specifies what information users shall be able to see.

      • 1.1.4.2 Vendor users shall be able to update the product's detail information

      • 1.1.4.3 Vendor users shall specify the stock information of a product. This requires:

        • Stock status information: Available, Out of Stock, Online only
        • Locations to which the product is deliverable.
    • 1.1.5 Comment

      • 1.1.5.1 Customer users shall be able to comment on a product only if they have purchased that product.
      • 1.1.5.1 Customer users shall be able to comment on a vendor only if they have purchased a product from that vendor.
      • 1.1.5.2 All users shall be able to see the comments about a product or a vendor.
      • 1.1.5.3 Vendor users shall be able to reply to comments.
      • 1.1.5.4 Customer users shall be able to like or dislike comments.
    • 1.1.6 List

      • 1.1.6.1 Customer users shall be able to create a list of products they would like to keep an eye on.
      • 1.1.6.2 Customer users shall be able to name their lists.
      • 1.1.6.3 Customer users shall be able to edit their lists.
      • 1.1.6.4 Customer users shall be able to delete their lists.
    • 1.1.7 Shopping Cart

      • 1.1.7.1 Guest and Customer users shall be able to add products to their shopping carts.
      • 1.1.7.2 Guest and Customer users shall be able to edit their shopping carts.
      • 1.1.7.3 Guest and Customer users shall be able to view their shopping carts.
      • 1.1.7.4 Guest users shall be able to checkout their shopping cart only after creating a Customer user account with a Quick registration option.
      • 1.1.7.5 Customer users shall be able to checkout their shopping cart only after verifying their account. Please look at 1.1.1.4 and the glossary for details about Account verification.
    • 1.1.8 Order

      • 1.1.8.1 Customers shall be able to see their active (not delivered) orders with their status.

        • 1.1.8.1.1 Status shall be At store or At cargo.
      • 1.1.8.2.1 Guest and Customers shall be able to see their delivered orders with information according to:

        • 1.1.8.2.1 Order date
        • 1.1.8.2.2 Selling price
        • 1.1.8.2.3 Cargo tracking ID
        • 1.1.8.2.4 Cargo tracking link
        • 1.1.8.2.5 Estimated delivery date
      • 1.1.8.3 Customers shall be able to cancel their active orders that have the At store status.

      • 1.1.8.4 Customers shall be able to return their delivered orders.

      • 1.1.8.5 Customers shall be able to see the total amount they spent on orders.

      • 1.1.8.6 Vendors shall be able to cancel an order during the order processing stage when vendors face a problem related to their order. In such case, the Vendor is required to:

        • specify the reason of the cancellation
        • specify their refund policy
    • 1.1.9 Direct Messaging

      • 1.1.9.1 Customers shall be able to communicate with the vendors or admins about orders via direct message.
      • 1.1.9.2 Vendors shall be able to communicate with the customers or admins about a certain product or order via direct message.
    • 1.1.10 Notifications

      • 1.1.10.1 Customers shall be able to choose to get notified whenever the price of any product in their list changes.
      • 1.1.10.2 Customers shall be able to choose to set an alarm for a certain price threshold in order to be notified about whether the price of selected product downs below the threshold price.
    • 1.1.11 Customer Review

      • 1.1.11.1 Customers shall be able to rate a product they have "bought and received".
      • 1.1.11.2 Customers shall be able to rate a vendor from which they have "bought and received" a product.
    • 1.1.12 Purchase

      • 1.1.12.1 Customer users shall be able to purchase the products in their shopping cart by using one of the following payment methods:.

        • 1.1.12.1.1 Debit card
        • 1.1.12.1.2 Credit card
      • 1.1.12.2 Customer users shall agree to the contract of sale before proceeding with the payment.

      • 1.1.12.3 Customer users shall be able to see if the payment is successfully completed or not.

    • 1.1.11 Online Shop

      • 1.1.11.1 Vendor users shall be able to open an online shop
        • 1.1.11.1.1 Vendor users shall be able to put the following information in their online shop:
          • 1.1.11.1.1.1 Vendor information
          • 1.1.11.1.1.2 Active products
          • 1.1.11.1.1.3 Location of physical stores (if any)
        • 1.1.11.1.2 Vendor users should be able to customize the online shop to their liking.
    1.2. System requirements
    • 1.2.1 The system shall have 4 different user types:

      • 1.2.1.1 Guest
      • 1.2.1.2 Customer
      • 1.2.1.3 Vendor
      • 1.2.1.4 Admin
    • 1.2.2 Signup Functionality

      • 1.2.2.1 The system shall provide Regular signup and Google signup.
      • 1.2.2.2 The system shall require acceptance of Terms of Service by the user before continuing with the signup processing.
      • 1.2.2.3 The system shall not allow Guest users to checkout their shopping cart
      • 1.2.2.4 The system shall confirm the user email by sending a link to the email account and receiving a confirmation from the user.
      • 1.2.2.5 The system shall not allow unverified Customer account to checkout their shopping cart
      • 1.2.2.6 The system shall only let confirmed users make transactions. Confirmation is via Google or e-mail.
    • 1.2.3 Search Functionality

      • 1.2.4.1 The system shall provide a semantic search functionality which finds products and vendors based on contextual information. The information shall be looked for in

        • 1.2.4.1.1 Product title
        • 1.2.4.1.1 Product description
        • 1.2.4.1.1 Product details
      • 1.2.3.2 The system shall be able to filter search results according to:

        • 1.2.3.2.1 Average customer review of the product
        • 1.2.3.2.2 Vendor of the product
        • 1.2.3.2.3 Brand of the product
        • 1.2.3.2.4 Price range of the product
      • 1.2.3.3 The system shall be able to sort search results according to:

        • 1.2.3.3.1 The rate of sale
        • 1.2.3.3.2 Arrival time
        • 1.2.3.3.3 Price
        • 1.2.3.3.4 Average customer review
        • 1.2.3.3.5 Number of comments
    • 1.2.3 Products in the system may be discovered in various categories:

      • 1.2.3.1 Arts & Crafts
      • 1.2.3.2 Automotive
      • 1.2.3.3 Baby
      • 1.2.3.4 Beauty & Personal Care
      • 1.2.3.6 Books
      • 1.2.3.7 Boys' Fashion
      • 1.2.3.8 Computers
      • 1.2.3.9 Camera & Photo
      • 1.2.3.10 Cell Phones & Accessories
      • 1.2.3.11 Digital Videos
      • 1.2.3.12 Electronics
      • 1.2.3.13 Furniture
      • 1.2.3.14 Girls' Fashion
      • 1.2.3.15 Health & Households
      • 1.2.3.16 Home & Garden
      • 1.2.3.17 Industrial & Scientific
      • 1.2.3.18 Luggage
      • 1.2.3.19 Men's Fashion
      • 1.2.3.20 Movies & TVs
      • 1.2.3.21 Music & CDs
      • 1.2.3.22 Pet Supplies
      • 1.2.3.23 Software
      • 1.2.3.24 Sports & Outdoor
      • 1.2.3.25 Toys & Games
      • 1.2.3.26 Video Games
      • 1.2.3.27 Women's Fashion
    • 1.2.4 The system shall distinguish between same products that are sold by different vendors.

    • 1.2.5 Product List Functionality

      • 1.2.5.1 Product Lists created by users shall be private.
    • 1.2.6 The system shall have a shopping cart functionality.

    • 1.2.7 Order Functionality

      • 1.2.7.1 System shall show the following information about past orders:

        • 1.2.7.1.1 Order date
        • 1.2.7.1.2 Product price
        • 1.2.7.1.3 Cargo information (Cargo tracking ID and a link to the tracking page)
        • 1.2.7.1.4 Delivery date
        • 1.2.7.1.5 Order status
      • 1.2.7.2 The system shall accept transactions made only with Credit Card or Debit Card.
    • 1.2.8 Price Tracking Functionality

      • 1.2.8.1 The system shall track changes in the prices of the products and alert users if requested.
    • 1.2.9 Notification Functionality

      • 1.2.9.1 The system shall notify users of direct messages.
      • 1.2.9.2 The system shall -if requested- notify users of price changes.
      • 1.2.9.3 The system shall -if it is set- notify users of price alarms.
      • 1.2.9.4 The system shall notify users of changes in order status.
      • 1.2.9.5 The system shall -if requested- notify users of sales and campaigns.
    • 1.2.10 Recommendation Functionality

      • 1.2.10.1 The system shall recommend certain products to the users based on their interactions on the platform.
    • 1.2.11 Direct Messaging Functionality

      • 1.2.11.1 The system shall provide direct messaging functionality between customers and vendors.
      • 1.2.11.2 The system shall provide direct messaging functionality between admin users and registered users for support.
    • 1.2.12 The system provides a like and comment functionality but only to the users whose products has been delivered.

    • 1.2.13 Product Details Functionality

      • 1.2.13.1 The system must keep track of the history of product information updates made by Vendors to avoid Vendors changing product information after bad reviews from Customers.

2. Non-Functional requirements

    2.1. Availability and Accessibility
    • 2.1.1 The system should work on wide range of web browsers (Chrome, Firefox, Safari, Microsoft Edge, Opera).
    • 2.1.2 The mobile app shall be developed natively for Android 7 and newer versions.
    • 2.1.3 Customer and Vendor users shall be able to verify their account via a link sent by the system to their e-mails.
    2.2. Performance
    • 2.2.1 System should be responsive (5 seconds in the worst case).
    • 2.2.2 Android application should be optimized well to work smoothly with lower hardware resources.
    2.3. Security
    • 2.3.1 Authentication and authorization shall always be done in the server side.
    • 2.3.2 Passwords should be hashed and salted to prevent accounts to be stolen in a database injection.
    • 2.3.3 Input to the system shall be properly validated.
    • 2.3.4 Sensitive data (such as passwords) should always be encrypted in requests.
    • 2.3.5 After 3 unsuccessful login attempts, owner of the account shall be informed via e-mail by the system.
    2.4. Protocols and Privacy
    • 2.4.1 Rules defined by GDPR and KVKK and shall be followed strictly when developing the system.
    • 2.4.2 The implementation of the system should follow the standards introduced by the World Wide Web Consortium (W3C)
    • 2.4.3 W3C Activity Streams protocol should be supported by the system.
    • 2.4.4 Privacy policy should be defined exactly and shown to users in registration process and users will be forced to accept it to complete registration.
    • 2.4.5 Distant sales contract should be defined clearly according to regulations, and customers shall be forced to accept it before purchasing any goods.
    2.5. Development and Publish
    • 2.5.1 System shall be deployed to Amazon EC2 servers or Digital Ocean.
    • 2.5.2 System shall be dockerized to ease development process.
    • 2.5.3 System shall have monthly periodic maintenance operations.

Mockups

Design

Class Diagram

Sequence Diagrams

Guest tries to buy product in his or her shopping cart.

Customer adds comment to his or her delivered order.

Customer sends message to the vendor of his or her order.

Customer checks out his or her shopping cart.

Project Plan

Project Plan

Gantt Chart

Responsibility Assignment Matrix

sonmatrix

Logo

🏠 Home

👤 Group Members

Practice App

💻 Project

📆 Meeting Notes

CMPE352 Meeting notes

CMPE451 Meeting notes

📈 Milestones

📜 Assignments

🔎 Research

Clone this wiki locally