-
Notifications
You must be signed in to change notification settings - Fork 1
Home
Okke Harsta edited this page Aug 31, 2021
·
4 revisions
The API for SP Dashboard is protected with basic authentication. See the ansible project for the username / password.
curl -u spdashboard:secret -H 'Content-Type: application/json' -d '@team.json' -X POST 'http://localhost:8080/api/spdashboard/teams'
The content of team.json can be found here. The output is the newly created team including the invites and generated ID.
{
"id": 337,
"urn": "demo:openconext:org:champions",
"name": "Champions ",
"description": "Team champions",
"personalNote": "Team created by SP Dashboard",
"viewable": true,
"created": 1630332882.592000000,
"publicLink": "OQ8X84Vu1JLT2FeT7uHV5bAiQFCqJ1xC6pAYuYqc6IUE3D",
"publicLinkDisabled": true,
"membershipCount": 0,
"memberships": [],
"invitations": [
{
"id": 46814,
"email": "test@test.com",
"timestamp": 1630332882627,
"declined": false,
"accepted": false,
"invitationMessages": [
{
"id": 46621,
"message": "Please..",
"timestamp": 1630332886409
}
],
"intendedRole": "ADMIN",
"language": "DUTCH",
"expiryDate": null,
"daysValid": 30,
"expired": false
}
],
"joinRequests": [],
"externalTeams": []
}
curl -u spdashboard:secret 'http://localhost:8080/api/spdashboard/teams/nl:surfnet:diensten:test-team'
Returns the full team information. Note that the urn is not the fully qualified urn name, but the internal short version of teams.
{
"id": 1,
"urn": "demo:openconext:org:riders",
"name": "riders",
"description": "we are riders",
"personalNote": null,
"viewable": true,
"created": 1630333540,
"publicLink": "wZiomLDTk3CU2FR9bRy1IFCfYSqt5AFwSAs74M1EuIQs3D",
"publicLinkDisabled": false,
"membershipCount": 2,
"memberships": [
{
"id": 1,
"role": "ADMIN",
"created": 1630333540,
"person": {
"id": 1,
"urn": "urn:collab:person:surfnet.nl:jdoe",
"name": "John Doe",
"email": "john.doe@example.org",
"created": 1630333540,
"lastLoginDate": 1630333540,
"guest": false,
"superAdmin": false
},
"urnPerson": "urn:collab:person:surfnet.nl:jdoe",
"urnTeam": "demo:openconext:org:riders",
"expiryDate": null,
"origin": "INITIAL_ADMIN",
"approvedBy": "John Doe"
},
{
"id": 10,
"role": "MEMBER",
"created": 1630333540,
"person": {
"id": 5,
"urn": "urn:collab:person:surfnet.nl:rdoe",
"name": "Ronald Doe",
"email": "ronald.doe@example.org",
"created": 1630333540,
"lastLoginDate": 1630333540,
"guest": false,
"superAdmin": false
},
"urnPerson": "urn:collab:person:surfnet.nl:rdoe",
"urnTeam": "demo:openconext:org:riders",
"expiryDate": null,
"origin": null,
"approvedBy": null
},
{
"id": 13,
"role": "OWNER",
"created": 1630333540,
"person": {
"id": 8,
"urn": "urn:collab:person:example.com:owner",
"name": "Owner User",
"email": "owner@domain.net",
"created": 1630333540,
"lastLoginDate": 1526542332,
"guest": false,
"superAdmin": false
},
"urnPerson": "urn:collab:person:example.com:owner",
"urnTeam": "demo:openconext:org:riders",
"expiryDate": null,
"origin": null,
"approvedBy": null
}
],
"invitations": [
{
"id": 1,
"email": "test@example.com",
"timestamp": 2491484828910,
"declined": false,
"accepted": false,
"invitationMessages": [
{
"id": 1,
"message": "Please join",
"timestamp": 2491484828910
}
],
"intendedRole": "MANAGER",
"language": "DUTCH",
"expiryDate": 1506636000,
"daysValid": 9997,
"expired": false
}
],
"joinRequests": null,
"externalTeams": null
}
curl -u spdashboard:secret -H 'Content-Type: application/json' -d '{"id":1,"role":"OWNER"}' -X PUT 'http://localhost:8080/api/spdashboard/memberships'
The id is the identifier of the membership. The return http status is 201.
curl -u spdashboard:secret -H 'Content-Type: application/json' -d '@invites.json' -X POST 'http://localhost:8080/api/spdashboard/invites'
The content of invites.json can be found here. The return http status is 201.
curl -u spdashboard:secret -H 'Content-Type: application/json' -d '{"id":1,"message":"Please join..."}' -X PUT 'http://localhost:8080/api/spdashboard/invites'
The id is the identifier of the invitation. The return http status is 201.
curl -u spdashboard:secret -H 'Content-Type: application/json' -X DELETE 'http://localhost:8080/api/spdashboard/memberships/1'
The id is the identifier of the membership. The return http status is 201.
curl -u spdashboard:secret -H 'Content-Type: application/json' -X DELETE 'http://localhost:8080/api/spdashboard/teams/1'
The id is the identifier of the team. The return http status is 201.