Commit 607bcecd authored by eugielimpin's avatar eugielimpin

Update broadcast messages docs

parent ebde9bd6
...@@ -6,6 +6,8 @@ info: To determine the technical writer assigned to the Stage/Group associated w ...@@ -6,6 +6,8 @@ info: To determine the technical writer assigned to the Stage/Group associated w
# Broadcast Messages API **(FREE SELF)** # Broadcast Messages API **(FREE SELF)**
> 'target_access_levels' [introduced](https://gitlab.com/gitlab-org/growth/team-tasks/-/issues/461) in GitLab 14.8 [with a flag](../administration/feature_flags.md) named `role_targeted_broadcast_messages`. Disabled by default.
Broadcast messages API operates on [broadcast messages](../user/admin_area/broadcast_messages.md). Broadcast messages API operates on [broadcast messages](../user/admin_area/broadcast_messages.md).
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: 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:
...@@ -39,6 +41,7 @@ Example response: ...@@ -39,6 +41,7 @@ Example response:
"font":"#FFFFFF", "font":"#FFFFFF",
"id":1, "id":1,
"active": false, "active": false,
"target_access_levels": [10,30],
"target_path": "*/welcome", "target_path": "*/welcome",
"broadcast_type": "banner", "broadcast_type": "banner",
"dismissable": false "dismissable": false
...@@ -77,6 +80,7 @@ Example response: ...@@ -77,6 +80,7 @@ Example response:
"font":"#FFFFFF", "font":"#FFFFFF",
"id":1, "id":1,
"active":false, "active":false,
"target_access_levels": [10,30],
"target_path": "*/welcome", "target_path": "*/welcome",
"broadcast_type": "banner", "broadcast_type": "banner",
"dismissable": false "dismissable": false
...@@ -93,21 +97,31 @@ POST /broadcast_messages ...@@ -93,21 +97,31 @@ POST /broadcast_messages
Parameters: Parameters:
| Attribute | Type | Required | Description | | Attribute | Type | Required | Description |
|:----------------|:---------|:---------|:------------------------------------------------------| |:-----------------------|:------------------|:---------|:------------------------------------------------------|
| `message` | string | yes | Message to display. | | `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`) | | `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`) | | `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. | | `color` | string | no | Background color hex code. |
| `font` | string | no | Foreground color hex code. | | `font` | string | no | Foreground color hex code. |
| `target_path` | string | no | Target path of the broadcast message. | | `target_access_levels` | array of integers | no | Target access levels (roles) of the broadcast message.|
| `broadcast_type`| string | no | Appearance type (defaults to banner) | | `target_path` | string | no | Target path of the broadcast message. |
| `dismissable` | boolean | no | Can the user dismiss the 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: Example request:
```shell ```shell
curl --data "message=Deploy in progress&color=#cecece" \ curl --data "message=Deploy in progress&color=#cecece&target_access_levels[]=10&target_access_levels[]=30" \
--header "PRIVATE-TOKEN: <your_access_token>" \ --header "PRIVATE-TOKEN: <your_access_token>" \
"https://gitlab.example.com/api/v4/broadcast_messages" "https://gitlab.example.com/api/v4/broadcast_messages"
``` ```
...@@ -123,6 +137,7 @@ Example response: ...@@ -123,6 +137,7 @@ Example response:
"font":"#FFFFFF", "font":"#FFFFFF",
"id":1, "id":1,
"active": true, "active": true,
"target_access_levels": [10,30],
"target_path": "*/welcome", "target_path": "*/welcome",
"broadcast_type": "notification", "broadcast_type": "notification",
"dismissable": false "dismissable": false
...@@ -139,17 +154,27 @@ PUT /broadcast_messages/:id ...@@ -139,17 +154,27 @@ PUT /broadcast_messages/:id
Parameters: Parameters:
| Attribute | Type | Required | Description | | Attribute | Type | Required | Description |
|:----------------|:---------|:---------|:--------------------------------------| |:-----------------------|:------------------|:---------|:------------------------------------------------------|
| `id` | integer | yes | ID of broadcast message to update. | | `id` | integer | yes | ID of broadcast message to update. |
| `message` | string | no | Message to display. | | `message` | string | no | Message to display. |
| `starts_at` | datetime | no | Starting time. Expected in ISO 8601 format (`2019-03-15T08:00:00Z`) | | `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`) | | `ends_at` | datetime | no | Ending time. Expected in ISO 8601 format (`2019-03-15T08:00:00Z`) |
| `color` | string | no | Background color hex code. | | `color` | string | no | Background color hex code. |
| `font` | string | no | Foreground color hex code. | | `font` | string | no | Foreground color hex code. |
| `target_path` | string | no | Target path of the broadcast message. | | `target_access_levels` | array of integers | no | Target access levels (roles) of the broadcast message.|
| `broadcast_type`| string | no | Appearance type (defaults to banner) | | `target_path` | string | no | Target path of the broadcast message. |
| `dismissable` | boolean | no | Can the user dismiss the 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: Example request:
...@@ -169,6 +194,7 @@ Example response: ...@@ -169,6 +194,7 @@ Example response:
"font":"#FFFFFF", "font":"#FFFFFF",
"id":1, "id":1,
"active": true, "active": true,
"target_access_levels": [10,30],
"target_path": "*/welcome", "target_path": "*/welcome",
"broadcast_type": "notification", "broadcast_type": "notification",
"dismissable": false "dismissable": false
......
...@@ -7,7 +7,9 @@ type: reference, howto ...@@ -7,7 +7,9 @@ type: reference, howto
# Broadcast messages **(FREE SELF)** # Broadcast messages **(FREE SELF)**
GitLab can display broadcast messages to all users of a GitLab instance. There are two types of broadcast messages: > Target roles [introduced](https://gitlab.com/gitlab-org/growth/team-tasks/-/issues/461) in GitLab 14.8 [with a flag](../../administration/feature_flags.md) named `role_targeted_broadcast_messages`. Disabled by default.
GitLab can display broadcast messages to users of a GitLab instance. There are two types of broadcast messages:
- Banners - Banners
- Notifications - Notifications
...@@ -66,6 +68,7 @@ To add a broadcast message: ...@@ -66,6 +68,7 @@ To add a broadcast message:
- `text-decoration` - `text-decoration`
1. Select one of the suggested background colors, or add the hex code of a different color. The default color is orange. 1. Select one of the suggested background colors, or add the hex code of a different color. The default color is orange.
1. Select the **Dismissable** checkbox to enable users to dismiss the broadcast message. 1. Select the **Dismissable** checkbox to enable users to dismiss the broadcast message.
1. Optional. Select **Target roles** to only show the broadcast message to users with the selected roles. The message displays on group, subgroup, and project pages, and does not display in Git remote responses.
1. If required, add a **Target Path** to only show the broadcast message on URLs matching that path. You can use the wildcard character `*` to match multiple URLs, for example `mygroup/myproject*`. 1. If required, add a **Target Path** to only show the broadcast message on URLs matching that path. You can use the wildcard character `*` to match multiple URLs, for example `mygroup/myproject*`.
1. Select a date for the message to start and end. 1. Select a date for the message to start and end.
1. Select **Add broadcast message**. 1. Select **Add broadcast message**.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment