* wip * collector parse fixes * refactor for class and also operation for reading * add skill management panel * management panel + lint * management panel + lint * Hide skill in non-docker context * add ask-prompt for edit tool calls * fix dep * fix execa pkg (unused in codebase) * simplify search with ripgrep only and build deps * Fs skill i18n (#5264) i18n * add copy file support * fix translations
65 lines
1.9 KiB
JavaScript
65 lines
1.9 KiB
JavaScript
const { AgentSkillWhitelist } = require("../models/agentSkillWhitelist");
|
|
const { reqBody, userFromSession } = require("../utils/http");
|
|
const { validatedRequest } = require("../utils/middleware/validatedRequest");
|
|
const {
|
|
flexUserRoleValid,
|
|
ROLES,
|
|
} = require("../utils/middleware/multiUserProtected");
|
|
|
|
function agentSkillWhitelistEndpoints(app) {
|
|
if (!app) return;
|
|
|
|
app.get(
|
|
"/agent-skills/filesystem-agent/is-available",
|
|
[validatedRequest],
|
|
async (_request, response) => {
|
|
try {
|
|
const filesystemTool = require("../utils/agents/aibitat/plugins/filesystem/lib");
|
|
return response
|
|
.status(200)
|
|
.json({ available: filesystemTool.isToolAvailable() });
|
|
} catch (e) {
|
|
console.error(e);
|
|
return response
|
|
.status(500)
|
|
.json({ available: false, error: e.message });
|
|
}
|
|
}
|
|
);
|
|
|
|
app.post(
|
|
"/agent-skills/whitelist/add",
|
|
[validatedRequest, flexUserRoleValid(ROLES.all)],
|
|
async (request, response) => {
|
|
try {
|
|
const { skillName } = reqBody(request);
|
|
if (!skillName) {
|
|
response
|
|
.status(400)
|
|
.json({ success: false, error: "Missing skillName" });
|
|
return;
|
|
}
|
|
|
|
const user = await userFromSession(request, response);
|
|
if (!user && response.locals?.multiUserMode) {
|
|
return response
|
|
.status(401)
|
|
.json({ success: false, error: "Unauthorized" });
|
|
}
|
|
|
|
const userId = user?.id || null;
|
|
const { success, error } = await AgentSkillWhitelist.add(
|
|
skillName,
|
|
userId
|
|
);
|
|
return response.status(success ? 200 : 400).json({ success, error });
|
|
} catch (e) {
|
|
console.error(e);
|
|
return response.status(500).json({ success: false, error: e.message });
|
|
}
|
|
}
|
|
);
|
|
}
|
|
|
|
module.exports = { agentSkillWhitelistEndpoints };
|