Professor Bloom is, in essence, a bot dedicated to helping the Welcome Committee onboard new Hack Clubbers, ensuring they feel at home from the moment they arrive.
 Credits for the logo: !Eleeza Amin
Credits for the logo: !Eleeza Amin
- Node.js (v14 or later)
- pnpm
- A Slack workspace where you have permissions to install apps
- ngrok (for local development)
- Go to https://api.slack.com/apps and click "Create New App".
- Choose "From an app manifest" and select your workspace.
- Copy and paste the following manifest, replacing YOUR_NGROK_URLwith your ngrok URL (we'll set this up later):
display_information:
  name: Professor Bloom - Dev [your_name]
  description:
  background_color: "#FFFFFF"
  long_description:
features:
  app_home:
    home_tab_enabled: true
    messages_tab_enabled: true
    messages_tab_read_only_enabled: true
  bot_user:
    display_name: Bloom Dev
    always_online: true
  shortcuts:
    - name: Report adult
      type: message
      callback_id: message_adult_report
      description: Reports this message's author for being an adult.
oauth_config:
  redirect_urls:
    - YOUR_NGROK_URL/slack/oauth_redirect
  scopes:
    user:
      - chat:write
    bot:
      - app_mentions:read
      - channels:history
      - channels:join
      - channels:read
      - chat:write
      - chat:write.public
      - emoji:read
      - groups:history
      - groups:write
      - im:history
      - im:read
      - im:write
      - mpim:history
      - users:read
      - users:read.email
settings:
  event_subscriptions:
    request_url: YOUR_NGROK_URL/slack/events
    bot_events:
      - app_home_opened
      - app_mention
      - team_join
  interactivity:
    is_enabled: true
    request_url: YOUR_NGROK_URL/slack/events
  org_deploy_enabled: false
  socket_mode_enabled: false
  token_rotation_enabled: false- Review and create the app.
- In the "Basic Information" section, note down the App Id,Client Id,Client Secret,Signing Secret.
- Go to "OAuth & Permissions" and install the app to your workspace. Note down the "Bot User OAuth Token".
- 
Clone the repository: git clone https://github.com/your-repo/professor-bloom.git cd professor-bloom
- 
Install dependencies: pnpm install
- 
Copy the sample.envfile to.env:cp sample.env .env
- 
Edit the .envfile and fill in the values:PORT=3000 NODE_ENV="development" AIRTABLE_API_KEY="api-key" AIRTABLE_BASE_ID="base-id" SLACK_BOT_TOKEN="bot-token" SLACK_SIGNING_SECRET="signing-secret" SLACK_CLIENT_ID="client-id" SLACK_CLIENT_SECRET="client-secret" SLACK_APP_ID="app-id" SLACK_STATE_SECRET="state-secret" SLACK_CHANNEL_DEV_SPAM="channel-id" SLACK_CHANNEL_WELCOMERS="channel-id" SLACK_WELCOMER_COMMS_CHANNEL="channel-id" DATABASE_URL="postgres://<username>:<password>@localhost:5432/<database>?schema=bloom" SHADOW_DATABASE_URL="postgres://<username>:<password>@localhost:5432/<database>?schema=bloom_shadow" UPGRADE_WEBHOOK_TOKENS="first second" #ENABLE_TEAM_JOIN_EVENT=Uncomment to enable the team_join eventReplace the values with your actual parameters. 
- 
Set up the database: pnpm prisma migrate dev
- 
Start ngrok: ngrok http 3000Note the HTTPS URL provided by ngrok. 
- 
Update your Slack app's request URLs: - Go to your Slack app's settings.
- In "Event Subscriptions" and "Interactivity & Shortcuts", update the request URL to your ngrok HTTPS URL followed by /slack/events.
- In "OAuth & Permissions", update Redirect URLsto your ngrok HTTPS URL followed by/slack/oauth_redirect.
 
- 
Start the application: pnpm dev
Professor Bloom should now be running and connected to your Slack workspace!
Contributions are welcome! Please feel free to submit a Pull Request.
This project is licensed under the MIT License.