fix: add slack deps and send helpers

This commit is contained in:
Peter Steinberger
2026-01-04 11:40:08 +00:00
parent 9958283ced
commit b234d82bf3

View File

@@ -1,4 +1,8 @@
import bolt from "@slack/bolt"; import bolt from "@slack/bolt";
import type {
SlackCommandMiddlewareArgs,
SlackEventMiddlewareArgs,
} from "@slack/bolt";
import { chunkText, resolveTextChunkLimit } from "../auto-reply/chunk.js"; import { chunkText, resolveTextChunkLimit } from "../auto-reply/chunk.js";
import { formatAgentEnvelope } from "../auto-reply/envelope.js"; import { formatAgentEnvelope } from "../auto-reply/envelope.js";
@@ -685,7 +689,9 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
} }
}; };
app.event("message", async ({ event }) => { app.event(
"message",
async ({ event }: SlackEventMiddlewareArgs<"message">) => {
try { try {
const message = event as SlackMessageEvent; const message = event as SlackMessageEvent;
if (message.subtype === "message_changed") { if (message.subtype === "message_changed") {
@@ -769,9 +775,12 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
} catch (err) { } catch (err) {
runtime.error?.(danger(`slack handler failed: ${String(err)}`)); runtime.error?.(danger(`slack handler failed: ${String(err)}`));
} }
}); },
);
app.event("app_mention", async ({ event }) => { app.event(
"app_mention",
async ({ event }: SlackEventMiddlewareArgs<"app_mention">) => {
try { try {
const mention = event as SlackAppMentionEvent; const mention = event as SlackAppMentionEvent;
await handleSlackMessage(mention as unknown as SlackMessageEvent, { await handleSlackMessage(mention as unknown as SlackMessageEvent, {
@@ -781,7 +790,8 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
} catch (err) { } catch (err) {
runtime.error?.(danger(`slack mention handler failed: ${String(err)}`)); runtime.error?.(danger(`slack mention handler failed: ${String(err)}`));
} }
}); },
);
const handleReactionEvent = async ( const handleReactionEvent = async (
event: SlackReactionEvent, event: SlackReactionEvent,
@@ -858,19 +868,29 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
} }
}; };
app.event("reaction_added", async ({ event }) => { app.event(
"reaction_added",
async ({ event }: SlackEventMiddlewareArgs<"reaction_added">) => {
await handleReactionEvent(event as SlackReactionEvent, "added"); await handleReactionEvent(event as SlackReactionEvent, "added");
}); },
);
app.event("reaction_removed", async ({ event }) => { app.event(
"reaction_removed",
async ({ event }: SlackEventMiddlewareArgs<"reaction_removed">) => {
await handleReactionEvent(event as SlackReactionEvent, "removed"); await handleReactionEvent(event as SlackReactionEvent, "removed");
}); },
);
app.event("member_joined_channel", async ({ event }) => { app.event(
"member_joined_channel",
async ({ event }: SlackEventMiddlewareArgs<"member_joined_channel">) => {
try { try {
const payload = event as SlackMemberChannelEvent; const payload = event as SlackMemberChannelEvent;
const channelId = payload.channel; const channelId = payload.channel;
const channelInfo = channelId ? await resolveChannelName(channelId) : {}; const channelInfo = channelId
? await resolveChannelName(channelId)
: {};
const channelType = payload.channel_type ?? channelInfo?.type; const channelType = payload.channel_type ?? channelInfo?.type;
if ( if (
!isChannelAllowed({ !isChannelAllowed({
@@ -881,7 +901,9 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
) { ) {
return; return;
} }
const userInfo = payload.user ? await resolveUserName(payload.user) : {}; const userInfo = payload.user
? await resolveUserName(payload.user)
: {};
const userLabel = userInfo?.name ?? payload.user ?? "someone"; const userLabel = userInfo?.name ?? payload.user ?? "someone";
const label = resolveSlackChannelLabel({ const label = resolveSlackChannelLabel({
channelId, channelId,
@@ -893,13 +915,18 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
} catch (err) { } catch (err) {
runtime.error?.(danger(`slack join handler failed: ${String(err)}`)); runtime.error?.(danger(`slack join handler failed: ${String(err)}`));
} }
}); },
);
app.event("member_left_channel", async ({ event }) => { app.event(
"member_left_channel",
async ({ event }: SlackEventMiddlewareArgs<"member_left_channel">) => {
try { try {
const payload = event as SlackMemberChannelEvent; const payload = event as SlackMemberChannelEvent;
const channelId = payload.channel; const channelId = payload.channel;
const channelInfo = channelId ? await resolveChannelName(channelId) : {}; const channelInfo = channelId
? await resolveChannelName(channelId)
: {};
const channelType = payload.channel_type ?? channelInfo?.type; const channelType = payload.channel_type ?? channelInfo?.type;
if ( if (
!isChannelAllowed({ !isChannelAllowed({
@@ -910,7 +937,9 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
) { ) {
return; return;
} }
const userInfo = payload.user ? await resolveUserName(payload.user) : {}; const userInfo = payload.user
? await resolveUserName(payload.user)
: {};
const userLabel = userInfo?.name ?? payload.user ?? "someone"; const userLabel = userInfo?.name ?? payload.user ?? "someone";
const label = resolveSlackChannelLabel({ const label = resolveSlackChannelLabel({
channelId, channelId,
@@ -922,9 +951,12 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
} catch (err) { } catch (err) {
runtime.error?.(danger(`slack leave handler failed: ${String(err)}`)); runtime.error?.(danger(`slack leave handler failed: ${String(err)}`));
} }
}); },
);
app.event("channel_created", async ({ event }) => { app.event(
"channel_created",
async ({ event }: SlackEventMiddlewareArgs<"channel_created">) => {
try { try {
const payload = event as SlackChannelCreatedEvent; const payload = event as SlackChannelCreatedEvent;
const channelId = payload.channel?.id; const channelId = payload.channel?.id;
@@ -947,9 +979,12 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
danger(`slack channel created handler failed: ${String(err)}`), danger(`slack channel created handler failed: ${String(err)}`),
); );
} }
}); },
);
app.event("channel_rename", async ({ event }) => { app.event(
"channel_rename",
async ({ event }: SlackEventMiddlewareArgs<"channel_rename">) => {
try { try {
const payload = event as SlackChannelRenamedEvent; const payload = event as SlackChannelRenamedEvent;
const channelId = payload.channel?.id; const channelId = payload.channel?.id;
@@ -973,13 +1008,18 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
danger(`slack channel rename handler failed: ${String(err)}`), danger(`slack channel rename handler failed: ${String(err)}`),
); );
} }
}); },
);
app.event("pin_added", async ({ event }) => { app.event(
"pin_added",
async ({ event }: SlackEventMiddlewareArgs<"pin_added">) => {
try { try {
const payload = event as SlackPinEvent; const payload = event as SlackPinEvent;
const channelId = payload.channel_id; const channelId = payload.channel_id;
const channelInfo = channelId ? await resolveChannelName(channelId) : {}; const channelInfo = channelId
? await resolveChannelName(channelId)
: {};
if ( if (
!isChannelAllowed({ !isChannelAllowed({
channelId, channelId,
@@ -993,7 +1033,9 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
channelId, channelId,
channelName: channelInfo?.name, channelName: channelInfo?.name,
}); });
const userInfo = payload.user ? await resolveUserName(payload.user) : {}; const userInfo = payload.user
? await resolveUserName(payload.user)
: {};
const userLabel = userInfo?.name ?? payload.user ?? "someone"; const userLabel = userInfo?.name ?? payload.user ?? "someone";
const itemType = payload.item?.type ?? "item"; const itemType = payload.item?.type ?? "item";
const messageId = payload.item?.message?.ts ?? payload.event_ts; const messageId = payload.item?.message?.ts ?? payload.event_ts;
@@ -1004,15 +1046,22 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
}, },
); );
} catch (err) { } catch (err) {
runtime.error?.(danger(`slack pin added handler failed: ${String(err)}`)); runtime.error?.(
danger(`slack pin added handler failed: ${String(err)}`),
);
} }
}); },
);
app.event("pin_removed", async ({ event }) => { app.event(
"pin_removed",
async ({ event }: SlackEventMiddlewareArgs<"pin_removed">) => {
try { try {
const payload = event as SlackPinEvent; const payload = event as SlackPinEvent;
const channelId = payload.channel_id; const channelId = payload.channel_id;
const channelInfo = channelId ? await resolveChannelName(channelId) : {}; const channelInfo = channelId
? await resolveChannelName(channelId)
: {};
if ( if (
!isChannelAllowed({ !isChannelAllowed({
channelId, channelId,
@@ -1026,7 +1075,9 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
channelId, channelId,
channelName: channelInfo?.name, channelName: channelInfo?.name,
}); });
const userInfo = payload.user ? await resolveUserName(payload.user) : {}; const userInfo = payload.user
? await resolveUserName(payload.user)
: {};
const userLabel = userInfo?.name ?? payload.user ?? "someone"; const userLabel = userInfo?.name ?? payload.user ?? "someone";
const itemType = payload.item?.type ?? "item"; const itemType = payload.item?.type ?? "item";
const messageId = payload.item?.message?.ts ?? payload.event_ts; const messageId = payload.item?.message?.ts ?? payload.event_ts;
@@ -1041,10 +1092,13 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
danger(`slack pin removed handler failed: ${String(err)}`), danger(`slack pin removed handler failed: ${String(err)}`),
); );
} }
}); },
);
if (slashCommand.enabled) { if (slashCommand.enabled) {
app.command(slashCommand.name, async ({ command, ack, respond }) => { app.command(
slashCommand.name,
async ({ command, ack, respond }: SlackCommandMiddlewareArgs) => {
try { try {
const prompt = command.text?.trim(); const prompt = command.text?.trim();
if (!prompt) { if (!prompt) {
@@ -1135,7 +1189,8 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
} }
const sender = await resolveUserName(command.user_id); const sender = await resolveUserName(command.user_id);
const senderName = sender?.name ?? command.user_name ?? command.user_id; const senderName =
sender?.name ?? command.user_name ?? command.user_id;
const channelName = channelInfo?.name; const channelName = channelInfo?.name;
const roomLabel = channelName const roomLabel = channelName
? `#${channelName}` ? `#${channelName}`
@@ -1184,7 +1239,8 @@ export async function monitorSlackProvider(opts: MonitorSlackOpts = {}) {
response_type: "ephemeral", response_type: "ephemeral",
}); });
} }
}); },
);
} }
const stopOnAbort = () => { const stopOnAbort = () => {