A CommunityThread represents a conversation posted to the Discussion Board. Discussion boards are a community feature that allows customers to communicate on the Members Portal — they can start, follow, like, and reply to conversations, mention other customers, and receive notifications about new messages.
Conversations can be assigned to a group (CommunityGroupId) to control who can see and contribute. Conversations not linked to any group are visible to all customers with access to the Discussion Boards page.
Use Tags to help customers find relevant conversations. Set Private to true to limit visibility to only the customers explicitly mentioned in the message. Enable InstantDelivery to push notifications to followers immediately rather than waiting for the daily digest.
Authentication
This endpoint requires OAuth2 authentication. Include a valid bearer token in the Authorization header.
The authenticated user must be a full unrestricted administrator or have the CommunityThread-List role.
Query Parameters
The page number to retrieve.
The number of records per page.
The property name to sort results by (e.g. Name, CreatedOn).
Sort direction. 1 for ascending, -1 for descending.
Filters
Filter by iD of the location this conversation belongs to.
Filter by iD of the group this conversation is assigned to; the group’s access level (Public, Restricted, or Private) determines who can see and contribute to it.
Filter by iD of the user account that posted this conversation.
Filter by iD of the customer profile that posted this conversation.
Filter by title or topic of the conversation.
Filter by body text of the opening message in this conversation.
Filter by when true, sends notifications to followers immediately after posting instead of waiting for the daily digest.
Filter by comma-separated tags to help customers find this conversation.
Filter by when true, the conversation is visible only to customers explicitly mentioned in the message.
Filter by date and time of the most recent reply in this conversation.
Filter by when true, attaches a Zoom meeting invite to this conversation.
Filter by jSON payload containing Zoom meeting details attached to this conversation.
Range Filters
Filter by date and time of the most recent reply in this conversation greater than or equal to this value. Format: YYYY-MM-DDTHH:mm.
Filter by date and time of the most recent reply in this conversation less than or equal to this value. Format: YYYY-MM-DDTHH:mm.
Filter records created on or after this date. Format: YYYY-MM-DDTHH:mm.
Filter records created on or before this date. Format: YYYY-MM-DDTHH:mm.
Filter records updated on or after this date. Format: YYYY-MM-DDTHH:mm.
Filter records updated on or before this date. Format: YYYY-MM-DDTHH:mm.
Code Examples
Simple listing
curl -X GET \
"https://spaces.nexudus.com/api/community/communitythreads?page=1&size=15&orderBy=Subject&dir=1" \
-H "Authorization: Bearer YOUR_TOKEN"
Filtering by Subject
curl -X GET \
"https://spaces.nexudus.com/api/community/communitythreads?CommunityThread_Subject=example-value&orderBy=Subject&dir=1" \
-H "Authorization: Bearer YOUR_TOKEN"
Range filters
curl -X GET \
"https://spaces.nexudus.com/api/community/communitythreads?from_CommunityThread_UpdatedOn=2025-01-01T00:00&to_CommunityThread_UpdatedOn=2025-12-31T23:59&orderBy=UpdatedOn&dir=-1" \
-H "Authorization: Bearer YOUR_TOKEN"
Response
200
The list of CommunityThread records matching the query. See the Get one CommunityThread endpoint for the full list of properties returned for each record.
Partial records — The listing endpoint returns a summary representation of each CommunityThread. The following fields are not included in the Records[] response: Message, InstantDelivery, IncludeZoomInvite.To get all fields, fetch the full record using the Get one CommunityThread endpoint.Important for updates: When updating a record via PUT, always retrieve the full record with a GET request first, apply your changes to that complete data, and then send the updated record. Do not use data from a listing response as the base for a PUT request, as missing fields may be unintentionally cleared.
Number of records per page.
The field used for sorting.
The sort direction (1 = ascending, -1 = descending).
Index of the first item on the current page.
Index of the last item on the current page.
Total number of matching records across all pages.
Whether there is a next page of results.
Whether there is a previous page of results.
{
"Records": [
{
"BusinessId": 0,
"CommunityGroupId": null,
"UserId": 0,
"CoworkerId": null,
"Subject": "",
"Message": "",
"InstantDelivery": false,
"Tags": null,
"Private": false,
"Guests": [],
"LastMessageDate": null,
"IncludeZoomInvite": false,
"ZoomEventData": null,
"Id": 87654321,
"UpdatedOn": "2025-01-15T10:30:00Z",
"CreatedOn": "2025-01-10T08:00:00Z",
"UniqueId": "a1b2c3d4-e5f6-7890-abcd-ef1234567890",
"UpdatedBy": "admin@example.com",
"IsNew": false,
"SystemId": null,
"ToStringText": "CommunityThread Example",
"LocalizationDetails": null,
"CustomFields": null
}
],
"CurrentPageSize": 15,
"CurrentPage": 1,
"CurrentOrderField": "Subject",
"CurrentSortDirection": 1,
"FirstItem": 1,
"HasNextPage": false,
"HasPreviousPage": false,
"LastItem": 1,
"PageNumber": 1,
"PageSize": 15,
"TotalItems": 1,
"TotalPages": 1
}