mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-11 00:08:30 +01:00
docs: Unleash Slack App integration (#4801)
https://linear.app/unleash/issue/2-1235/docs-slack-app-integration-documentation This adds a new reference doc for the new Unleash Slack App integration and marks the previous Slack integration as deprecated. As a side-effect this PR also fixes an issue where we wouldn't be able to delete tags with special characters. --------- Co-authored-by: David Leek <david@getunleash.io> Co-authored-by: Thomas Heartman <thomas@getunleash.ai>
This commit is contained in:
parent
e197934fa4
commit
b9946ee35c
@ -196,8 +196,12 @@ const useFeatureApi = () => {
|
|||||||
type: string,
|
type: string,
|
||||||
value: string
|
value: string
|
||||||
) => {
|
) => {
|
||||||
|
const encodedTagPath = `${encodeURIComponent(
|
||||||
|
type
|
||||||
|
)}/${encodeURIComponent(value)}`;
|
||||||
|
|
||||||
// TODO: Change this path to the new API when moved.
|
// TODO: Change this path to the new API when moved.
|
||||||
const path = `api/admin/features/${featureId}/tags/${type}/${value}`;
|
const path = `api/admin/features/${featureId}/tags/${encodedTagPath}`;
|
||||||
const req = createRequest(path, {
|
const req = createRequest(path, {
|
||||||
method: 'DELETE',
|
method: 'DELETE',
|
||||||
});
|
});
|
||||||
|
@ -11,7 +11,6 @@ import {
|
|||||||
FEATURE_STRATEGY_ADD,
|
FEATURE_STRATEGY_ADD,
|
||||||
FEATURE_METADATA_UPDATED,
|
FEATURE_METADATA_UPDATED,
|
||||||
FEATURE_PROJECT_CHANGE,
|
FEATURE_PROJECT_CHANGE,
|
||||||
FEATURE_VARIANTS_UPDATED,
|
|
||||||
FEATURE_POTENTIALLY_STALE_ON,
|
FEATURE_POTENTIALLY_STALE_ON,
|
||||||
FEATURE_ENVIRONMENT_VARIANTS_UPDATED,
|
FEATURE_ENVIRONMENT_VARIANTS_UPDATED,
|
||||||
} from '../types/events';
|
} from '../types/events';
|
||||||
@ -62,7 +61,6 @@ const slackAppDefinition: IAddonDefinition = {
|
|||||||
FEATURE_STRATEGY_UPDATE,
|
FEATURE_STRATEGY_UPDATE,
|
||||||
FEATURE_STRATEGY_ADD,
|
FEATURE_STRATEGY_ADD,
|
||||||
FEATURE_METADATA_UPDATED,
|
FEATURE_METADATA_UPDATED,
|
||||||
FEATURE_VARIANTS_UPDATED,
|
|
||||||
FEATURE_PROJECT_CHANGE,
|
FEATURE_PROJECT_CHANGE,
|
||||||
FEATURE_POTENTIALLY_STALE_ON,
|
FEATURE_POTENTIALLY_STALE_ON,
|
||||||
],
|
],
|
||||||
|
@ -24,7 +24,7 @@ Unleash currently supports the following integrations out of the box:
|
|||||||
- [Jira Cloud](jira-cloud-plugin-usage.md) - Allows you to create, view and manage Unleash feature flags directly from a Jira Cloud issue
|
- [Jira Cloud](jira-cloud-plugin-usage.md) - Allows you to create, view and manage Unleash feature flags directly from a Jira Cloud issue
|
||||||
- [Jira Server](jira-server-plugin-usage.md) - Allows you to create and link Unleash feature flags directly from a Jira Server issue
|
- [Jira Server](jira-server-plugin-usage.md) - Allows you to create and link Unleash feature flags directly from a Jira Server issue
|
||||||
- [Microsoft Teams](teams.md) - Allows Unleash to post updates to Microsoft Teams.
|
- [Microsoft Teams](teams.md) - Allows Unleash to post updates to Microsoft Teams.
|
||||||
- [Slack](slack.md) - Allows Unleash to post updates to Slack.
|
- [Slack App](slack-app.md) - The Unleash Slack App posts messages to the selected channels in your Slack workspace.
|
||||||
- [Webhook](webhook.md) - A generic way to post messages from Unleash to third party services.
|
- [Webhook](webhook.md) - A generic way to post messages from Unleash to third party services.
|
||||||
|
|
||||||
:::tip Missing an integration? Request it!
|
:::tip Missing an integration? Request it!
|
||||||
@ -33,6 +33,12 @@ If you're looking for an integration that Unleash doesn't have at the moment, yo
|
|||||||
|
|
||||||
:::
|
:::
|
||||||
|
|
||||||
|
## Deprecated integrations
|
||||||
|
|
||||||
|
These integrations are deprecated and will be removed in a future release:
|
||||||
|
|
||||||
|
- [Slack](slack.md) - Allows Unleash to post updates to Slack. Please try the new [Slack App](slack-app.md) integration instead.
|
||||||
|
|
||||||
## Community integrations
|
## Community integrations
|
||||||
|
|
||||||
Our wonderful community has also created the following integrations:
|
Our wonderful community has also created the following integrations:
|
||||||
|
63
website/docs/reference/integrations/slack-app.md
Normal file
63
website/docs/reference/integrations/slack-app.md
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
---
|
||||||
|
title: Slack App
|
||||||
|
---
|
||||||
|
|
||||||
|
import Figure from '@site/src/components/Figure/Figure.tsx'
|
||||||
|
|
||||||
|
:::info Availability
|
||||||
|
|
||||||
|
The Slack App integration was introduced in **Unleash 5.5**.
|
||||||
|
|
||||||
|
:::
|
||||||
|
|
||||||
|
The Slack App integration posts messages to a specified set of channels in your Slack workspace. The channels can be public or private, and can be specified on a per-flag basis by using [Slack tags](#tags).
|
||||||
|
|
||||||
|
## Installation {#installation}
|
||||||
|
|
||||||
|
To install the Slack App integration, follow these steps:
|
||||||
|
|
||||||
|
1. Navigate to the *integrations* page in the Unleash admin UI (available at the URL `/integrations`) and select "configure" on the Slack App integration.
|
||||||
|
2. On the integration configuration form, use the "install & connect" button.
|
||||||
|
3. A new tab will open, asking you to select the Slack workspace where you'd like to install the app.
|
||||||
|
4. After successful installation of the Unleash Slack App in your chosen Slack workspace, you'll be automatically redirected to a page displaying a newly generated access token.
|
||||||
|
5. Copy this access token and paste it into the `Access token` field within the integration settings.
|
||||||
|
|
||||||
|
By default, the Unleash Slack App is granted access to public channels. If you want the app to post messages to private channels, you'll need to manually invite it to each of those channels.
|
||||||
|
|
||||||
|
## Configuration {#configuration}
|
||||||
|
|
||||||
|
The configuration settings allow you to choose the events you're interested in and whether you want to filter them by projects and environments. You can configure a comma-separated list of channels to post the configured events to. These channels are always notified, regardless of the event type or the presence of [Slack tags](#tags).
|
||||||
|
|
||||||
|
#### Events {#events}
|
||||||
|
|
||||||
|
You can choose to trigger updates for the following events:
|
||||||
|
|
||||||
|
- feature-created
|
||||||
|
- feature-metadata-updated
|
||||||
|
- feature-project-change
|
||||||
|
- feature-archived
|
||||||
|
- feature-revived
|
||||||
|
- feature-strategy-update
|
||||||
|
- feature-strategy-add
|
||||||
|
- feature-strategy-remove
|
||||||
|
- feature-stale-on
|
||||||
|
- feature-stale-off
|
||||||
|
- feature-environment-enabled
|
||||||
|
- feature-environment-disabled
|
||||||
|
- feature-environment-variants-updated
|
||||||
|
- feature-potentially-stale-on
|
||||||
|
|
||||||
|
#### Parameters {#parameters}
|
||||||
|
|
||||||
|
The Unleash Slack App integration takes the following parameters.
|
||||||
|
|
||||||
|
- **Access token** - This is the only required property. After successful installation of the Unleash Slack App in your chosen Slack workspace, you'll be automatically redirected to a page displaying a newly generated access token. You should copy this access token and paste it into this field.
|
||||||
|
- **Channels** - A comma-separated list of channels to post the configured events to. These channels are always notified, regardless of the event type or the presence of a Slack tag.
|
||||||
|
|
||||||
|
## Tags {#tags}
|
||||||
|
|
||||||
|
Besides the configured channels, you can choose to notify other channels by tagging your feature flags with Slack-specific tags. For instance, if you want the Unleash Slack App to send notifications to the `#general` channel, add a Slack-type tag with the value "general" (or "#general"; both will work) to your flag. This will ensure that any configured events related to that feature flag will notify the tagged channel in addition to any channels configured on the integration-level.
|
||||||
|
|
||||||
|
To exclusively use tags for determining notification channels, you can leave the "channels" field blank in the integration configuration. Since you can have multiple configurations for the integration, you're free to mix and match settings to meet your precise needs. Before posting a message, all channels for that event, both configured and tagged, are combined and duplicates are removed.
|
||||||
|
|
||||||
|
<Figure caption="We have defined two Slack tags for the "new-payment-system" flag. In this example Unleash will post updates to the #notifications and #random channels, along with any channels defined in the integration configuration." img="/img/slack-addon-tags.png"/>
|
@ -1,8 +1,14 @@
|
|||||||
---
|
---
|
||||||
id: slack
|
id: slack
|
||||||
title: Slack
|
title: Slack (deprecated)
|
||||||
---
|
---
|
||||||
|
|
||||||
|
:::caution Deprecation notice
|
||||||
|
|
||||||
|
This Slack integration is deprecated and will be removed in a future release. We recommend using the new [Slack App](./slack-app.md) integration instead.
|
||||||
|
|
||||||
|
:::
|
||||||
|
|
||||||
> This feature was introduced in _Unleash v3.11.0_.
|
> This feature was introduced in _Unleash v3.11.0_.
|
||||||
|
|
||||||
The Slack integration allows Unleash to post Updates when a feature toggle is updated. To set up Slack, you need to configure an incoming Slack webhook URL. You can follow [Sending messages using Incoming Webhooks](https://api.slack.com/incoming-webhooks) on how to do that. You can also choose to [create a slack app for Unleash](https://api.slack.com/apps), which will provide you with additional functionality to control how Unleash communicates messages on your Slack workspace.
|
The Slack integration allows Unleash to post Updates when a feature toggle is updated. To set up Slack, you need to configure an incoming Slack webhook URL. You can follow [Sending messages using Incoming Webhooks](https://api.slack.com/incoming-webhooks) on how to do that. You can also choose to [create a slack app for Unleash](https://api.slack.com/apps), which will provide you with additional functionality to control how Unleash communicates messages on your Slack workspace.
|
||||||
@ -48,6 +54,6 @@ Unleash Slack integration takes the following parameters.
|
|||||||
|
|
||||||
The Slack integration also defined the Tag type "slack". You may use this tag to override which Slack channel Unleash should post updates to for this feature toggle.
|
The Slack integration also defined the Tag type "slack". You may use this tag to override which Slack channel Unleash should post updates to for this feature toggle.
|
||||||
|
|
||||||
![Slack Tags](/img/slack_addon_tags.png)
|
![Slack Tags](/img/slack-addon-tags.png)
|
||||||
|
|
||||||
In the picture you can see we have defined two slack tags for the "new-payment-system" toggle. In this example Unleash will post updates to the **#notifications** and **#random** channel.
|
In the picture you can see we have defined two slack tags for the "new-payment-system" toggle. In this example Unleash will post updates to the **#notifications** and **#random** channel.
|
||||||
|
@ -347,6 +347,7 @@ module.exports = {
|
|||||||
'reference/integrations/jira-cloud-plugin-usage',
|
'reference/integrations/jira-cloud-plugin-usage',
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
'reference/integrations/slack-app',
|
||||||
'reference/integrations/slack',
|
'reference/integrations/slack',
|
||||||
'reference/integrations/teams',
|
'reference/integrations/teams',
|
||||||
'reference/integrations/webhook',
|
'reference/integrations/webhook',
|
||||||
|
Before Width: | Height: | Size: 162 KiB After Width: | Height: | Size: 162 KiB |
Loading…
Reference in New Issue
Block a user