Skip to content

Commit

Permalink
chore: readme
Browse files Browse the repository at this point in the history
  • Loading branch information
solaris007 committed Feb 1, 2024
1 parent 22b327b commit d7bfda0
Showing 1 changed file with 67 additions and 171 deletions.
238 changes: 67 additions & 171 deletions packages/spacecat-shared-slack-client/README.md
Original file line number Diff line number Diff line change
@@ -1,14 +1,26 @@
# Spacecat Shared - Slack Client

A library utility to manage to interact with different Slack organizations.
This package provides a set of tools for interacting with Slack workspaces, specifically designed to cater to different organizational needs. It facilitates message posting, channel management, user invitations, and file uploads, with support for both standard and elevated privileges.

## Installation

```
Install the package using npm:

```bash
npm install @adobe/spacecat-shared-slack-client
```

## Usage
## Features

- **Client Creation**: Utilize a factory method to create Slack clients for different targets, with or without elevated privileges.
- **Message Posting**: Send messages to channels or threads, including advanced formatting with Slack Block Builder.
- **Channel Management**: Create Slack channels and manage their details.
- **User Invitations**: Invite users to channels via email.
- **File Uploading**: Upload files to Slack channels.

## Configuration

The package uses environment variables for configuration. Set the following variables in your environment:

### Configuring Tokens

Expand Down Expand Up @@ -45,211 +57,95 @@ users:read (to lookup users, required by users:read.email)
users:read.email (to lookup users by their emails)
```

### Creating and instance from Helix UniversalContext

```js
import createFrom from '@adobe/spacecat-shared-slack-client';

const context = {}; // Your Helix UniversalContext object
const target = 'ADOBE_INTERNAL';
const isElevated = false; // optional, defaults to false
const slackClient = createFrom(context, target, isElevated);
```

**Required env variables in Helix UniversalContext**

At least one of the following environment variables should exist in Helix UniversalContext

```
SLACK_TOKEN_ADOBE_INTERNAL="slack bot token for the adobe internal org"
SLACK_TOKEN_ADOBE_EXTERNAL="slack bot token for the adobe external org"
```

Additionally, when using the elevated slack client, the following environment variables are required:
### Standard Client

```
SLACK_TOKEN_ADOBE_INTERNAL_ELEVATED="slack bot token for the adobe internal org"
SLACK_TOKEN_ADOBE_EXTERNAL_ELEVATED="slack bot token for the adobe external org"
SLACK_OPS_CHANNEL_ADOBE_INTERNAL="slack channel id for the ops channel to which status and action required messages are sent"
SLACK_OPS_CHANNEL_ADOBE_EXTERNAL="slack channel id for the ops channel to which status and action required messages are sent"
SLACK_OPS_ADMINS_ADOBE_INTERNAL="comma separated list of slack user ids who are invited to created channels"
SLACK_OPS_ADMINS_ADOBE_EXTERNAL="comma separated list of slack user ids who are invited to created channels"
```
- `SLACK_TOKEN_ADOBE_INTERNAL`
- `SLACK_TOKEN_ADOBE_EXTERNAL`

**Note**: if Helix UniversalContext object already contains a `slackClients` field, then `createFrom` factory method returns the previously created instance instead of creating a new one.
### Elevated Client

### Constructor

`ElevatedSlackClient` or `BaseSlackClient` need a slack bot token, an ops config and a logger object:

```js
const token = 'slack bot token';
const opsConfig = {
channel: 'mandatory slack channel id for the ops channel to which status and action required messages are sent',
admins: 'optional comma separated list of slack user ids who are invited to created channels',
};
const slackClient = new SlackClient(token, opsConfig, console);
```
- `SLACK_TOKEN_ADOBE_INTERNAL_ELEVATED`
- `SLACK_TOKEN_ADOBE_EXTERNAL_ELEVATED`
- `SLACK_OPS_CHANNEL_ADOBE_INTERNAL`
- `SLACK_OPS_CHANNEL_ADOBE_EXTERNAL`
- `SLACK_OPS_ADMINS_ADOBE_INTERNAL`
- `SLACK_OPS_ADMINS_ADOBE_EXTERNAL`

### Channel Creation && Invitation

#### Creating a channel

```js
import createFrom, { SLACK_TARGETS } from '@adobe/spacecat-shared-slack-client';
## Usage

const elevatedClient = createFrom(context, SLACK_TARGETS.ADOBE_EXTERNAL, true);
const channel = await elevatedClient.createChannel(
channelName,
'This is a test topic',
'This is a test description',
false, // public vs private channel
);
```
### Client Creation

#### Inviting a user to a channel
Create a Slack client instance:

```js
```javascript
import createFrom, { SLACK_TARGETS } from '@adobe/spacecat-shared-slack-client';

const elevatedClient = createFrom(context, SLACK_TARGETS.ADOBE_EXTERNAL, true);

