merlyn/server/endpoints/agentSkillWhitelist.js
Timothy Carambat 3dedcede34
Filesystem Agent Skill overhaul (#5260)
* 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
2026-03-26 14:07:46 -07:00

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 };