Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aiven-open/slack-connector-for-apache-flink
Apache Flink® connector for Slack
https://github.com/aiven-open/slack-connector-for-apache-flink
flink flink-connector slack
Last synced: about 2 months ago
JSON representation
Apache Flink® connector for Slack
- Host: GitHub
- URL: https://github.com/aiven-open/slack-connector-for-apache-flink
- Owner: Aiven-Open
- License: apache-2.0
- Created: 2022-02-21T13:07:57.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2023-08-17T09:08:36.000Z (over 1 year ago)
- Last Synced: 2023-08-17T10:02:34.796Z (over 1 year ago)
- Topics: flink, flink-connector, slack
- Language: Java
- Homepage:
- Size: 203 KB
- Stars: 2
- Watchers: 63
- Forks: 4
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
README
# Slack Connector for Apache Flink®
## Compatibility matrix
| Apache Flink | Slack Connector for Apache Flink | Release date |
|-----------------|----------------------------------|--------------|
| 1.14.x - 1.15.x | v1.0 | 17.10.2022 |
| 1.15.x | v1.0.1-1.15 | 16.11.2022 |
| 1.16.x | v1.0.1-1.16 | 16.11.2022 |Since 1.0.1 versioning looks like `..-.`
according to [Externalized Connector development](https://cwiki.apache.org/confluence/display/FLINK/Externalized+Connector+development)To start using Slack connector for Flink put `flink-slack-connector-.jar`
to `lib/` folder of Flink and restart Flink.## Build locally
```bash
./mvnw clean verify -DskipTests
```
or in case of Windows
```
mvnw clean verify -DskipTests
```
To build with tests it is required to define `SLACK_FOR_FLINK_BOT_TOKEN` and `SLACK_FOR_FLINK_CHANNEL_ID` env variables.
`SLACK_FOR_FLINK_BOT_TOKEN` contains Bot User OAuth Token (see below)
`SLACK_FOR_FLINK_CHANNEL_ID` contains a channel id used during unit tests## Set-up Slack Application
1. Create your Slack app at [Slack API](https://api.slack.com/apps)
2. In Oauth & Permissions in Scopes add `chat:write`
3. In Oauth & Permissions copy `Bot User OAuth Token` and use for placeholder `BOT_USER_OAUTH_ACCESS_TOKEN`
4. Reinstall the app
5. Add app to the channel where it should post by mentioning the app name in a message (e.g. `@APP_NAME`) and confirming the invitation
6. Collect the Channel Id by right clicking on the channel name -> View Channel details and scrolling at the bottom of the window. The channel id should start with `C` and have a format similar to `CXXXXXXXXX`[Channel ID shown at the bottom of the window](/img/channel_id.png)
## Send message
Messages could be sent in plain text or formatted way. Also, messages could be sent as normal messages or as replies.
To send messages it is required that app has `chat:write` permission and bot is added to channel where a message should be post.First create table
```sql
CREATE TEMPORARY TABLE slack_example (
`channel_id` STRING,
`message` STRING
) WITH (
'connector' = 'slack',
'token' = BOT_USER_OAUTH_ACCESS_TOKEN
);
```
To be able to send messages in a table there should be column with name `channel_id` and `message` (or `text`).
Now to send a simple plain text message to channel_id `CHANNEL_ID`
```sql
INSERT INTO slack_example VALUES('CHANNEL_ID', 'Hello world!');
```### Send message as reply
To send message as reply it is required to specify `thread` to reply.
```sql
CREATE TEMPORARY TABLE slack_example_with_reply (
`channel_id` STRING,
`thread` STRING,
`message` STRING
) WITH (
'connector' = 'slack',
'token' = BOT_USER_OAUTH_ACCESS_TOKEN
);
```
Now to reply a simple plain text message to thread `THREAD_ID` in channel_id `CHANNEL_ID`
```sql
INSERT INTO slack_example_with_reply VALUES('CHANNEL_ID', 'THREAD_ID', 'Hello world!');
```
In case `THREAD_ID` is null it will be a normal message e.g.
```sql
INSERT INTO slack_example_with_reply VALUES('CHANNEL_ID', CAST(NULL AS STRING), 'Hello world!');
```### Send formatted message
To send formatted message there should be `blocks_as_str` or `formatted` column
```sql
CREATE TEMPORARY TABLE slack_example_formatted (
`channel_id` STRING,
`thread` STRING,
`formatted` STRING
) WITH (
'connector' = 'slack',
'token' = BOT_USER_OAUTH_ACCESS_TOKEN
);
```
Now to send a formatted message to channel_id `CHANNEL_ID`
```sql
INSERT INTO slack_example_formatted VALUES('CHANNEL_ID', CAST(NULL AS STRING), '[{"type": "divider"}]');
```
And similar message replying to `THREAD_ID`
```sql
INSERT INTO slack_example_formatted VALUES('CHANNEL_ID', 'THREAD_ID', '[{"type": "divider"}]');
```More examples of formatted messages could be found at [block-kit-builder](https://app.slack.com/block-kit-builder)
Note: in `formatted` there should be passed only value for `blocks`.
## Source
For querying there are available `type`, `ts`, `user`, `text`, `team`, `thread_ts` columns.
While querying it is also required to specify `channel_id` like
```sql
CREATE TEMPORARY TABLE table_for_quering (
`ts` DECIMAL(16, 6),
`channel` STRING,
`type` STRING,
`username` STRING,
`user` STRING,
`text` STRING
) WITH (
'connector' = 'slack',
'token' = :BOT_TOKEN,
'channel_id' = :CHANNEL_ID
);
```## Common errors
When creating a Flink job, the following are common error messages and related solutions:
* ``not_in_channel``: The app has the right permissions, but is not invited in the channel where it should post. Mention the app name in a message (e.g. `@APP_NAME`) and confirm the invitation.
## Trademarks
Apache Flink is either registered trademarks or trademarks of the Apache Software Foundation in the United States and/or other countries.
Slack is a trademark and service mark of Slack Technologies, Inc., registered in the U.S. and in other countries.