Use cases
...
In the second phase, we could add new features so that a user could help the community by marking a Thread is helpful, and by marking a Reply is helpful or unhelpful.
Mockups
Phase 1
Summary View
Paginated Threads
Thread View
...
New Thread
New Reply
Models
API
| Action | Intended User | URI | Method | Request Parameters | Request Body | Response Body | Notification Sent to (P2) |
1 | Get Forum Metadata for a Project | authorized user | /forum/{projectId} | GET |
| | Update Forum Description | Moderator | /forum/{forumId}/description | POST | | String | | | 3 | Get Threads of a Forum | authorized user | /forum/{forumId}/threads | GET | order, limit, offset |
4 | Create a Thread | authorized user | /thread | POST |
| | 5
|
4 | Get a Thread by its ID | authorized user | /thread/{threadId} | GET |
| 6 | Create a Reply | authorized user | /reply | POST |
|
| CreateReply | Reply | Thread’s Author |
76 | Get a Reply by its ID | authorized user | /reply/{replyId} | GET |
| 8 | , Author | | | | 9 | , Author10 | | | | | 9 | Get Replies for a Thread | authorized user | /thread/{threadId}/replies | GET | order, limit, offset |
| | 11
|
10 | Update a Thread’s Message | Author | /thread/{threadId}/message | PUT |
| 12 | Update a Reply’s Message | Author | /reply/{replyId}/message | PUT |
| 13 | | 12 | Update a Thread's title | Author | /thread/{threadId}/title | PUT |
| | | | | | | | String | | | 13 | Restore a deleted thread | Moderator | /thread/{threadId}/restore | PUT |
|
|
|
|
14 | Retrieve a paginated list of moderator for a given forum | authorized user | /forum/{forumId}/moderators | GET | limit, offset |
| PaginatedModerators |
|
Future Potential Extensions
Search
Notification
Vote (up and down) on responses
Flag a thread/ response as inappropriate
Mark a thread as helpful
Be able to see that there are discussions on a file / table* - DONE
Be able to link to a thread - DONE
- Moderator would be able to close a thread and link to another thread
...