Merged via /review-pr -> /prepare-pr -> /merge-pr. Prepared head SHA: 16b025b3aa13c91fe3aab8a0eaac4987dddc574e Co-authored-by: guirguispierre <22091706+guirguispierre@users.noreply.github.com> Co-authored-by: obviyus <22031114+obviyus@users.noreply.github.com> Reviewed-by: @obviyus
53 lines
1.3 KiB
TypeScript
53 lines
1.3 KiB
TypeScript
import type { MsgContext } from "../auto-reply/templating.js";
|
|
import {
|
|
recordSessionMetaFromInbound,
|
|
type GroupKeyResolution,
|
|
type SessionEntry,
|
|
updateLastRoute,
|
|
} from "../config/sessions.js";
|
|
|
|
export type InboundLastRouteUpdate = {
|
|
sessionKey: string;
|
|
channel: SessionEntry["lastChannel"];
|
|
to: string;
|
|
accountId?: string;
|
|
threadId?: string | number;
|
|
};
|
|
|
|
export async function recordInboundSession(params: {
|
|
storePath: string;
|
|
sessionKey: string;
|
|
ctx: MsgContext;
|
|
groupResolution?: GroupKeyResolution | null;
|
|
createIfMissing?: boolean;
|
|
updateLastRoute?: InboundLastRouteUpdate;
|
|
onRecordError: (err: unknown) => void;
|
|
}): Promise<void> {
|
|
const { storePath, sessionKey, ctx, groupResolution, createIfMissing } = params;
|
|
void recordSessionMetaFromInbound({
|
|
storePath,
|
|
sessionKey,
|
|
ctx,
|
|
groupResolution,
|
|
createIfMissing,
|
|
}).catch(params.onRecordError);
|
|
|
|
const update = params.updateLastRoute;
|
|
if (!update) {
|
|
return;
|
|
}
|
|
await updateLastRoute({
|
|
storePath,
|
|
sessionKey: update.sessionKey,
|
|
deliveryContext: {
|
|
channel: update.channel,
|
|
to: update.to,
|
|
accountId: update.accountId,
|
|
threadId: update.threadId,
|
|
},
|
|
// Avoid leaking inbound origin metadata into a different target session.
|
|
ctx: update.sessionKey === sessionKey ? ctx : undefined,
|
|
groupResolution,
|
|
});
|
|
}
|