2017-01-26 14:58:52 +01:00
|
|
|
#######################
|
|
|
|
LoginAPI (api/login)
|
|
|
|
#######################
|
2017-03-07 07:07:13 +01:00
|
|
|
GET -> Authentication method
|
2017-01-26 17:30:23 +01:00
|
|
|
Out:
|
|
|
|
200 -> AUTH_RESULT = "OK" : Authentication sucessful
|
|
|
|
401 -> AUTH_RESULT = "AUTHENTICATION_FAILURE" : Wrong login/password
|
|
|
|
403 -> AUTH_RESULT = "NOT_ALLOWED" : User is not allowed for this application
|
|
|
|
201 -> AUTH_RESULT = "ALREADY_LOGGED" : A user is already logged on this session
|
2017-01-26 14:58:52 +01:00
|
|
|
|
|
|
|
DELETE -> Logout current user
|
2017-01-26 17:30:23 +01:00
|
|
|
Out:
|
|
|
|
200 -> AUTH_RESULT = "OK" : Logout sucessful
|
|
|
|
|
|
|
|
|
|
|
|
#######################
|
|
|
|
UserInfoAPI (api/userInfo)
|
|
|
|
#######################
|
|
|
|
GET -> Get the current logged user, return None if no one is connected
|
|
|
|
Out:
|
2017-03-14 10:14:11 +01:00
|
|
|
200 -> USER = <USER_OBJECT>|null : Dictionary containing user infos or null
|
2017-01-26 14:58:52 +01:00
|
|
|
|
|
|
|
|
2017-03-07 07:07:13 +01:00
|
|
|
########################
|
|
|
|
Redirect to cas auth (/login)
|
|
|
|
########################
|
|
|
|
Redirect to cas auth
|
2017-03-14 10:14:11 +01:00
|
|
|
|
|
|
|
|
|
|
|
########################
|
|
|
|
UserAPI (api/user)
|
|
|
|
########################
|
|
|
|
POST -> Create a user if it not already exists
|
|
|
|
In:
|
2017-03-17 10:01:30 +01:00
|
|
|
CASid = Login of the user caught from the CAS authentication (must be unique)
|
2017-03-14 10:14:11 +01:00
|
|
|
role = Role of the user (can be concatenated with -) 1=secrétaire, 2=resp_formation, 3=tuteur_univ, 4=étudiant
|
|
|
|
Out:
|
|
|
|
200 -> UID = <USER_ID> : The user already exists with the id USER_ID
|
|
|
|
201 -> UID = <USER_ID> : The user has been successfully created with the id USER_ID
|
|
|
|
400 -> ERROR = "One or more parameters are missing" : Bad request
|
2017-03-17 10:01:30 +01:00
|
|
|
405 -> ERROR = "A user with this email already exists !" : A user with this email already exists
|
2017-03-14 10:14:11 +01:00
|
|
|
|
|
|
|
PUT -> Modify an existing user
|
|
|
|
In: (Suffix = /byuid/<USER_ID>)
|
2017-03-17 10:01:30 +01:00
|
|
|
CASid = Login of the user caught from the CAS authentication (must be unique)
|
2017-03-14 10:14:11 +01:00
|
|
|
role = Role of the user (can be concatenated with -) 1=secrétaire, 2=resp_formation, 3=tuteur_univ, 4=étudiant
|
|
|
|
phone = Phone number of the user (00.00.00.00.00)
|
2017-03-17 10:01:30 +01:00
|
|
|
email = Email of the user (must be unique)
|
2017-03-14 10:14:11 +01:00
|
|
|
Out:
|
|
|
|
200 -> UID = <USER_ID> : The user has been modified sucessfully with the id USER_ID
|
|
|
|
400 -> ERROR = "One or more parameters are missing !" : Bad request
|
|
|
|
405 -> ERROR = "This user doesn't exists !" : Bad USER_ID provided
|
2017-03-17 10:01:30 +01:00
|
|
|
405 -> ERROR = "A user with this CASid (login) already exists !" : A user with this login already exists
|
|
|
|
405 -> ERROR = "A user with this email already exists !" : A user with this email already exists
|
2017-03-14 10:14:11 +01:00
|
|
|
|
|
|
|
GET -> Getting specified user infos
|
|
|
|
In: (Suffixes = /byuid/<USER_ID> | /bylogin/<USER_LOGIN> | /byemail/<USER_EMAIL>)
|
|
|
|
Out:
|
|
|
|
200 -> USER = <USER_OBJECT>|null : Dictionary containing user infos or null
|
|
|
|
|
2017-03-17 09:08:50 +01:00
|
|
|
########################
|
|
|
|
GroupAPI (api/group)
|
|
|
|
########################
|
|
|
|
POST -> Create a group if it not already exists
|
|
|
|
In:
|
|
|
|
name = Name of the group (must be unique)
|
|
|
|
year = Parameter setting the year
|
|
|
|
class_short = Parameter setting the short name of the class
|
|
|
|
class_long = Parameter setting the full name of the class
|
|
|
|
department = Parameter setting the name of the class's department
|
|
|
|
resp_id = UID of the group's responsible
|
|
|
|
sec_id = UID of the group's secretary
|
|
|
|
Out:
|
|
|
|
200 -> GID = <GROUP_ID> : The group already exists with the id GROUP_ID
|
|
|
|
201 -> GID = <GROUP_ID> : The group has been successfully created with the id GROUP_ID
|
|
|
|
400 -> ERROR = "One or more parameters are missing" : Bad request
|
|
|
|
400 -> ERROR = "The user with id <USER_ID> doesn't exists !" : The given USER_ID for resp_id or sec_id is not found
|
|
|
|
|
|
|
|
PUT -> Modify an existing group
|
|
|
|
In: (Suffix = /bygid/<GROUP_ID>)
|
|
|
|
name = Name of the group (must be unique)
|
|
|
|
year = Parameter setting the year
|
|
|
|
class_short = Parameter setting the short name of the class
|
|
|
|
class_long = Parameter setting the full name of the class
|
|
|
|
department = Parameter setting the name of the class's department
|
|
|
|
resp_id = UID of the group's responsible
|
|
|
|
sec_id = UID of the group's secretary
|
|
|
|
Out:
|
|
|
|
200 -> GID = <GROUP_ID> : The group has been modified sucessfully with the id GROUP_ID
|
|
|
|
400 -> ERROR = "One or more parameters are missing !" : Bad request
|
|
|
|
400 -> ERROR = "The user with id <USER_ID> doesn't exists !" : The given USER_ID for resp_id or sec_id is not found
|
|
|
|
405 -> ERROR = "This group doesn't exists !" : Bad GROUP_ID provided
|
|
|
|
405 -> ERROR = "A group with this name already exists !" : A group with this name already exists
|
|
|
|
|
|
|
|
GET -> Getting specified group infos
|
|
|
|
In: (Suffixes = /bygid/<GROUP_ID> | /byname/<GROUP_NAME> )
|
|
|
|
Out:
|
2017-03-17 17:10:38 +01:00
|
|
|
200 -> GROUP = <GROUP_OBJECT>|null : Dictionary containing group infos or null
|
|
|
|
|
|
|
|
OPTIONS -> Add pairs of users (student/tutor) to the group
|
|
|
|
In:
|
|
|
|
pairs -> Table of pairs student's uid/tutor's uid (ex: [[1,2],[3,2]])
|
|
|
|
Out:
|
|
|
|
200 -> RESULT = "Pairs added successfully"
|
|
|
|
400 -> ERROR = "One or more parameters are missing !" : Bad request
|
|
|
|
400 -> ERROR = "The user with id <USER_ID> doesn't exists !" : The given USER_ID for student or tutor is not found
|
|
|
|
400 -> ERROR = "A student must have the 'student' role !" : The given USER_ID for student doesn't have the "student" role (4)
|
|
|
|
400 -> ERROR = "A student can't be a tutor !" : The given USER_ID for tutor have the "student" role (4) and so can't be a tutor
|
|
|
|
405 -> ERROR = "This group doesn't exists !" : Bad GROUP_ID provided
|
|
|
|
409 -> ERROR = "Pairs are incorrectly formed !" : Bad syntax in pairs table
|