From 92298c53b58d577d04813095436c1f500475e91d Mon Sep 17 00:00:00 2001 From: Anthony Debucquoy Date: Fri, 15 Dec 2023 14:32:37 +0100 Subject: [PATCH 1/4] First api --- Documents/proto/general/openapi.yaml | 612 ++++++++++++++++++++++++++- 1 file changed, 608 insertions(+), 4 deletions(-) diff --git a/Documents/proto/general/openapi.yaml b/Documents/proto/general/openapi.yaml index 014861d..381b210 100644 --- a/Documents/proto/general/openapi.yaml +++ b/Documents/proto/general/openapi.yaml @@ -18,6 +18,10 @@ tags: description: Scientifics articles extension's endpoints - name: Ext (Schedule) description: Schedule extension's endpoints + - name: Ext (Student Registration) + description: Student Registration's endpoints + - name: Ext (Messaging) + description: Messaging extension's endpoints paths: /ping: @@ -31,6 +35,610 @@ paths: schema: type: string example: pong + # Messaging + + /forum: + get: + summary: get list of available forum + security: + - bearer: [] + tags: + - Ext (Messaging) + - Forum + responses: + '200': + description: OK + content: + application/json: + schema: + type: array + items: + type: object + required: + - id + - name + - owner + properties: + id: + type: integer + name: + type: string + owner: + type: integer + description: user id of the teacher + '401': + $ref: '#/components/responses/UnauthorizedError' + post: + summary: Create a new forum + security: + - bearer: [] + tags: + - Ext (Messaging) + - Forum + requestBody: + required: true + content: + application/x-www-form-urlencoded: + schema: + type: object + properties: + name: + type: string + courseId: + type: integer + responses: + '201': + description: User created + '401': + $ref: '#/components/responses/UnauthorizedError' + /forum/{forumId}: + parameters: + - name: forumId + in: path + description: Id of the forum + required: true + schema: + type: integer + get: + summary: get informations about a forum + tags: + - Ext (Messaging) + - Forum + responses: + '200': + description: OK + content: + application/json: + schema: + type: array + items: + type: object + required: + - id + - name + - owner + properties: + id: + type: integer + name: + type: string + owner: + type: integer + description: user id of the teacher + topics: + type: array + items: + type: object + properties: + id: + type: integer + name: + type: string + autor: + type: integer + description: user Id + registered: + description: List of registered user only if have the authorisation to view + type: array + items: + type: integer + description: userId + '401': + $ref: '#/components/responses/UnauthorizedError' + delete: + summary: remove the forum + security: + - bearer: [] + tags: + - Ext (Messaging) + - Forum + responses: + '201': + description: Forum deleted + '401': + $ref: '#/components/responses/UnauthorizedError' + /forum/{forumId}/topic: + parameters: + - name: forumId + in: path + description: Id of the forum + required: true + schema: + type: integer + get: + summary: list topics of a forum + tags: + - Ext (Messaging) + - Forum + responses: + '200': + description: OK + content: + application/json: + schema: + type: array + items: + type: object + required: + - id + - name + - author + properties: + id: + type: integer + name: + type: string + author: + type: integer + description: user id of the author + '401': + $ref: '#/components/responses/UnauthorizedError' + post: + summary: create a new topic in the forum + tags: + - Ext (Messaging) + - Forum + requestBody: + required: true + content: + application/x-www-form-urlencoded: + schema: + type: object + properties: + subject: + type: string + content: + type: integer + responses: + '201': + description: post created + '401': + $ref: '#/components/responses/UnauthorizedError' + /forum/{forumId}/topic/{topicId}: + parameters: + - name: forumId + in: path + description: Id of the forum + required: true + schema: + type: integer + - name: topicId + in: path + description: Id of the topic + required: true + schema: + type: integer + get: + summary: get info about a topic + tags: + - Ext (Messaging) + - Forum + responses: + '200': + description: OK + content: + application/json: + schema: + type: object + required: + - id + - name + - author + - locked + properties: + id: + type: integer + name: + type: string + author: + type: integer + description: user id of the author + locked: + type: boolean + description: define if the topic is locked to new responses or not + '401': + $ref: '#/components/responses/UnauthorizedError' + delete: + summary: delete a topic + security: + - bearer: [] + tags: + - Ext (Messaging) + - Forum + responses: + '201': + description: Topic deleted + '401': + $ref: '#/components/responses/UnauthorizedError' + /forum/{forumId}/topic/{topicId}/response: + parameters: + - name: forumId + in: path + description: Id of the forum + required: true + schema: + type: integer + - name: topicId + in: path + description: Id of the topic + required: true + schema: + type: integer + get: + summary: list responses of a topic + tags: + - Ext (Messaging) + - Forum + responses: + '200': + description: OK + content: + application/json: + schema: + type: array + items: + type: object + properties: + id: + type: integer + author: + type: integer + description: user id of the author + content: + type: string + '401': + $ref: '#/components/responses/UnauthorizedError' + post: + summary: create a new response + tags: + - Ext (Messaging) + - Forum + requestBody: + required: true + content: + application/x-www-form-urlencoded: + schema: + type: object + properties: + content: + type: integer + responses: + '201': + description: Message posted + '401': + $ref: '#/components/responses/UnauthorizedError' + /forum/{forumId}/topic/{topicId}/response/{responseId}: + parameters: + - name: forumId + in: path + description: Id of the forum + required: true + schema: + type: integer + - name: topicId + in: path + description: Id of the topic + required: true + schema: + type: integer + - name: responseId + in: path + description: Id of the response + required: true + schema: + type: integer + get: + summary: get info on a response + tags: + - Ext (Messaging) + - Forum + responses: + '200': + description: OK + content: + application/json: + schema: + type: object + required: + - id + - author + - content + properties: + id: + type: integer + author: + type: string + content: + type: integer + '401': + $ref: '#/components/responses/UnauthorizedError' + delete: + summary: delete a response + tags: + - Ext (Messaging) + - Forum + responses: + '201': + description: Message deleted + '401': + $ref: '#/components/responses/UnauthorizedError' + + /discussion: + get: + summary: get list of available discussions + tags: + - Ext (Messaging) + - discussion + responses: + '201': + description: OK + content: + application/json: + schema: + type: array + items: + type: object + properties: + id: + type: integer + name: + type: string + users: + type: array + items: + type: integer + '401': + $ref: '#/components/responses/UnauthorizedError' + post: + summary: create a new discussion + tags: + - Ext (Messaging) + - discussion + requestBody: + require: true + content: + application/x-www-form-urlencoded: + schema: + type: object + properties: + name: + type: string + users: + type: array + descrition: id of users + items: + type: integer + responses: + '201': + description: Discussion created + '401': + $ref: '#/components/responses/UnauthorizedError' + /discussion/{id}: + parameters: + - name: id + in: path + description: Id of the discussion + required: true + schema: + type: integer + get: + summary: get info on a discussion + tags: + - Ext (Messaging) + - discussion + responses: + '200': + description: OK + content: + application/json: + schema: + type: object + required: + - id + - name + - users + properties: + id: + type: integer + name: + type: string + users: + type: integer + description: user ids of participants + '401': + $ref: '#/components/responses/UnauthorizedError' + /discussion/{id}/msg: + parameters: + - name: id + in: path + description: Id of the discussion + required: true + schema: + type: integer + get: + summary: list messages in a discussion + tags: + - Ext (Messaging) + - discussion + responses: + '200': + description: Ok + content: + application/json: + schema: + type: array + items: + type: object + properties: + id: + type: integer + datetime: + type: integer + author: + type: integer + content: + type: string + '401': + $ref: '#/components/responses/UnauthorizedError' + post: + summary: post a new message in a discussion + tags: + - Ext (Messaging) + - discussion + requestBody: + required: true + content: + application/x-www-form-urlencoded: + schema: + type: string + description: message content + responses: + '201': + description: Message sent + '401': + $ref: '#/components/responses/UnauthorizedError' + + /appointment: + get: + summary: list appointments + tags: + - Ext (Messaging) + - appointment + parameters: + - name: type + in: query + required: false + schema: + type: string + enum: [open, closed] + responses: + '200': + description: Ok + content: + test/calendar: + description: file containing the appointments + application/json: + schema: + type: array + items: + type: object + properties: + id: + type: integer + teacher: + type: integer + student: + type: integer + date: + type: integer + status: + type: string + '401': + $ref: '#/components/responses/UnauthorizedError' + post: + summary: create a new appointment + tags: + - Ext (Messaging) + - appointment + requestBody: + required: true + content: + application/x-www-form-urlencoded: + schema: + type: object + properties: + content: + type: integer + datetime: + type: integer + to: + type: integer + description: user id of the person to request to + responses: + '201': + description: Appointment created + '401': + $ref: '#/components/responses/UnauthorizedError' + /appointment/{id}: + parameters: + - name: id + in: path + description: Id of the appointment + required: true + schema: + type: integer + get: + summary: get info on an appointment + tags: + - Ext (Messaging) + - appointment + responses: + '200': + description: Ok + content: + test/calendar: + description: file containing the appointment + application/json: + schema: + type: object + properties: + id: + type: integer + teacher: + type: integer + student: + type: integer + date: + type: integer + status: + type: string + '401': + $ref: '#/components/responses/UnauthorizedError' + post: + summary: Accept, decline or propose a new schedule for the appointment + tags: + - Ext (Messaging) + - appointment + requestBody: + required: true + content: + application/x-www-form-urlencoded: + schema: + type: object + properties: + action: + type: string + enum: [accept, refuse, propose] + data: + type: object + description: context dependant response (can be null) + responses: + '201': + description: Done + '401': + $ref: '#/components/responses/UnauthorizedError' + +# general /users: get: summary: list all users @@ -1234,7 +1842,3 @@ components: responses: UnauthorizedError: description: Unauthorized access or missing bearer - - - - -- 2.46.0 From f97d4c3ff33f83d389a0d2b50dc41a61fdc3a3ac Mon Sep 17 00:00:00 2001 From: Anthony Debucquoy Date: Fri, 15 Dec 2023 14:41:20 +0100 Subject: [PATCH 2/4] Roles ref problem --- Documents/proto/general/openapi.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Documents/proto/general/openapi.yaml b/Documents/proto/general/openapi.yaml index 014861d..2ac25de 100644 --- a/Documents/proto/general/openapi.yaml +++ b/Documents/proto/general/openapi.yaml @@ -44,7 +44,7 @@ paths: name: type required: false schema: - $ref: '#components/schemas/Roles' + $ref: '#/components/schemas/Roles' responses: '200': description: OK -- 2.46.0 From 8e3b825673b29bf2b9462cada7d07ba3ff5af15f Mon Sep 17 00:00:00 2001 From: Anthony Debucquoy Date: Fri, 15 Dec 2023 14:44:41 +0100 Subject: [PATCH 3/4] Put tag guest to DisplayArticle asked-by: Max --- Documents/proto/general/openapi.yaml | 1 + 1 file changed, 1 insertion(+) diff --git a/Documents/proto/general/openapi.yaml b/Documents/proto/general/openapi.yaml index 2ac25de..b7a0c6f 100644 --- a/Documents/proto/general/openapi.yaml +++ b/Documents/proto/general/openapi.yaml @@ -911,6 +911,7 @@ paths: summary: get a list of article's data tags: - Users + - Guest - Ext (scientific articles) responses: '200': -- 2.46.0 From f311697047b8055aa01f25286396033e45d6d830 Mon Sep 17 00:00:00 2001 From: Anthony Debucquoy Date: Fri, 15 Dec 2023 14:50:30 +0100 Subject: [PATCH 4/4] Adding delete and get to message-id --- Documents/proto/general/openapi.yaml | 50 ++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) diff --git a/Documents/proto/general/openapi.yaml b/Documents/proto/general/openapi.yaml index 2160d74..9f1af01 100644 --- a/Documents/proto/general/openapi.yaml +++ b/Documents/proto/general/openapi.yaml @@ -517,6 +517,56 @@ paths: description: Message sent '401': $ref: '#/components/responses/UnauthorizedError' + /discussion/{id}/msg/{msgId}: + parameters: + - name: id + in: path + description: Id of the discussion + required: true + schema: + type: integer + - name: msgId + in: path + description: Id of the message + required: true + schema: + type: integer + get: + summary: get info about message + tags: + - Ext (Messaging) + - discussion + responses: + '200': + description: Ok + content: + application/json: + schema: + type: object + properties: + id: + type: integer + datetime: + type: integer + author: + type: integer + content: + type: string + '401': + $ref: '#/components/responses/UnauthorizedError' + delete: + summary: delete a message + security: + - bearer: [] + tags: + - Ext (Messaging) + - discussion + responses: + '201': + description: Message deleted + '401': + $ref: '#/components/responses/UnauthorizedError' + /appointment: get: -- 2.46.0