mirror of
https://github.com/openclaw/openclaw.git
synced 2026-03-16 12:30:49 +00:00
* refactor: remove channel shim directories, point all imports to extensions
Delete the 6 backward-compat shim directories (src/telegram, src/discord,
src/slack, src/signal, src/imessage, src/web) that were re-exporting from
extensions. Update all 112+ source files to import directly from
extensions/{channel}/src/ instead of through the shims.
Also:
- Move src/channels/telegram/ (allow-from, api) to extensions/telegram/src/
- Fix outbound adapters to use resolveOutboundSendDep (fixes 5 pre-existing TS errors)
- Update cross-extension imports (src/web/media.js → extensions/whatsapp/src/media.js)
- Update vitest, tsdown, knip, labeler, and script configs for new paths
- Update guard test allowlists for extension paths
After this, src/ has zero channel-specific implementation code — only the
generic plugin framework remains.
* fix: update raw-fetch guard allowlist line numbers after shim removal
* refactor: document direct extension channel imports
* test: mock transcript module in delivery helpers
46 lines
1.5 KiB
JavaScript
46 lines
1.5 KiB
JavaScript
#!/usr/bin/env node
|
|
|
|
import path from "node:path";
|
|
import ts from "typescript";
|
|
import { runCallsiteGuard } from "./lib/callsite-guard.mjs";
|
|
import { runAsScript, toLine, unwrapExpression } from "./lib/ts-guard-utils.mjs";
|
|
|
|
const sourceRoots = ["src/gateway", "extensions/discord/src/voice"];
|
|
const enforcedFiles = new Set([
|
|
"extensions/discord/src/voice/manager.ts",
|
|
"src/gateway/openai-http.ts",
|
|
"src/gateway/openresponses-http.ts",
|
|
"src/gateway/server-methods/agent.ts",
|
|
"src/gateway/server-node-events.ts",
|
|
]);
|
|
|
|
export function findLegacyAgentCommandCallLines(content, fileName = "source.ts") {
|
|
const sourceFile = ts.createSourceFile(fileName, content, ts.ScriptTarget.Latest, true);
|
|
const lines = [];
|
|
const visit = (node) => {
|
|
if (ts.isCallExpression(node)) {
|
|
const callee = unwrapExpression(node.expression);
|
|
if (ts.isIdentifier(callee) && callee.text === "agentCommand") {
|
|
lines.push(toLine(sourceFile, callee));
|
|
}
|
|
}
|
|
ts.forEachChild(node, visit);
|
|
};
|
|
visit(sourceFile);
|
|
return lines;
|
|
}
|
|
|
|
export async function main() {
|
|
await runCallsiteGuard({
|
|
importMetaUrl: import.meta.url,
|
|
sourceRoots,
|
|
findCallLines: findLegacyAgentCommandCallLines,
|
|
skipRelativePath: (relPath) => !enforcedFiles.has(relPath.replaceAll(path.sep, "/")),
|
|
header: "Found ingress callsites using local agentCommand() (must be explicit owner-aware):",
|
|
footer:
|
|
"Use agentCommandFromIngress(...) and pass senderIsOwner explicitly at ingress boundaries.",
|
|
});
|
|
}
|
|
|
|
runAsScript(import.meta.url, main);
|