const result = await elevatedClient.inviteUsersByEmail(channel.getId(), [
{
email: 'user1@email.com',
realName: 'User 1',
},
{
email: 'user3@acme.com',
realName: 'User 2',
},
]);
const context = {}; // Your context object
const target = SLACK_TARGETS.ADOBE_INTERNAL; // or ADOBE_EXTERNAL
const slackClient = createFrom(context, target);
```

### Posting a message

#### Posting a text message
### Posting a Message

```js
import createFrom, { SLACK_TARGETS } from '@adobe/spacecat-shared-slack-client';

const channelId = 'channel-id'; // channel to send the message to
const threadId = 'thread-id'; // thread id to send the message under (optional)

const internalSlackClient = createFrom(context, SLACK_TARGETS.ADOBE_INTERNAL);

await internalSlackClient.postMessage({
text: 'HELLO WORLD!',
```javascript
await slackClient.postMessage({
channel: 'channel-id',
thread_ts: threadId, // (optional)
text: 'Hello, world!',
});
```

#### Posting a simple text message using Slack Block Builder (recommended)

```js
import createFrom, { SLACK_TARGETS } from '@adobe/spacecat-shared-slack-client';
import { Message, Blocks, Elements } from 'slack-block-builder';

const channelId = 'channel-id'; // channel to send the message to
const threadId = 'thread-id'; // thread id to send the message under (optional)

// Create a SlackClient instance from a helix universal context object
const internalSlackClient = SlackClient.createFrom(context, SLACK_TARGETS.ADOBE_INTERNAL);

// build the message to be sent to Slack
const message = Message()
.text('Alas, my friend.')
.channel(channelId)
.threadTs(threadId) //optional
.buildToObject();

await internalSlackClient.postMessage(message);
### Creating a Channel

```javascript
const channel = await slackClient.createChannel('channel-name', 'Topic', 'Description', true);
```

#### Posting a non-trivial message using Slack Block Builder (recommended)

```js
import createFrom, { SLACK_TARGETS } from '@adobe/spacecat-shared-slack-client';
import { Message, Blocks, Elements } from 'slack-block-builder';

const channelId = 'channel-id'; // channel to send the message to
const threadId = 'thread-id'; // thread id to send the message under (optional)

// Create a SlackClient instance from a helix universal context object
const internalSlackClient = SlackClient.createFrom(context, SLACK_TARGETS.ADOBE_INTERNAL);

// build the message to be sent to Slack
const message = Message()
.channel(channelId)
.threadTs(threadId) //optional
.text('Alas, my friend.')
.blocks(
Blocks.Section()
.text('One does not simply walk into Slack and click a button.'),
Blocks.Section()
.text('At least that\'s what my friend Slackomir said :crossed_swords:'),
Blocks.Divider(),
Blocks.Actions()
.elements(
Elements.Button()
.text('Sure One Does')
.actionId('gotClicked')
.danger(dangerLevel > 42), // Optional argument, defaults to 'true'
Elements.Button()
.text('One Does Not')
.actionId('scaredyCat')
.primary()))
.asUser()
.buildToObject();

await internalSlackClient.postMessage(message);
### Inviting Users

```javascript
await slackClient.inviteUsersByEmail('channel-id', [{ email: 'user@example.com' }]);
```

### Uploading a file

```js
import createFrom, { SLACK_TARGETS } from '@adobe/spacecat-shared-slack-client';

const channelId = 'channel-id'; // channel to send the message to
const threadId = 'thread-id'; // thread id to send the message under (optional)
### Uploading a File

const internalSlackClient = SlackClient.createFrom(context, SLACK_TARGETS.ADOBE_INTERNAL);

await internalSlackClient.fileUpload({
file: './path/to/logo.png', // also accepts Buffer or ReadStream
filename: 'logo.png',
initial_comment: 'Here is the new company logo',
channel_id: channelId,
thread_ts: threadId, // (optional)
```javascript
await slackClient.fileUpload({
file: 'path/to/file.png',
filename: 'file.png',
channel_id: 'channel-id',
});
```

## Testing
Run the included tests with the following command:
```

To run tests:

```bash
npm test
```

## Linting
Lint the codebase using:
```

Lint your code:

```bash
npm run lint
```

## Cleaning
To clean the package (remove `node_modules` and `package-lock.json`):
```

To remove `node_modules` and `package-lock.json`:

```bash
npm run clean
```

## Repository
Find the source code and contribute [here](https://github.com/adobe/spacecat-shared.git).
## Additional Information

- **Repository**: [GitHub](https://github.com/adobe/spacecat-shared.git)
- **Issue Tracking**: [GitHub Issues](https://github.com/adobe/spacecat-shared/issues)
- **License**: Apache-2.0

## Issues
Report issues or bugs [here](https://github.com/adobe/spacecat-shared/issues).
---

## License
This project is licensed under the Apache-2.0 License.
This revised README provides a structured and straightforward guide to the package, ensuring users can quickly understand its capabilities and how to use them effectively.

0 comments on commit d7bfda0

Please sign in to comment.