mirror of
https://github.com/Litlyx/litlyx
synced 2025-12-11 16:28:37 +01:00
new selfhosted version
This commit is contained in:
16
dashboard/server/api/shields/addresses/add.post.ts
Normal file
16
dashboard/server/api/shields/addresses/add.post.ts
Normal file
@@ -0,0 +1,16 @@
|
||||
import { AddressBlacklistModel } from "~/shared/schema/shields/AddressBlacklistSchema";
|
||||
|
||||
export default defineEventHandler(async event => {
|
||||
|
||||
const ctx = await getRequestContext(event, 'pid');
|
||||
|
||||
const { project_id } = ctx;
|
||||
|
||||
const body = await readBody(event);
|
||||
const { address, description } = body;
|
||||
|
||||
if (address.trim().length == 0) return setResponseStatus(event, 400, 'Address is required');
|
||||
const result = await AddressBlacklistModel.updateOne({ project_id, address }, { description }, { upsert: true });
|
||||
|
||||
return { ok: result.acknowledged };
|
||||
});
|
||||
15
dashboard/server/api/shields/addresses/delete.delete.ts
Normal file
15
dashboard/server/api/shields/addresses/delete.delete.ts
Normal file
@@ -0,0 +1,15 @@
|
||||
import { AddressBlacklistModel } from "~/shared/schema/shields/AddressBlacklistSchema";
|
||||
|
||||
export default defineEventHandler(async event => {
|
||||
|
||||
const ctx = await getRequestContext(event, 'pid');
|
||||
|
||||
const { project_id } = ctx;
|
||||
|
||||
const body = await readBody(event);
|
||||
const { address } = body;
|
||||
|
||||
const removal = await AddressBlacklistModel.deleteOne({ project_id, address });
|
||||
|
||||
return { ok: removal.deletedCount == 1 };
|
||||
});
|
||||
12
dashboard/server/api/shields/addresses/list.ts
Normal file
12
dashboard/server/api/shields/addresses/list.ts
Normal file
@@ -0,0 +1,12 @@
|
||||
import { AddressBlacklistModel } from "~/shared/schema/shields/AddressBlacklistSchema";
|
||||
|
||||
export default defineEventHandler(async event => {
|
||||
|
||||
const ctx = await getRequestContext(event, 'pid');
|
||||
|
||||
const { project_id } = ctx;
|
||||
|
||||
const blacklist = await AddressBlacklistModel.find({ project_id: project_id });
|
||||
|
||||
return blacklist.map(e => e.toJSON());
|
||||
});
|
||||
9
dashboard/server/api/shields/bots/options.ts
Normal file
9
dashboard/server/api/shields/bots/options.ts
Normal file
@@ -0,0 +1,9 @@
|
||||
import { BotTrafficOptionModel } from "~/shared/schema/shields/BotTrafficOptionSchema";
|
||||
|
||||
export default defineEventHandler(async event => {
|
||||
const ctx = await getRequestContext(event, 'pid');
|
||||
const { project_id } = ctx;
|
||||
const result = await BotTrafficOptionModel.findOne({ project_id });
|
||||
if (!result) return { block: false };
|
||||
return { block: result.block }
|
||||
});
|
||||
11
dashboard/server/api/shields/bots/update_options.post.ts
Normal file
11
dashboard/server/api/shields/bots/update_options.post.ts
Normal file
@@ -0,0 +1,11 @@
|
||||
import { BotTrafficOptionModel } from "~/shared/schema/shields/BotTrafficOptionSchema";
|
||||
|
||||
export default defineEventHandler(async event => {
|
||||
const ctx = await getRequestContext(event, 'pid');
|
||||
const { project_id } = ctx;
|
||||
const body = await readBody(event);
|
||||
const { block } = body;
|
||||
if (block != true && block != false) return setResponseStatus(event, 400, 'block is required and must be true or false');
|
||||
const result = await BotTrafficOptionModel.updateOne({ project_id }, { block }, { upsert: true });
|
||||
return { ok: result.acknowledged };
|
||||
});
|
||||
20
dashboard/server/api/shields/domains/add.post.ts
Normal file
20
dashboard/server/api/shields/domains/add.post.ts
Normal file
@@ -0,0 +1,20 @@
|
||||
import { DomainWhitelistModel } from "~/shared/schema/shields/DomainWhitelistSchema";
|
||||
|
||||
export default defineEventHandler(async event => {
|
||||
|
||||
const ctx = await getRequestContext(event, 'pid');
|
||||
|
||||
const { project_id } = ctx;
|
||||
|
||||
const body = await readBody(event);
|
||||
const { domain } = body;
|
||||
|
||||
if (domain.trim().length == 0) return setResponseStatus(event, 400, 'Domain is required');
|
||||
|
||||
await DomainWhitelistModel.updateOne({ project_id: project_id },
|
||||
{ $push: { domains: domain } },
|
||||
{ upsert: true }
|
||||
);
|
||||
|
||||
return { ok: true };
|
||||
});
|
||||
17
dashboard/server/api/shields/domains/delete.delete.ts
Normal file
17
dashboard/server/api/shields/domains/delete.delete.ts
Normal file
@@ -0,0 +1,17 @@
|
||||
import { DomainWhitelistModel } from "~/shared/schema/shields/DomainWhitelistSchema";
|
||||
|
||||
export default defineEventHandler(async event => {
|
||||
|
||||
const ctx = await getRequestContext(event, 'pid');
|
||||
|
||||
const { project_id } = ctx;
|
||||
|
||||
const body = await readBody(event);
|
||||
const { domain } = body;
|
||||
|
||||
const removal = await DomainWhitelistModel.updateOne({ project_id: project_id },
|
||||
{ $pull: { domains: domain } },
|
||||
);
|
||||
|
||||
return { ok: removal.modifiedCount == 1 };
|
||||
});
|
||||
18
dashboard/server/api/shields/domains/list.ts
Normal file
18
dashboard/server/api/shields/domains/list.ts
Normal file
@@ -0,0 +1,18 @@
|
||||
|
||||
import { DomainWhitelistModel } from "~/shared/schema/shields/DomainWhitelistSchema";
|
||||
|
||||
export default defineEventHandler(async event => {
|
||||
|
||||
const ctx = await getRequestContext(event, 'pid');
|
||||
|
||||
const { project_id } = ctx;
|
||||
|
||||
const whitelist = await DomainWhitelistModel.findOne({
|
||||
project_id
|
||||
});
|
||||
|
||||
if (!whitelist) return [];
|
||||
|
||||
return whitelist.domains;
|
||||
|
||||
});
|
||||
Reference in New Issue
Block a user