mirror of
https://github.com/Mintplex-Labs/anything-llm.git
synced 2024-11-09 00:10:10 +01:00
1846a99b93
* WIP embedded app * WIP got response from backend in embedded app * WIP streaming prints to embedded app * implemented streaming and tailwind min for styling into embedded app * WIP embedded app history functional * load params from script tag into embedded app * rough in modularization of embed chat cleanup dev process for easier dev support move all chat to components todo: build process todo: backend support * remove eslint config * Implement models and cleanup embed chat endpoints Improve build process for embed prod minification and bundle size awareness WIP * forgot files * rename to embed folder * introduce chat modal styles * add middleware validations on embed chat * auto open param and default greeting * reset chat history * Admin embed config page * Admin Embed Chats mgmt page * update embed * nonpriv * more style support reopen if chat was last opened * update comments * remove unused imports * allow change of workspace for embedconfig * update failure to lookup message * update reset script * update instructions * Add more styling options Add sponsor text at bottom Support dynamic container height Loading animations * publish new embed script * Add back syntax highlighting and keep bundle small via dynamic script build * add hint * update readme * update copy model for snippet with link to styles --------- Co-authored-by: timothycarambat <rambat1010@gmail.com>
116 lines
3.3 KiB
JavaScript
116 lines
3.3 KiB
JavaScript
const { EmbedChats } = require("../models/embedChats");
|
|
const { EmbedConfig } = require("../models/embedConfig");
|
|
const { reqBody, userFromSession } = require("../utils/http");
|
|
const { validEmbedConfigId } = require("../utils/middleware/embedMiddleware");
|
|
const {
|
|
flexUserRoleValid,
|
|
ROLES,
|
|
} = require("../utils/middleware/multiUserProtected");
|
|
const { validatedRequest } = require("../utils/middleware/validatedRequest");
|
|
|
|
function embedManagementEndpoints(app) {
|
|
if (!app) return;
|
|
|
|
app.get(
|
|
"/embeds",
|
|
[validatedRequest, flexUserRoleValid([ROLES.admin])],
|
|
async (_, response) => {
|
|
try {
|
|
const embeds = await EmbedConfig.whereWithWorkspace({}, null, {
|
|
createdAt: "desc",
|
|
});
|
|
response.status(200).json({ embeds });
|
|
} catch (e) {
|
|
console.error(e);
|
|
response.sendStatus(500).end();
|
|
}
|
|
}
|
|
);
|
|
|
|
app.post(
|
|
"/embeds/new",
|
|
[validatedRequest, flexUserRoleValid([ROLES.admin])],
|
|
async (request, response) => {
|
|
try {
|
|
const user = userFromSession(request, response);
|
|
const data = reqBody(request);
|
|
const { embed, message: error } = await EmbedConfig.new(data, user?.id);
|
|
response.status(200).json({ embed, error });
|
|
} catch (e) {
|
|
console.error(e);
|
|
response.sendStatus(500).end();
|
|
}
|
|
}
|
|
);
|
|
|
|
app.post(
|
|
"/embed/update/:embedId",
|
|
[validatedRequest, flexUserRoleValid([ROLES.admin]), validEmbedConfigId],
|
|
async (request, response) => {
|
|
try {
|
|
const { embedId } = request.params;
|
|
const updates = reqBody(request);
|
|
const { success, error } = await EmbedConfig.update(embedId, updates);
|
|
response.status(200).json({ success, error });
|
|
} catch (e) {
|
|
console.error(e);
|
|
response.sendStatus(500).end();
|
|
}
|
|
}
|
|
);
|
|
|
|
app.delete(
|
|
"/embed/:embedId",
|
|
[validatedRequest, flexUserRoleValid([ROLES.admin]), validEmbedConfigId],
|
|
async (request, response) => {
|
|
try {
|
|
const { embedId } = request.params;
|
|
await EmbedConfig.delete({ id: Number(embedId) });
|
|
response.status(200).json({ success: true, error: null });
|
|
} catch (e) {
|
|
console.error(e);
|
|
response.sendStatus(500).end();
|
|
}
|
|
}
|
|
);
|
|
|
|
app.post(
|
|
"/embed/chats",
|
|
[validatedRequest, flexUserRoleValid([ROLES.admin])],
|
|
async (request, response) => {
|
|
try {
|
|
const { offset = 0, limit = 20 } = reqBody(request);
|
|
const embedChats = await EmbedChats.whereWithEmbedAndWorkspace(
|
|
{},
|
|
limit,
|
|
{ id: "desc" },
|
|
offset * limit
|
|
);
|
|
const totalChats = await EmbedChats.count();
|
|
const hasPages = totalChats > (offset + 1) * limit;
|
|
response.status(200).json({ chats: embedChats, hasPages, totalChats });
|
|
} catch (e) {
|
|
console.error(e);
|
|
response.sendStatus(500).end();
|
|
}
|
|
}
|
|
);
|
|
|
|
app.delete(
|
|
"/embed/chats/:chatId",
|
|
[validatedRequest, flexUserRoleValid([ROLES.admin])],
|
|
async (request, response) => {
|
|
try {
|
|
const { chatId } = request.params;
|
|
await EmbedChats.delete({ id: Number(chatId) });
|
|
response.status(200).json({ success: true, error: null });
|
|
} catch (e) {
|
|
console.error(e);
|
|
response.sendStatus(500).end();
|
|
}
|
|
}
|
|
);
|
|
}
|
|
|
|
module.exports = { embedManagementEndpoints };
|