Attributes¶
- Feed.UserFeedResource¶
The feed service returns generically formed blocks that wrap around particular kinds of resources. For example, a UserFeedResourceNewsItem variant of the generic container contains a Resource composite that’s actually a
NewsItem
structure.{ "Type": <string>, "MessageMetaData": { "Identifier": <string>, "Title": <string>, "Summary": { <composite:RichText> }, "Date": <string:UTCDateTime>, "ApiViewUrl": <string:URL>, "WebViewUrl": <string:URL> }, "Resource": { <composite> } // Generic resource composite wrapper }
- News.NewsFeed¶
If you use an action that retrieves a news feed from the service, it sends the data back to you in a block like this:
{ "OrgUnitId": <numeric:D2LID>, "Resource": { <composite:News.NewsItem> } }
- News.NewsItem¶
If you use an action that retrieves a news item from the service, it sends the data back to you in a block like this:
{ "Id": <number:D2LID>, "IsHidden": <boolean>, "Attachments": [ // Array of File blocks { "FileId": <number:D2LID>, "FileName": <string>, "FileSize": <number> }, { <composite:File> }, ... ], "Title": <string>, "Body": { <composite:RichText> }, "CreatedBy": <number:D2LID>|null, "CreatedDate": <string:UTCDateTime>|null, "LastModifiedBy": <number:D2LID>|null, "LastModifiedDate": <string:UTCDateTime>|null, "StartDate": <string:UTCDateTime>|null, "EndDate": <string:UTCDateTime>|null, "IsGlobal": <boolean>, "IsPublished": <boolean>, "ShowOnlyInCourseOfferings": <boolean>, "IsAuthorInfoShown": <boolean>, "IsPinned": <boolean>, "PinnedDate": <string:UTCDateTime>|null, // Added with LE API v1.81 "IsStartDateShown": <boolean>, // Added with LE API v1.75 "SortOrder": <number> // Added with LE API v1.75 }
- News.NewsItemData¶
If you use an action where you must provide news item data, then the service expects you to send it in a block like this:
{ "Title": <string>, "Body": { <composite:RichText> }, "StartDate": <string:UTCDateTime>, "EndDate": <string:UTCDateTime>|null, "IsGlobal": <boolean>, "IsPublished": <boolean>, "ShowOnlyInCourseOfferings": <boolean>, "IsAuthorInfoShown": <boolean>, "IsPinned": <boolean>, "IsStartDateShown": <boolean>, // Added with LE API v1.75 "SortOrder": <number>|null // Added with LE API v1.75 }
Note
When you provide a RichText composite Body in a NewsItemData structure, you should not provide an empty-string “Html” property field if your intention is to provide a text-only news body. Rather, you should pass in an explicit NULL for the field.
Actions¶
- DELETE /d2l/api/le/(version)/(orgUnitId)/news/(newsItemId)¶
Delete a particular news item from an org unit.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
newsItemId (D2LID) – News Item ID.
- Oauth2 Scopes:
news:newsitems:manage
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to edit news for this org unit.
404 Not Found – News item not found.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
- DELETE /d2l/api/le/(version)/(orgUnitId)/news/(newsItemId)/attachments/(fileId)¶
Delete an attachment from an org unit’s news item.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
newsItemId (D2LID) – News Item ID.
fileId (D2LID) – File attachment ID.
- Oauth2 Scopes:
news:newsitems:manage
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to see news for this org unit.
404 Not Found – News item not found, or file attachment not found.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
- GET /d2l/api/lp/(version)/feed/¶
Fetch the feed for the current user context.
- Parameters:
version (D2LVERSION) – API version.
- Query Parameters:
since (UTCDateTime) – Optional. Earliest publication time to retrieve.
until (UTCDateTime) – Optional. Latest publication time to retrieve.
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to see feed.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.46+ – Route first appears in LMS v20.24.3.
1.43-1.45 – Deprecated as of LMS v20.25.1.
1.42- – Obsolete as of LMS v20.25.1.
This call retrieves and aggregates a list of user messages gathered from various sources in the back-end service. The original sources for those messages determine when a user event message gets made available for aggregation, and when the events expire from the pool available to this API call.
Note that, unlike many Brightspace APIs, there is currently no direct functional equivalent for this API call in the web UI.
Input. This route accepts two query parameters (since and until) to specify a time window for retrieved results:
If you do not provide a since value, this call returns only a list of “recent” feed items: those with a publication time sometime within the twenty-four hours preceding the time when the back-end service handles your call.
If you provide a since value, and do not provide an until value, this call returns all the feed items from your provided since time up until the time when the back-end service handles your call.
If you provide a since value, and do provide an until value, this call returns all the feed items between your two provided time parameters. Note that, if your since parameter is more recent than your until parameter, this action returns success and an empty feed list.
Return. This action returns a JSON array of
UserFeedResource
data blocks. Note that each element in this list will be named appropriately for the kind of resource it envelopes.
- GET /d2l/api/le/(version)/news/user/(userId)/¶
Retrieve a list of news items for specific user.
- Parameters:
version (D2LVERSION) – API version.
userId (D2LID) – User ID.
- Query Parameters:
since (UTCDateTime) – Optional. Earliest publication time to retrieve.
until (UTCDateTime) – Optional. Latest publication time to retrieve.
- Oauth2 Scopes:
news:newsitems:read
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to add news, classlist, roles for this org unit, no permission to see news for this org unit, or no permission to see User Information Privacy.
404 Not Found – No such user enrolled.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
Return. This action returns a
paged result set
containing the resultingNewsFeed
blocks for the segment following your bookmark parameter (or the first segment if that parameter is empty or missing).Note
This action is subject to user privacy controls. The calling user context must belong to a role granted permission to see all user fields via User Information Privacy.
- GET /d2l/api/le/(version)/(orgUnitId)/news/¶
Retrieve a list of news items for an org unit.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
- Query Parameters:
since (UTCDateTime) – Optional. Earliest publication time to retrieve.
- Oauth2 Scopes:
news:newsitems:read
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to see news for this org unit.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
Return. This action returns a JSON array of
NewsItem
data blocks containing news items’ properties.
- GET /d2l/api/le/(version)/(orgUnitId)/news/deleted/¶
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
- Query Parameters:
global (boolean) – Optional. Show only global news items if present and true; otherwise, show no global items.
- Oauth2 Scopes:
news:newsitems:read
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to see news items of requested type.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
unstable – Route first appears in LMS v10.5.2.
Return. This action returns a JSON array of
NewsItem
data blocks containing the properties of deleted news items. Note that this action will also retrieve deleted news item that have the IsHidden property set to true.
- GET /d2l/api/le/(version)/(orgUnitId)/news/user/(userId)/¶
Retrieve a list of news items from an org unit for specific user.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
userId (D2LID) – User ID.
- Oauth2 Scopes:
news:newsitems:read
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to add news, classlist, roles for this org unit, no permission to see news for this org unit, or no permission to see User Information Privacy.
404 Not Found – No such user enrolled in org unit.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
Return. This action returns a JSON array of
NewsItem
data blocks containing news items’ properties.Note
This action is subject to user privacy controls. The calling user context must belong to a role granted permission to see all user fields via User Information Privacy.
- GET /d2l/api/le/(version)/(orgUnitId)/news/(newsItemId)¶
Retrieve a particular news item for an org unit.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
newsItemId (D2LID) – News Item ID.
- Oauth2 Scopes:
news:newsitems:read
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to see news for this org unit.
404 Not Found – News item not found.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
Return. This action returns a
NewsItem
JSON data block containing the news item’s properties.
- GET /d2l/api/le/(version)/(orgUnitId)/news/(newsItemId)/access/¶
Retrieve a list of users with access to a specified news item.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
newsItemId (D2LID) – News Item ID.
- Query Parameters:
- Oauth2 Scopes:
news:access:read
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to see and manage news for this org unit, see classlist, view user enrollment.
404 Not Found – News item ID not found in provided org unit, or org unit not found.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
Return. This action returns a
paged result set
containing the resultingUserAccess
blocks for the segment following your bookmark parameter (or the first segment if that parameter is empty or missing).
- GET /d2l/api/le/(version)/(orgUnitId)/news/(newsItemId)/attachments/(fileId)¶
Retrieve an attachment for an org unit’s news item.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
newsItemId (D2LID) – News Item ID.
fileId (D2LID) – File attachment ID.
- Oauth2 Scopes:
news:newsitems:read
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to see news for this org unit.
404 Not Found – News item not found, or file attachment not found.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
Return. This action returns a file stream containing the attachment file data.
- POST /d2l/api/le/(version)/(orgUnitId)/news/¶
Create a news item for an org unit.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
- JSON Parameters:
NewsItemData (
News.NewsItemData
) – Data for new news item (see input description).
- Oauth2 Scopes:
news:newsitems:manage
- Status Codes:
200 OK – Action succeeded.
400 Bad Request – Invalid News Item data provided.
403 Forbidden – No permission to create news items for this org unit.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
Input. Provide a multipart/mixed POST body: the first part must be the news item data JSON; other parts may include file attachments to go along with the news item.
If you want to create a new item as a draft, make sure to set the news item’s IsPublished property to false. In order to publish such a created news item, you must then use the
Publish
action.The calling user must have permission to manage author information to use this action.
Return. Returns a
NewsItem
JSON data block for the newly created news item.
- POST /d2l/api/le/(version)/(orgUnitId)/news/deleted/(newsItemId)/restore¶
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
newsItemId (D2LID) – News Item ID.
- Oauth2 Scopes:
news:newsitems:manage
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to see news item.
404 Not Found – News item not found.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
unstable – Route first appears in LMS v10.5.2.
Return. Returns a
NewsItem
JSON data block for the newly restored news item.
- POST /d2l/api/le/(version)/(orgUnitId)/news/(newsItemId)/attachments/¶
Add an attachment to a news item for an org unit.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
newsItemId (D2LID) – News Item ID.
- Oauth2 Scopes:
news:newsitems:manage
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to edit news for this org unit.
404 Not Found – News item not found.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
Input. Use a multipart/form-data POST body to provide the attachment data to add to the news item, with the part’s Content-Disposition header’s name field set to “file”.
- POST /d2l/api/le/(version)/(orgUnitId)/news/(newsItemId)/dismiss¶
Dismiss (hide) a news item for an org unit.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
newsItemId (D2LID) – News Item ID.
- Oauth2 Scopes:
news:newsitems:manage
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to see news items for this org unit.
404 Not Found – News item not found.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
- POST /d2l/api/le/(version)/(orgUnitId)/news/(newsItemId)/publish¶
Publish a draft news item for an org unit.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
newsItemId (D2LID) – News Item ID.
- Oauth2 Scopes:
news:newsitems:manage
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to edit news items for this org unit.
404 Not Found – News item not found.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
- POST /d2l/api/le/(version)/(orgUnitId)/news/(newsItemId)/restore¶
Restore (unhide) a news item for an org unit.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
newsItemId (D2LID) – News Item ID.
- Oauth2 Scopes:
news:newsitems:manage
- Status Codes:
200 OK – Action succeeded.
403 Forbidden – No permission to see news items for this org unit.
404 Not Found – News item not found.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
- PUT /d2l/api/le/(version)/(orgUnitId)/news/(newsItemId)¶
Update a news item for an org unit.
- Parameters:
version (D2LVERSION) – API version.
orgUnitId (D2LID) – Org unit ID.
newsItemId (D2LID) – News Item ID.
- JSON Parameters:
NewsItemData (
News.NewsItemData
) – Updated Data for news item.
- Oauth2 Scopes:
news:newsitems:manage
- Status Codes:
200 OK – Action succeeded.
400 Bad Request – Invalid news item data provided, or attempt to provide a draft news update to a published news item.
403 Forbidden – No permission to update news items for this org unit.
404 Not Found – News item not found.
429 Too Many Requests – API call-rate limit exceeded.
- API Versions:
1.75+ – Route first appears in LMS v20.24.5.
1.67-74 – Deprecated as of LMS v20.25.1.
1.66- – Obsolete as of LMS v20.25.1.
Input. The calling user must have permission to manage author information to use this action.
Note
If the org unit’s news item has already been published, then you may not provide an update with the IsPublished property set to false (i.e. once an item is no longer a draft item, you can’t turn it back into a draft item). However, if the org unit’s news item is in draft state, you can publish it with this action by setting the IsPublished property to true.