* CLI: add read-only SecretRef inspection * CLI: fix read-only SecretRef status regressions * CLI: preserve read-only SecretRef status fallbacks * Docs: document read-only channel inspection hook * CLI: preserve audit coverage for read-only SecretRefs * CLI: fix read-only status account selection * CLI: fix targeted gateway fallback analysis * CLI: fix Slack HTTP read-only inspection * CLI: align audit credential status checks * CLI: restore Telegram read-only fallback semantics
40 lines
1.1 KiB
TypeScript
40 lines
1.1 KiB
TypeScript
import type { OpenClawConfig } from "../config/config.js";
|
|
import { inspectDiscordAccount, type InspectedDiscordAccount } from "../discord/account-inspect.js";
|
|
import { inspectSlackAccount, type InspectedSlackAccount } from "../slack/account-inspect.js";
|
|
import {
|
|
inspectTelegramAccount,
|
|
type InspectedTelegramAccount,
|
|
} from "../telegram/account-inspect.js";
|
|
import type { ChannelId } from "./plugins/types.js";
|
|
|
|
export type ReadOnlyInspectedAccount =
|
|
| InspectedDiscordAccount
|
|
| InspectedSlackAccount
|
|
| InspectedTelegramAccount;
|
|
|
|
export function inspectReadOnlyChannelAccount(params: {
|
|
channelId: ChannelId;
|
|
cfg: OpenClawConfig;
|
|
accountId?: string | null;
|
|
}): ReadOnlyInspectedAccount | null {
|
|
if (params.channelId === "discord") {
|
|
return inspectDiscordAccount({
|
|
cfg: params.cfg,
|
|
accountId: params.accountId,
|
|
});
|
|
}
|
|
if (params.channelId === "slack") {
|
|
return inspectSlackAccount({
|
|
cfg: params.cfg,
|
|
accountId: params.accountId,
|
|
});
|
|
}
|
|
if (params.channelId === "telegram") {
|
|
return inspectTelegramAccount({
|
|
cfg: params.cfg,
|
|
accountId: params.accountId,
|
|
});
|
|
}
|
|
return null;
|
|
}
|