- Get all broadcast messages
- Get a specific broadcast message
- Create a broadcast message
- Update a broadcast message
- Delete a broadcast message
Broadcast Messages API
‘target_access_levels’
Broadcast messages API operates on broadcast messages.
As of GitLab 12.8, GET requests do not require authentication. All other broadcast message API endpoints are accessible only to administrators. Non-GET requests by:
List all broadcast messages.
Example request:
Example response:
Get a specific broadcast message.
Parameters:
401 Unauthorized
.
403 Forbidden
.
Get all broadcast messages
GET /broadcast_messages
curl "https://gitlab.example.com/api/v4/broadcast_messages"
[
{
"message":"Example broadcast message",
"starts_at":"2016-08-24T23:21:16.078Z",
"ends_at":"2016-08-26T23:21:16.080Z",
"color":"#E75E40",
"font":"#FFFFFF",
"id":1,
"active": false,
"target_access_levels": [10,30],
"target_path": "*/welcome",
"broadcast_type": "banner",
"dismissable": false
}
]
Get a specific broadcast message
GET /broadcast_messages/:id
Attribute | Type | Required | Description |
---|---|---|---|
id
| integer | yes | ID of broadcast message to retrieve. |
Example request:
curl "https://gitlab.example.com/api/v4/broadcast_messages/1"
Example response:
{
"message":"Deploy in progress",
"starts_at":"2016-08-24T23:21:16.078Z",
"ends_at":"2016-08-26T23:21:16.080Z",
"color":"#cecece",
"font":"#FFFFFF",
"id":1,
"active":false,
"target_access_levels": [10,30],
"target_path": "*/welcome",
"broadcast_type": "banner",
"dismissable": false
}
Create a broadcast message
Create a new broadcast message.
POST /broadcast_messages
Parameters:
Attribute | Type | Required | Description |
---|---|---|---|
message
| string | yes | Message to display. |
starts_at
| datetime | no | Starting time (defaults to current time). Expected in ISO 8601 format (2019-03-15T08:00:00Z )
|
ends_at
| datetime | no | Ending time (defaults to one hour from current time). Expected in ISO 8601 format (2019-03-15T08:00:00Z )
|
color
| string | no | Background color hex code. |
font
| string | no | Foreground color hex code. |
target_access_levels
| array of integers | no | Target access levels (roles) of the broadcast message. |
target_path
| string | no | Target path of the broadcast message. |
broadcast_type
| string | no | Appearance type (defaults to banner) |
dismissable
| boolean | no | Can the user dismiss the message? |
The target_access_levels
are defined in the Gitlab::Access
module. The
following levels are valid:
- Guest (
10
) - Reporter (
20
) - Developer (
30
) - Maintainer (
40
) - Owner (
50
)
Example request:
curl --data "message=Deploy in progress&color=#cecece&target_access_levels[]=10&target_access_levels[]=30" \
--header "PRIVATE-TOKEN: <your_access_token>" \
"https://gitlab.example.com/api/v4/broadcast_messages"
Example response:
{
"message":"Deploy in progress",
"starts_at":"2016-08-26T00:41:35.060Z",
"ends_at":"2016-08-26T01:41:35.060Z",
"color":"#cecece",
"font":"#FFFFFF",
"id":1,
"active": true,
"target_access_levels": [10,30],
"target_path": "*/welcome",
"broadcast_type": "notification",
"dismissable": false
}
Update a broadcast message
Update an existing broadcast message.
PUT /broadcast_messages/:id
Parameters:
Attribute | Type | Required | Description |
---|---|---|---|
id
| integer | yes | ID of broadcast message to update. |
message
| string | no | Message to display. |
starts_at
| datetime | no | Starting time. Expected in ISO 8601 format (2019-03-15T08:00:00Z )
|
ends_at
| datetime | no | Ending time. Expected in ISO 8601 format (2019-03-15T08:00:00Z )
|
color
| string | no | Background color hex code. |
font
| string | no | Foreground color hex code. |
target_access_levels
| array of integers | no | Target access levels (roles) of the broadcast message. |
target_path
| string | no | Target path of the broadcast message. |
broadcast_type
| string | no | Appearance type (defaults to banner) |
dismissable
| boolean | no | Can the user dismiss the message? |
The target_access_levels
are defined in the Gitlab::Access
module. The
following levels are valid:
- Guest (
10
) - Reporter (
20
) - Developer (
30
) - Maintainer (
40
) - Owner (
50
)
Example request:
curl --request PUT --data "message=Update message&color=#000" \
--header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/broadcast_messages/1"
Example response:
{
"message":"Update message",
"starts_at":"2016-08-26T00:41:35.060Z",
"ends_at":"2016-08-26T01:41:35.060Z",
"color":"#000",
"font":"#FFFFFF",
"id":1,
"active": true,
"target_access_levels": [10,30],
"target_path": "*/welcome",
"broadcast_type": "notification",
"dismissable": false
}
Delete a broadcast message
Delete a broadcast message.
DELETE /broadcast_messages/:id
Parameters:
Attribute | Type | Required | Description |
---|---|---|---|
id
| integer | yes | ID of broadcast message to delete. |
Example request:
curl --request DELETE --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/broadcast_messages/1"