0.2.4 • Published 2 years ago
@adamkac/nestjs-slack-bolt v0.2.4
Description
This module gives a handy way to develop Slack applications using the Nestjs framework
Features
- Handle Messages
- Handle Commands
- Handle Actions
- Handle Events
Installation
# yarn
$ yarn add nestjs-slack-bolt
# npm
$ npm i nestjs-slack-boltUsage
Add these variables to the .env file
# to define on API mode
SLACK_SIGNING_SECRET="**"
# to define on Socket mode
SLACK_APP_TOKEN="**"
# require variables
SLACK_BOT_TOKEN="**"
SLACK_SOCKET_MODE=trueImport the SlackModule
import { Module } from '@nestjs/common';
import { SlackModule } from 'nestjs-slack-bolt';
import { AppController } from './app.controller';
import { AppService } from './app.service';
@Module({
  imports: [SlackModule],
  controllers: [AppController],
  providers: [AppService],
})
export class AppModule {}Example
Using annotations
import { Controller } from '@nestjs/common';
import { Action, Command, Message, Event } from 'nestjs-slack-bolt';
import { AppService } from './app.service';
import {
  SlackActionMiddlewareArgs,
  SlackCommandMiddlewareArgs,
  SlackEventMiddlewareArgs,
} from '@slack/bolt';
@Controller()
export class AppController {
  constructor(private readonly appService: AppService) {}
  @Message('hi') //Handle a message event
  message({ say }: SlackEventMiddlewareArgs) {
    say('Hello');
  }
  @Action('click') //Handle an action
  action({ say }: SlackActionMiddlewareArgs) {
    say('click event received');
  }
  @Command('/list') // handle command
  command({ say }: SlackCommandMiddlewareArgs) {
    say('/list command received');
  }
  @Event('app_home_opened')
  event({ say }: SlackEventMiddlewareArgs) {
    say('app_open_event received');
  }
}Example
Using the SlackService
import { Controller } from '@nestjs/common';
import { ConfigService } from '@nestjs/config';
import { SlackService } from 'nestjs-slack-bolt/services/slack.service';
import { Cron, CronExpression } from '@nestjs/schedule';
import { from } from 'rxjs';
@Controller()
export class AppController {
  constructor(
    private readonly slackService: SlackService,
    private readonly configService: ConfigService,
  ) {}
  @Cron(CronExpression.EVERY_10_SECONDS)
  cronJob() {
    this.searchUsers()
      .pipe()
      .subscribe((users) => {
        console.log(JSON.stringify(users));
      });
  }
  searchUsers(cursor?: string) {
    return from(
      this.slackService.client.users.list({
        token: this.configService.get('SLACK_BOT_TOKEN'),
        limit: 1,
        ...(cursor && { cursor }),
      }),
    );
  }
}TODO
- Improve testing
- handle additional slack events
Contribute & Disclaimer
....