From fdaf96778b6c61e12b9ed513a538e78a222945fc Mon Sep 17 00:00:00 2001 From: Dimitris Frangiadakis Date: Fri, 21 Apr 2023 13:52:00 +0300 Subject: [PATCH] communities: add /records and /members docs, replace id instances with {id} --- docs/reference/rest_api_communities.md | 271 +++++++++++++++---------- docs/reference/rest_api_members.md | 131 ++++++------ 2 files changed, 232 insertions(+), 170 deletions(-) diff --git a/docs/reference/rest_api_communities.md b/docs/reference/rest_api_communities.md index 11f64390..9f18c301 100644 --- a/docs/reference/rest_api_communities.md +++ b/docs/reference/rest_api_communities.md @@ -15,12 +15,12 @@ ### Community access -| Name | Type | Location | Description | -|-----------------|--------|----------|------------------------------------------------------------------------------------------------------------------------------| -| `visibility` | string | body | Required, one of `"public"` or `"restricted"`. Visible by the public or restricted to those who have access. | -| `member_policy` | string | body | Required, one of `"open"` or `"closed"`. Can people request to be part of the community (open) or not (closed)? | +| Name | Type | Location | Description | +|-----------------|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------| +| `visibility` | string | body | Required, one of `"public"` or `"restricted"`. Visible by the public or restricted to those who have access. | +| `member_policy` | string | body | Required, one of `"open"` or `"closed"`. Can people request to be part of the community (open) or not (closed)? | | `record_policy` | string | body | Required, one of `"open"` or `"closed"`. Can community's members submit a record to the community without a review (open), or a review is always necessary (closed)? | -| `owned_by` | array | body | Array of Objects of the form: `{"user": }`. Community owners (admins). | +| `owned_by` | array | body | Array of Objects of the form: `{"user": }`. Community owners (admins). | ### Community metadata @@ -86,15 +86,15 @@ Content-Type: application/json "id": "399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3", "revision_id": 1, "links": { - "self": "{scheme+hostname}/api/communities/{community_id}", - "self_html": "{scheme+hostname}/communities/{community_slug}", - "settings_html": "{scheme+hostname}/communities/{community_slug}/settings", - "logo": "{scheme+hostname}/communities/{community_id}/logo", - "rename": "{scheme+hostname}/communities/{community_id}", - "members": "{scheme+hostname}/communities/{community_id}/members", - "public_members": "{scheme+hostname}/communities/{community_id}/members/public", - "invitations": "{scheme+hostname}/communities/{community_id}/invitations", - "requests": "{scheme+hostname}/communities/{community_id}/requests" + "self": "{scheme+hostname}/api/communities/{id}", + "self_html": "{scheme+hostname}/communities/{id}", + "settings_html": "{scheme+hostname}/communities/{id}/settings", + "logo": "{scheme+hostname}/communities/{id}/logo", + "rename": "{scheme+hostname}/communities/{id}", + "members": "{scheme+hostname}/communities/{id}/members", + "public_members": "{scheme+hostname}/communities/{id}/members/public", + "invitations": "{scheme+hostname}/communities/{id}/invitations", + "requests": "{scheme+hostname}/communities/{id}/requests" }, "metadata": { "title": "My Community", @@ -126,7 +126,7 @@ Content-Type: application/json **Request** ```http -PUT /api/communities/ HTTP/1.1 +PUT /api/communities/{id} HTTP/1.1 Content-Type: application/json { @@ -170,15 +170,15 @@ Content-Type: application/json "id": "399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3", "revision_id": 2, "links": { - "self": "{scheme+hostname}/api/communities/{community_id}", - "self_html": "{scheme+hostname}/communities/{community_slug}", - "settings_html": "{scheme+hostname}/communities/{community_slug}/settings", - "logo": "{scheme+hostname}/communities/{community_id}/logo", - "rename": "{scheme+hostname}/communities/{community_id}", - "members": "{scheme+hostname}/communities/{community_id}/members", - "public_members": "{scheme+hostname}/communities/{community_id}/members/public", - "invitations": "{scheme+hostname}/communities/{community_id}/invitations", - "requests": "{scheme+hostname}/communities/{community_id}/requests" + "self": "{scheme+hostname}/api/communities/{id}", + "self_html": "{scheme+hostname}/communities/{id}", + "settings_html": "{scheme+hostname}/communities/{id}/settings", + "logo": "{scheme+hostname}/communities/{id}/logo", + "rename": "{scheme+hostname}/communities/{id}", + "members": "{scheme+hostname}/communities/{id}/members", + "public_members": "{scheme+hostname}/communities/{id}/members/public", + "invitations": "{scheme+hostname}/communities/{id}/invitations", + "requests": "{scheme+hostname}/communities/{id}/requests" }, "metadata": { "title": "My Updated Community", @@ -198,19 +198,19 @@ Content-Type: application/json ### Delete a Community -`DELETE /api/communities/` +`DELETE /api/communities/{id}` **Parameters** -| Name | Type | Location | Description | -|------------|--------|----------|----------------------------------------------------------------------------| -| `com_slug` | string | path | Identifier of the community, e.g. `my_community` | -| `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | +| Name | Type | Location | Description | +|----------|--------|----------|---------------------------------------------------------------------------------------------------| +| `id` | string | path | UUID or slug of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` or 'my-super-community' | +| `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | **Request** ```http -DELETE /api/communities/ HTTP/1.1 +DELETE /api/communities/{id} HTTP/1.1 Accept: application/json ``` @@ -223,19 +223,19 @@ HTTP/1.1 204 No Content ### Get a Community -`GET /api/communities/` +`GET /api/communities/{id}` **Parameters** -| Name | Type | Location | Description | -|----------|--------|----------|----------------------------------------------------------------------------| -| `com_id` | string | path | UUID of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` | -| `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | +| Name | Type | Location | Description | +|----------|--------|----------|-----------------------------------------------------------------------------------------------------| +| `id` | string | path | UUID or slug of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` or `my-super-community` | +| `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | **Request** ```http -GET /api/communities/ HTTP/1.1 +GET /api/communities/{id} HTTP/1.1 Accept: application/json ``` @@ -256,16 +256,16 @@ Content-Type: application/json "id": "399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3", "revision_id": 2, "links": { - "self": "{scheme+hostname}/api/communities/{community_id}", - "self_html": "{scheme+hostname}/communities/{community_slug}", - "settings_html": "{scheme+hostname}/communities/{community_slug}/settings", - "logo": "{scheme+hostname}/communities/{community_id}/logo", - "rename": "{scheme+hostname}/communities/{community_id}", - "members": "{scheme+hostname}/communities/{community_id}/members", - "public_members": "{scheme+hostname}/communities/{community_id}/members/public", - "invitations": "{scheme+hostname}/communities/{community_id}/invitations", - "requests": "{scheme+hostname}/communities/{community_id}/requests", - "featured": "{scheme+hostname}/communities/{community_id}/featured" + "self": "{scheme+hostname}/api/communities/{id}", + "self_html": "{scheme+hostname}/communities/{id}", + "settings_html": "{scheme+hostname}/communities/{id}/settings", + "logo": "{scheme+hostname}/communities/{id}/logo", + "rename": "{scheme+hostname}/communities/{id}", + "members": "{scheme+hostname}/communities/{id}/members", + "public_members": "{scheme+hostname}/communities/{id}/members/public", + "invitations": "{scheme+hostname}/communities/{id}/invitations", + "requests": "{scheme+hostname}/communities/{id}/requests", + "featured": "{scheme+hostname}/communities/{id}/featured" }, "metadata": { "title": "My Updated Community", @@ -342,15 +342,15 @@ Content-Type: application/json "id": "399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3", "revision_id": 2, "links": { - "self": "{scheme+hostname}/api/communities/{community_id}", - "self_html": "{scheme+hostname}/communities/{community_slug}", - "settings_html": "{scheme+hostname}/communities/{community_slug}/settings", - "logo": "{scheme+hostname}/communities/{community_id}/logo", - "rename": "{scheme+hostname}/communities/{community_id}", - "members": "{scheme+hostname}/communities/{community_id}/members", - "public_members": "{scheme+hostname}/communities/{community_id}/members/public", - "invitations": "{scheme+hostname}/communities/{community_id}/invitations", - "requests": "{scheme+hostname}/communities/{community_id}/requests" + "self": "{scheme+hostname}/api/communities/{id}", + "self_html": "{scheme+hostname}/communities/{id}", + "settings_html": "{scheme+hostname}/communities/{id}/settings", + "logo": "{scheme+hostname}/communities/{id}/logo", + "rename": "{scheme+hostname}/communities/{id}", + "members": "{scheme+hostname}/communities/{id}/members", + "public_members": "{scheme+hostname}/communities/{id}/members/public", + "invitations": "{scheme+hostname}/communities/{id}/invitations", + "requests": "{scheme+hostname}/communities/{id}/requests" }, "metadata": { "title": "My Updated Community", @@ -426,19 +426,19 @@ Content-Type: application/json ### Rename a Community -`POST /api/communities//rename` +`POST /api/communities/{id}/rename` **Parameters** -| Name | Type | Location | Description | -|----------|--------|----------|----------------------------------------------------------------------------| -| `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | - | `com_id` | string | path | UUID of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` | +| Name | Type | Location | Description | +|----------|--------|----------|-----------------------------------------------------------------------------------------------------| +| `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | +| `id` | string | path | UUID or slug of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` or `my-super-community` | **Request** ```http -POST /api/communities//rename HTTP/1.1 +POST /api/communities/{id}/rename HTTP/1.1 Content-Type: application/json { @@ -485,15 +485,15 @@ Content-Type: application/json "id": "399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3", "revision_id": 2, "links": { - "self": "{scheme+hostname}/api/communities/{community_id}", - "self_html": "{scheme+hostname}/communities/{community_slug}", - "settings_html": "{scheme+hostname}/communities/{community_slug}/settings", - "logo": "{scheme+hostname}/communities/{community_id}/logo", - "rename": "{scheme+hostname}/communities/{community_id}", - "members": "{scheme+hostname}/communities/{community_id}/members", - "public_members": "{scheme+hostname}/communities/{community_id}/members/public", - "invitations": "{scheme+hostname}/communities/{community_id}/invitations", - "requests": "{scheme+hostname}/communities/{community_id}/requests" + "self": "{scheme+hostname}/api/communities/{id}", + "self_html": "{scheme+hostname}/communities/{id}", + "settings_html": "{scheme+hostname}/communities/{id}/settings", + "logo": "{scheme+hostname}/communities/{id}/logo", + "rename": "{scheme+hostname}/communities/{id}", + "members": "{scheme+hostname}/communities/{id}/members", + "public_members": "{scheme+hostname}/communities/{id}/members/public", + "invitations": "{scheme+hostname}/communities/{id}/invitations", + "requests": "{scheme+hostname}/communities/{id}/requests" }, "metadata": { "title": "My Community", @@ -511,20 +511,20 @@ Content-Type: application/json ### Update Community Logo -`PUT api/communities//logo` +`PUT /api/communities/{id}/logo` **Parameters** -| Name | Type | Location | Description | -|----------------|--------|----------|----------------------------------------------------------------------------| -| `com_id` | string | path | UUID of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` | -| `content-type` | string | header | Should always be `application/octet-stream`. | -| `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | +| Name | Type | Location | Description | +|----------------|--------|----------|-----------------------------------------------------------------------------------------------------| +| `id` | string | path | UUID or slug of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` or `my-super-community` | +| `content-type` | string | header | Should always be `application/octet-stream`. | +| `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | **Request** ```http -PUT api/communities//logo HTTP/1.1 +PUT /api/communities/{id}/logo HTTP/1.1 Content-Type: application/octet-stream <...file binary data...> @@ -542,7 +542,7 @@ Content-Type: application/json "created": "2021-04-26 10:52:23.945755", "file_id": "d2a7adb5", "key": "logo", - "links": {"self": "{scheme+hostname}/api/communities//logo"}, + "links": {"self": "{scheme+hostname}/api/communities/{id}/logo"}, "metadata": None, "mimetype": "application/octet-stream", "size": file_size, @@ -554,19 +554,19 @@ Content-Type: application/json ``` ### Get Community Logo -{scheme+hostname} -`GET api/communities//logo` + +`GET /api/communities/{id}/logo` **Parameters** -| Name | Type | Location | Description | -|----------|--------|----------|--------------------------------------------------------------------| -| `com_id` | string | path | UUID of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` | +| Name | Type | Location | Description | +|------|--------|----------|-----------------------------------------------------------------------------------------------------| +| `id` | string | path | UUID or slug of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` or `my-super-community` | **Request** ```http -GET api/communities//logo HTTP/1.1 +GET /api/communities/{id}/logo HTTP/1.1 ``` @@ -583,18 +583,18 @@ Content-Type: application/json ### Delete Community Logo -`DELETE api/communities//logo` +`DELETE /api/communities/{id}/logo` **Parameters** -| Name | Type | Location | Description | -|----------|--------|----------|--------------------------------------------------------------------| -| `com_id` | string | path | UUID of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` | +| Name | Type | Location | Description | +|------|--------|----------|-----------------------------------------------------------------------------------------------------| +| `id` | string | path | UUID or slug of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` or `my-super-community` | **Request** ```http -DELETE api/communities//logo HTTP/1.1 +DELETE /api/communities/{id}/logo HTTP/1.1 ``` @@ -604,6 +604,69 @@ DELETE api/communities//logo HTTP/1.1 HTTP/1.1 204 No Content ``` +### Get Community Records + +`GET /api/communities/{id}/records` + +**Parameters** + +| Name | Type | Location | Description | +|------|--------|----------|-----------------------------------------------------------------------------------------------------| +| `id` | string | path | UUID or slug of the community e.g. `399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3` or `my-super-community` | + +**Request** + +```http +GET /api/communities/{id}/records HTTP/1.1 + +``` + +**Response** + +```http +HTTP/1.1 200 OK +Content-Type: application/json + +{ + "hits": { + "hits": [ + {......} + ], + "total": 1 + }, + "aggregations": { + "access_status": { + "buckets": [ + { + "key": "metadata-only", + "doc_count": 1, + "label": "Metadata-only", + "is_selected": false + } + ], + "label": "Access status" + }, + "resource_type": { + "buckets": [ + { + "key": "dataset", + "doc_count": 1, + "label": "Dataset", + "is_selected": false, + "inner": { + "buckets": [] + } + } + ], + "label": "Resource types" + } + }, + "sortBy": "newest", + "links": { + "self": "https://127.0.0.1:5000/api/communities/399a3cdc-d2ba-4f63-8b3a-9c2c977a5dd3/records?page=1&size=25&sort=newest" + } +} +``` ### Error Responses of Community @@ -771,7 +834,7 @@ Content-Type: application/json ``` ### Create a Featured Community Entry -`POST /api/communities//featured` +`POST /api/communities/{id}/featured` **Parameters** @@ -779,13 +842,13 @@ Content-Type: application/json |----------------|--------|----------|-----------------------------------------------------------------------------------------------| | `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | | `community_id` | string | path | ID of the community. | -| `start_date` | string | body | Required, ISO 8601 DateTime format in UTC (YYYY-MM-DDTHH:MM:SS.ssssssZ). Community will be featured from this point in time onwards. | +| `start_date` | string | body | Required, ISO 8601 DateTime format in UTC (YYYY-MM-DDTHH:MM:SS.ssssssZ). The community will be featured from this point in time onwards. | **Request** ```http -POST /api/communities//featured HTTP/1.1 +POST /api/communities/{id}/featured HTTP/1.1 Content-Type: application/json { @@ -807,20 +870,20 @@ Content-Type: application/json ### Get Featured Community Entries -`GET /api/communities//featured` +`GET /api/communities/{id}/featured` **Parameters** -| Name | Type | Location | Description | -|----------------|--------|----------|----------------------------------------------------------------------------| -| `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | -| `community_id` | string | path | ID of the community. | +| Name | Type | Location | Description | +|----------|--------|----------|----------------------------------------------------------------------------| +| `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | +| `id` | string | path | ID of the community. | **Request** ```http -GET /api/communities//featured HTTP/1.1 +GET /api/communities/{id}/featured HTTP/1.1 ``` **Response** @@ -849,14 +912,14 @@ Content-Type: application/json ### Update a Featured Community Entry -`PUT /api/communities//featured/` +`PUT /api/communities/{id}/featured/` **Parameters** | Name | Type | Location | Description | |---------------------|--------|----------|-----------------------------------------------------------------------------------------------| | `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | -| `community_id` | string | path | ID of the community. | +| `id` | string | path | ID of the community. | | `featured_entry_id` | string | path | ID of the featured entry. | | `start_date` | string | body | Required, datetime in iso format. Community will be featured from this point in time onwards. | @@ -864,7 +927,7 @@ Content-Type: application/json **Request** ```http -PUT /api/communities//featured/ HTTP/1.1 +PUT /api/communities/{id}/featured/ HTTP/1.1 Content-Type: application/json { @@ -886,21 +949,21 @@ Content-Type: application/json ### Delete a Featured Community Entry -`DELETE /api/communities//featured/` +`DELETE /api/communities/{id}/featured/` **Parameters** | Name | Type | Location | Description | |---------------------|--------|----------|----------------------------------------------------------------------------| | `accept` | string | header | - `application/json` (default)
- `application/vnd.inveniordm.v1+json` | -| `community_id` | string | path | ID of the community. | +| `id` | string | path | ID of the community. | | `featured_entry_id` | string | path | ID of the featured entry. | **Request** ```http -DELETE /api/communities//featured/ HTTP/1.1 +DELETE /api/communities/{id}/featured/ HTTP/1.1 ``` **Response** diff --git a/docs/reference/rest_api_members.md b/docs/reference/rest_api_members.md index b9e8df26..ea50edb4 100644 --- a/docs/reference/rest_api_members.md +++ b/docs/reference/rest_api_members.md @@ -20,29 +20,28 @@ The following general restrictions apply to the member API: - Members can change their own visibility to both public/hidden. - Owners/managers can change visibility of members to hidden. -### Search members +### Get Community Members `GET /api/communities/{id}/members` **Parameters** -| Name | Type | Location | Description | -|--------------|---------|----------|--------------------------------------------------------------------------| -| `id` | string | path | Community UUID identifier | -| `accept` | string | header | - `application/json` | -| `q` | string | query | Search query used to filter results. | -| `sort` | string | query | Sort search results. Customizable. Built-in options are `"bestmatch"`, `"name"`, `"newest"`, `"oldest"` (default: `"bestmatch"` or `"name"`). | -| `size` | integer | query | Specify number of items in the results page (default: 10). | -| `page` | integer | query | Specify the page of results. | -| `role` | string | query | Filter by role (one of ``reader``, ``curator``, ``manager``, ``owner``). | -| `visibility` | boolean | query | Filter by visibility (one of ``true``, ``false``) | - -Sort options for community members can be configured using the `COMMUNITIES_MEMBERS_SORT_OPTIONS` config variable as described in the [search customization](../customize/search.md) section. Note that `"bestmatch"` is only available as a sort option on requests that provide a query string as a `q` parameter, in which case it is the default sort type. If no query string is provided in the request, the default sort type is `"name"`. In this case a `"bestmatch"` value is ignored and the default `"name"` sort is used. - +| Name | Type | Location | Description | +|--------------|---------|----------|-------------------------------------------------------------------------------------------------------| +| `id` | string | path | Community UUID identifier or slug e.g. `bd647379-23ea-477a-970f-201512ae5624` or `my-super-community` | +| `accept` | string | header | - `application/json` | +| `q` | string | query | Search query used to filter results. | +| `sort` | string | query | Sort search results. | +| `size` | integer | query | Specify number of items in the results page (default: 10). | +| `page` | integer | query | Specify the page of results. | +| `role` | string | query | Filter by role (one of ``reader``, ``curator``, ``manager``, ``owner``). | +| `visibility` | boolean | query | Filter by visibility (one of ``true``, ``false``) | + +Customizable. Built-in options are `"bestmatch"`, `"name"`, `"newest"`, `"oldest"` (default: `"bestmatch"` or `"name"`). | **Request** ```http -GET /api/communities/bd647379-23ea-477a-970f-201512ae5624/members HTTP/1.1 +GET /api/communities/{id}/members HTTP/1.1 Accept: application/json ``` @@ -151,13 +150,13 @@ Content-Type: application/json **Parameters** -| Name | Type | Location | Description | -| -------- | ------- | -------- | ---------------------------------------------------------- | -| `id` | string | path | Community UUID identifier | -| `accept` | string | header | - `application/json` | -| `q` | string | query | Search query used to filter results. | -| `size` | integer | query | Specify number of items in the results page (default: 10). | -| `page` | integer | query | Specify the page of results. | +| Name | Type | Location | Description | +|----------|---------|----------|-------------------------------------------------------------------------------------------------------| +| `id` | string | path | Community UUID identifier or slug e.g. `bd647379-23ea-477a-970f-201512ae5624` or `my-super-community` | +| `accept` | string | header | - `application/json` | +| `q` | string | query | Search query used to filter results. | +| `size` | integer | query | Specify number of items in the results page (default: 10). | +| `page` | integer | query | Specify the page of results. | Note that no sort options are available when searching public members. The results are sorted by `"name"` in ascending order. @@ -204,17 +203,17 @@ Content-Type: application/json **Parameters** -| Name | Type | Location | Description | -| --------- | ------- | -------- | ----------------------------------------------------------------------------------------------- | -| `id` | string | path | Community UUID identifier | -| `accept` | string | header | - `application/json` | -| `q` | string | query | Search query used to filter results. | +| Name | Type | Location | Description | +|-----------|---------|----------|-------------------------------------------------------------------------------------------------------| +| `id` | string | path | Community UUID identifier or slug e.g. `bd647379-23ea-477a-970f-201512ae5624` or `my-super-community` | +| `accept` | string | header | - `application/json` | +| `q` | string | query | Search query used to filter results. | | `sort` | string | query | Sort search results. Customizable. Built-in options are `"bestmatch"`, `"name"`, `"newest"`, `"oldest"` (default: `"bestmatch"` or `"name"`). | -| `size` | integer | query | Specify number of items in the results page (default: 10). | -| `page` | integer | query | Specify the page of results. | -| `role` | string | query | Filter by role (one of ``reader``, ``curator``, ``manager``, ``owner``). | -| `status` | string | query | Filter by status (one of ``submitted``, ``accepted``, ``declined``, ``expired``, ``cancelled``) | -| `is_open` | boolean | query | Filter by open/closed (one of ``true``, ``false``) | +| `size` | integer | query | Specify number of items in the results page (default: 10). | +| `page` | integer | query | Specify the page of results. | +| `role` | string | query | Filter by role (one of ``reader``, ``curator``, ``manager``, ``owner``). | +| `status` | string | query | Filter by status (one of ``submitted``, ``accepted``, ``declined``, ``expired``, ``cancelled``) | +| `is_open` | boolean | query | Filter by open/closed (one of ``true``, ``false``) | Sort options for community members can be configured using the `COMMUNITIES_INVITATIONS_SORT_OPTIONS` config variable as described in the [search customization](../customize/search.md) section. Note that `"bestmatch"` is only available as a sort option on requests that provide a query string as a `q` parameter, in which case it is the default sort type. If no query string is provided in the request, the default sort type is `"name"`. In this case a `"bestmatch"` value is ignored and the default `"name"` sort is used. @@ -343,13 +342,13 @@ system identity. **Parameters** -| Name | Type | Location | Description | -| -------------- | ------- | -------- | --------------------------------------------------------------------------- | -| `id` | string | path | Community UUID identifier | -| `content-type` | string | header | - `application/json` | -| `members` | object | body | List of group members to add. | -| `role` | string | body | Set role of group (one of ``reader``, ``curator``, ``manager``, ``owner``). | -| `visible` | boolean | body | Set visibility (one of ``true``, ``false``) | +| Name | Type | Location | Description | +|----------------|---------|----------|-------------------------------------------------------------------------------------------------------| +| `id` | string | path | Community UUID identifier or slug e.g. `bd647379-23ea-477a-970f-201512ae5624` or `my-super-community` | +| `content-type` | string | header | - `application/json` | +| `members` | object | body | List of group members to add. | +| `role` | string | body | Set role of group (one of ``reader``, ``curator``, ``manager``, ``owner``). | +| `visible` | boolean | body | Set visibility (one of ``true``, ``false``) | **Request** @@ -382,14 +381,14 @@ Note, only users can be invited. Groups must be added directly. **Parameters** -| Name | Type | Location | Description | -| -------------- | ------- | -------- | --------------------------------------------------------------------------- | -| `id` | string | path | Community UUID identifier | -| `content-type` | string | header | - `application/json` | -| `members` | object | body | List of group members to add. | -| `role` | string | body | Set role of group (one of ``reader``, ``curator``, ``manager``, ``owner``). | -| `visible` | boolean | body | Set visibility (one of ``true``, ``false``) | -| `message` | string | body | A message to the user being invited. | +| Name | Type | Location | Description | +|----------------|---------|----------|-------------------------------------------------------------------------------------------------------| +| `id` | string | path | Community UUID identifier or slug e.g. `bd647379-23ea-477a-970f-201512ae5624` or `my-super-community` | +| `content-type` | string | header | - `application/json` | +| `members` | object | body | List of group members to add. | +| `role` | string | body | Set role of group (one of ``reader``, ``curator``, ``manager``, ``owner``). | +| `visible` | boolean | body | Set visibility (one of ``true``, ``false``) | +| `message` | string | body | A message to the user being invited. | **Request** @@ -421,11 +420,11 @@ HTTP/1.1 204 NO CONTENT **Parameters** -| Name | Type | Location | Description | -| -------------- | ------ | -------- | -------------------------------- | -| `id` | string | path | Community UUID identifier | -| `content-type` | string | header | - `application/json` | -| `members` | object | body | List of group members to delete. | +| Name | Type | Location | Description | +|----------------|--------|----------|-------------------------------------------------------------------------------------------------------| +| `id` | string | path | Community UUID identifier or slug e.g. `bd647379-23ea-477a-970f-201512ae5624` or `my-super-community` | +| `content-type` | string | header | - `application/json` | +| `members` | object | body | List of group members to delete. | **Request** @@ -455,13 +454,13 @@ HTTP/1.1 204 NO CONTENT **Parameters** -| Name | Type | Location | Description | -| -------------- | ------- | -------- | --------------------------------------------------------------------------- | -| `id` | string | path | Community UUID identifier | -| `content-type` | string | header | - `application/json` | -| `members` | object | body | List of group members to add. | -| `role` | string | body | Set role of group (one of ``reader``, ``curator``, ``manager``, ``owner``). | -| `visible` | boolean | body | Set visibility (one of ``true``, ``false``) | +| Name | Type | Location | Description | +|----------------|---------|----------|-------------------------------------------------------------------------------------------------------| +| `id` | string | path | Community UUID identifier or slug e.g. `bd647379-23ea-477a-970f-201512ae5624` or `my-super-community` | +| `content-type` | string | header | - `application/json` | +| `members` | object | body | List of group members to add. | +| `role` | string | body | Set role of group (one of ``reader``, ``curator``, ``manager``, ``owner``). | +| `visible` | boolean | body | Set visibility (one of ``true``, ``false``) | **Request** @@ -498,13 +497,13 @@ HTTP/1.1 204 NO CONTENT **Parameters** -| Name | Type | Location | Description | -| -------------- | ------- | -------- | --------------------------------------------------------------------------- | -| `id` | string | path | Community UUID identifier | -| `content-type` | string | header | - `application/json` | -| `members` | object | body | List of group members to add. | -| `role` | string | body | Set role of group (one of ``reader``, ``curator``, ``manager``, ``owner``). | -| `visible` | boolean | body | Set visibility (one of ``true``, ``false``) | +| Name | Type | Location | Description | +|----------------|---------|----------|-------------------------------------------------------------------------------------------------------| +| `id` | string | path | Community UUID identifier or slug e.g. `bd647379-23ea-477a-970f-201512ae5624` or `my-super-community` | +| `content-type` | string | header | - `application/json` | +| `members` | object | body | List of group members to add. | +| `role` | string | body | Set role of group (one of ``reader``, ``curator``, ``manager``, ``owner``). | +| `visible` | boolean | body | Set visibility (one of ``true``, ``false``) | **Request**