-
Notifications
You must be signed in to change notification settings - Fork 69
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[v1.5][W11-B4] StardyTogether #82
base: master
Are you sure you want to change the base?
Changes from 120 commits
1a3a4e6
306126e
456957c
56b484f
a767a64
65be8df
ee15b1d
ab9338d
925dcf2
4a3ad84
22585cb
4b2804c
b07fa4b
6f31153
d51c236
dbbc01f
5db70ef
c8f5cb5
76d9e85
976d2ec
b2486e7
a9d0e42
409979b
4aa7886
d16ea49
47b273d
34cbda3
da4def1
efe47a8
726898e
7b04988
e952804
e76f08f
de72570
c8bbcc3
784156f
22e34e8
55b43c8
37d4308
ba0c562
606ba27
dceeba4
666089f
8cee3ef
a042d01
0995682
f7b2c8b
0d960c8
2f3e567
683d83c
6fd48e9
59ccb00
35508fd
4ef7b92
71b7801
a399cde
5802377
3c25363
50c403a
ad91565
f1b7ad0
4278a0b
a240674
c1a2720
262fc9b
320287e
0ac43a9
bdae4ca
7c93c7a
1e4e96a
4c98e88
29e8586
94b8f39
0e2bb4b
0d66858
2a81734
ca9fd8c
3170bd2
bfa0115
cdd655f
d9a8614
aabd314
8ef17ab
f5df6a8
60f7f29
9c6e56e
06f1c6e
93bc64c
d8ef8a0
c3d57b1
8496b3f
5d92579
c66f132
8dd4ba2
fe819d4
170069a
031bd99
b6bdcbc
a91842d
0c51ca6
2e1835a
40e55d2
bc3dbfa
29028d8
16dabbe
bcb9552
3919538
5536072
5922769
412afac
794e3e4
d1a9204
2c0229c
4f667c5
c21ddf5
b9fbae7
73c5f79
771b2af
8d2e710
88990a7
9b93323
abde8f7
00a40e1
ecaf17a
0a5bad8
fc05222
9a09713
3839cad
c809e7c
ead7680
6242fe0
a4de846
047ab8e
496af9f
3522c6e
f3ec2ac
84b1629
feaad71
677f0c0
1737a21
5861614
46cac33
a178980
b42a4e7
185e0bb
8ce1573
a58da44
727714f
acbf5b7
dd3b3d1
61f6821
6f1e032
581383c
3cfd398
d1d9c66
e8a9846
82b7306
ca13518
fbf4df2
2cdb43f
84c2b38
ee6069f
c8692f1
3633d56
3b7dc54
9ff4c58
a0ad363
1c3b64b
5755736
78864fc
a2630dd
2174981
9420eda
5dd5efa
5a9c185
aa76682
7c1a675
f768d14
e834417
347755e
77efcbf
15f1118
58cf73f
c3be5a9
009204c
6b325ab
cb87db8
786965e
d08a1ca
1250e60
e51f54f
668cdad
d75c874
22f2b8d
bf257c6
0c24493
3f862af
02365ca
177c3ce
6cdacc1
d2184fc
d8a9420
966251b
4ec9b73
e41885d
d7d79b8
b9e6776
6642c92
a008ced
43e2122
a0d13b8
7430786
1dfbc66
a891526
6febb8a
7b2cdfe
582c61c
43fd51b
ae035af
200dabb
02712eb
f2798db
e80c6a7
564a1b0
0a1defc
24ac62a
24658d4
6a134fb
de27134
a519b7d
40494cc
6cdbc0b
ce03243
a011769
0b0943b
8628b5e
dd90c8b
a47f0be
4b34348
32c4094
e147ab3
c63d8f7
23451c5
11358c2
6bf72e4
2c0792b
a67ac3c
692fd0a
8bb43fb
1a86375
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,10 +1,10 @@ | ||
= Address Book (Level 4) | ||
= StardyTogether | ||
ifdef::env-github,env-browser[:relfileprefix: docs/] | ||
|
||
https://travis-ci.org/se-edu/addressbook-level4[image:https://travis-ci.org/se-edu/addressbook-level4.svg?branch=master[Build Status]] | ||
https://ci.appveyor.com/project/damithc/addressbook-level4[image:https://ci.appveyor.com/api/projects/status/3boko2x2vr5cc3w2?svg=true[Build status]] | ||
https://coveralls.io/github/se-edu/addressbook-level4?branch=master[image:https://coveralls.io/repos/github/se-edu/addressbook-level4/badge.svg?branch=master[Coverage Status]] | ||
https://www.codacy.com/app/damith/addressbook-level4?utm_source=github.com&utm_medium=referral&utm_content=se-edu/addressbook-level4&utm_campaign=Badge_Grade[image:https://api.codacy.com/project/badge/Grade/fc0b7775cf7f4fdeaf08776f3d8e364a[Codacy Badge]] | ||
https://travis-ci.org/CS2103JAN2018-W11-B4/main[image:https://travis-ci.org/CS2103JAN2018-W11-B4/main.svg?branch=master[Build Status]] | ||
https://ci.appveyor.com/project/yeggasd/main[image:https://ci.appveyor.com/api/projects/status/kc7eo8888cc960u0?svg=true[Build status]] | ||
https://coveralls.io/github/CS2103JAN2018-W11-B4/main?branch=master[image:https://coveralls.io/repos/github/CS2103JAN2018-W11-B4/main/badge.svg?branch=master[Coverage Status]] | ||
https://app.codacy.com/app/yeggasd/main[image:https://api.codacy.com/project/badge/Grade/81c0e706007944e881b2290412d87325[Codacy Badge]] | ||
https://gitter.im/se-edu/Lobby[image:https://badges.gitter.im/se-edu/Lobby.svg[Gitter chat]] | ||
|
||
ifdef::env-github[] | ||
|
@@ -15,19 +15,15 @@ ifndef::env-github[] | |
image::images/Ui.png[width="600"] | ||
endif::[] | ||
|
||
* This is a desktop Address Book application. It has a GUI but most of the user interactions happen using a CLI (Command Line Interface). | ||
* It is a Java sample application intended for students learning Software Engineering while using Java as the main programming language. | ||
* It is *written in OOP fashion*. It provides a *reasonably well-written* code example that is *significantly bigger* (around 6 KLoC)than what students usually write in beginner-level SE modules. | ||
* What's different from https://github.com/se-edu/addressbook-level3[level 3]: | ||
** A more sophisticated GUI that includes a list panel and an in-built Browser. | ||
** More test cases, including automated GUI testing. | ||
** Support for _Build Automation_ using Gradle and for _Continuous Integration_ using Travis CI. | ||
* This is a desktop Address Book application for students studying in NUS (National University of Singapore). | ||
* Manage the contacts of your friends in University, keep track of your friends' Birthdays, find the location of your lecture venues! | ||
* Share useful information with your friends who are taking the same modules and find a common studying time! | ||
* StardyTogether has a GUI (Graphic User Interface) but most of the user interactions happen using a CLI (Command Line Interface). | ||
|
||
== Site Map | ||
|
||
* <<UserGuide#, User Guide>> | ||
* <<DeveloperGuide#, Developer Guide>> | ||
* <<LearningOutcomes#, Learning Outcomes>> | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Good job removing irrelevant sections |
||
* <<AboutUs#, About Us>> | ||
* <<ContactUs#, Contact Us>> | ||
|
||
|
@@ -36,5 +32,6 @@ endif::[] | |
* Some parts of this sample application were inspired by the excellent http://code.makery.ch/library/javafx-8-tutorial/[Java FX tutorial] by | ||
_Marco Jakob_. | ||
* Libraries used: https://github.com/TomasMikula/EasyBind[EasyBind], https://github.com/TestFX/TestFX[TextFX], https://bitbucket.org/controlsfx/controlsfx/[ControlsFX], https://github.com/FasterXML/jackson[Jackson], https://github.com/google/guava[Guava], https://github.com/junit-team/junit4[JUnit4] | ||
* Source code is from AddressBook-Level4 project created by SE-EDU initiative at https://github.com/se-edu/ | ||
|
||
== Licence : link:LICENSE[MIT] |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -3,51 +3,49 @@ | |
:imagesDir: images | ||
:stylesDir: stylesheets | ||
|
||
AddressBook - Level 4 was developed by the https://se-edu.github.io/docs/Team.html[se-edu] team. + | ||
_{The dummy content given below serves as a placeholder to be used by future forks of the project.}_ + | ||
{empty} + | ||
StardyTogether was developed by team W11-B4. + | ||
We are a team based in the http://www.comp.nus.edu.sg[School of Computing, National University of Singapore]. | ||
|
||
== Project Team | ||
|
||
=== John Doe | ||
image::damithc.jpg[width="150", align="left"] | ||
{empty}[http://www.comp.nus.edu.sg/~damithch[homepage]] [https://github.com/damithc[github]] [<<johndoe#, portfolio>>] | ||
=== Joanne Ong | ||
image::joanne.jpg[width="150", align="left"] | ||
{empty}[https://github.com/joanneong[github]] [<<johndoe#, portfolio>>] | ||
|
||
Role: Project Advisor | ||
|
||
''' | ||
|
||
=== John Roe | ||
image::lejolly.jpg[width="150", align="left"] | ||
{empty}[http://github.com/lejolly[github]] [<<johndoe#, portfolio>>] | ||
=== Ong Jing Yin | ||
image::jing.jpg[width="150", align="left"] | ||
{empty}[http://github.com/jingyinno[github]] [<<johndoe#, portfolio>>] | ||
|
||
Role: Team Lead + | ||
Responsibilities: UI | ||
Responsibilities: Logic | ||
|
||
''' | ||
|
||
=== Johnny Doe | ||
image::yijinl.jpg[width="150", align="left"] | ||
{empty}[http://github.com/yijinl[github]] [<<johndoe#, portfolio>>] | ||
=== Low Cai Jun | ||
image::caijun.jpg[width="150", align="left"] | ||
{empty}[http://github.com/caijun7[github]] [<<johndoe#, portfolio>>] | ||
|
||
Role: Developer + | ||
Responsibilities: Data | ||
Responsibilities: Model | ||
|
||
''' | ||
|
||
=== Johnny Roe | ||
image::m133225.jpg[width="150", align="left"] | ||
=== Wayne Neo Wei Zhe | ||
image::wayne.jpg[width="150", align="left"] | ||
{empty}[http://github.com/m133225[github]] [<<johndoe#, portfolio>>] | ||
|
||
Role: Developer + | ||
Responsibilities: Dev Ops + Threading | ||
Responsibilities: Storage | ||
|
||
''' | ||
|
||
=== Benson Meier | ||
image::yl_coder.jpg[width="150", align="left"] | ||
{empty}[http://github.com/yl-coder[github]] [<<johndoe#, portfolio>>] | ||
=== Lee Yong Ler | ||
image::yongler.jpg[width="150", align="left"] | ||
{empty}[http://github.com/yeggasd[github]] [<<johndoe#, portfolio>>] | ||
|
||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. As I mentioned in class, the photos are very nice and everything, so 👍 But if you want to be even stricter, the textbook says: "The photo of a team member should be doc/images/githbub_username_in_lower_case.png e.g. docs/images/damithc.png." |
||
Role: Developer + | ||
Responsibilities: UI | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,4 @@ | ||
= AddressBook Level 4 - Developer Guide | ||
= StardyTogether - Developer Guide | ||
:toc: | ||
:toc-title: | ||
:toc-placement: preamble | ||
|
@@ -359,9 +359,25 @@ image::UndoRedoActivityDiagram.png[width="650"] | |
// end::undoredo[] | ||
|
||
// tag::dataencryption[] | ||
=== [Proposed] Data Encryption | ||
=== Data Encryption | ||
==== Current Implementation | ||
|
||
We are using `java.crypto.cipher` and `java.security.key` package for the encryption of the data. The `SecurityUtil` class is used to provide the `SHA-1` hashing and `AES` encryption/decryption required. | ||
|
||
Using a given password, it is first hashed using `SHA-1` to be used as the `AES` key. | ||
The first 16 bits of the digest created by the `SHA-1` hash is extracted. | ||
This is required as `AES` requires its key to be 16 bits long. | ||
|
||
Although this would subject the data to be vulnerable to brute force attack, this data encryption is not used for the purpose of preventing attacks. | ||
It is used to prevent data from being stored in plain text and hence a simple cipher would suffice. | ||
|
||
* The encryption can be done simply by using `SecurityUtil.encrypt()` which will encrypt the addressbook.xml. | ||
* The decryption can be done simply by using `SecurityUtil.decrypt()` which will decrypt the addressbook.xml. | ||
* Currently, decryption/encryption is done in `XmlAddressBookStorage` class before/after `readAddressBook` and `saveAddressBook`. | ||
|
||
_{Explain here how the data encryption feature will be implemented}_ | ||
==== Design Considerations | ||
|
||
===== Aspect: <TODO> | ||
|
||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Seems like there are some formatting issues with the bullet points in this entire section :P There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Also, is it possible for you to find an |
||
// end::dataencryption[] | ||
|
||
|
@@ -787,8 +803,10 @@ See this https://github.com/se-edu/addressbook-level4/pull/599[PR] for the step- | |
* can type fast | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Remember to update the application title for the developer guide as well! |
||
* prefers typing over mouse input | ||
* is reasonably comfortable using CLI apps | ||
* is a student in National University of Singapore | ||
* has many friends in the same course | ||
|
||
*Value proposition*: manage contacts faster than a typical mouse/GUI driven app | ||
*Value proposition*: share useful information with their friends who are taking the same modules and find a common studying time | ||
|
||
[appendix] | ||
== User Stories | ||
|
@@ -800,15 +818,27 @@ Priorities: High (must have) - `* * \*`, Medium (nice to have) - `* \*`, Low (un | |
|Priority |As a ... |I want to ... |So that I can... | ||
|`* * *` |new user |see usage instructions |refer to instructions when I forget how to use the App | ||
|
||
|`* * *` |student with friends |search friends who have taken or are taking similar modules |know who I can group with or approach for help | ||
|
||
|`* * *` |student with friends |find my friend’s timetables |can find common studying time with them | ||
|
||
|`* * *` |user |add tasks |keep track of what I need to do | ||
|
||
|`* * *` |user |add a new person | | ||
|
||
|`* * *` |user |delete a person |remove entries that I no longer need | ||
|
||
|`* * *` |user |find a person by name |locate details of persons without having to go through the entire list | ||
|
||
|`* * *` |user who is concerned about privacy |have my data encrypted |ensure that no one can access my data without my permission | ||
|
||
|`* *` |user |hide <<private-contact-detail,private contact details>> by default |minimize chance of someone else seeing them by accident | ||
|
||
|`* *` |student with friends |tag my friends in my tasks, so that we can share important information | | ||
|
||
|`*` |user with many persons in the address book |sort persons by name |locate a person easily | ||
|
||
|`*` |student |find venues in NUS |locate my tutorial rooms | ||
|======================================================================= | ||
|
||
_{More to be added}_ | ||
|
@@ -844,6 +874,44 @@ Use case ends. | |
+ | ||
Use case resumes at step 2. | ||
|
||
[discrete] | ||
=== Use case: Find venue | ||
|
||
*MSS* | ||
|
||
1. User requests to find an available venue | ||
2. AddressBook prompts user to input a faculty | ||
3. User requests venues near this faculty | ||
4. AddressBook prints out a list of available venues near the specified faculty | ||
+ | ||
Use case ends. | ||
|
||
*Extensions* | ||
|
||
[none] | ||
* 2a. No location is available | ||
+ | ||
[none] | ||
** 2a1. AddressBook displays the empty result | ||
+ | ||
Use case resumes at step 2 | ||
|
||
* 3a. The given location is invalid. | ||
+ | ||
[none] | ||
** 3a1. AddressBook shows an error message. | ||
+ | ||
Use case resumes at step 2. | ||
|
||
* 4a. AddressBook cannot retrieve the information online | ||
+ | ||
[none] | ||
** 4a1. AddressBook shows an error message | ||
** 4a2. AddressBook attempts to reconnect | ||
** 4a3. If problem persists, AddressBook directs User to troubleshooting | ||
+ | ||
Use case ends | ||
|
||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Good to see a new use case added :) |
||
_{More to be added}_ | ||
|
||
[appendix] | ||
|
@@ -852,6 +920,13 @@ _{More to be added}_ | |
. Should work on any <<mainstream-os,mainstream OS>> as long as it has Java `1.8.0_60` or higher installed. | ||
. Should be able to hold up to 1000 persons without a noticeable sluggishness in performance for typical usage. | ||
. A user with above average typing speed for regular English text (i.e. not code, not system admin commands) should be able to accomplish most of the tasks faster using commands than using the mouse. | ||
. Address book must be able to be picked up with 2 hours of usage. | ||
. Color Scheme must be pleasing to the eyes. | ||
. User guide must be clear and concise. | ||
. Basic features must be intuitive to use. | ||
. Should respond to user within 3 seconds. | ||
. Should work in both 32-bit and 64-bit environments. | ||
. Should be usable by a new user who has not used command line interface before. | ||
|
||
_{More to be added}_ | ||
|
||
|
@@ -925,4 +1000,8 @@ _{ more test cases ... }_ | |
|
||
.. _{explain how to simulate a missing/corrupted file and the expected behavior}_ | ||
|
||
=== Encrypting data | ||
. Dealing with wrong password | ||
.. Change password | ||
|
||
_{ more test cases ... }_ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just noticed that your mock UI has the name "Address App" :P