mirror of
https://github.com/Litlyx/litlyx
synced 2025-12-11 16:28:37 +01:00
fix admin panel + payment ok page
This commit is contained in:
15
dashboard/server/api/admin/delete_feedback.delete.ts
Normal file
15
dashboard/server/api/admin/delete_feedback.delete.ts
Normal file
@@ -0,0 +1,15 @@
|
||||
|
||||
import { FeedbackModel } from '@schema/FeedbackSchema';
|
||||
|
||||
export default defineEventHandler(async event => {
|
||||
|
||||
const userData = getRequestUser(event);
|
||||
if (!userData?.logged) return;
|
||||
if (!userData.user.roles.includes('ADMIN')) return;
|
||||
|
||||
const { id } = await readBody(event);
|
||||
|
||||
await FeedbackModel.deleteOne({ _id: id });
|
||||
|
||||
|
||||
});
|
||||
@@ -2,6 +2,18 @@ import { ProjectModel } from "@schema/project/ProjectSchema";
|
||||
import { UserModel } from "@schema/UserSchema";
|
||||
import { EventModel } from "@schema/metrics/EventSchema";
|
||||
import { VisitModel } from "@schema/metrics/VisitSchema";
|
||||
import { PremiumModel } from "~/shared/schema/PremiumSchema";
|
||||
|
||||
|
||||
function addFieldsFromArray(data: { fieldName: string, projectedName: string, arrayName: string }[]) {
|
||||
const content: Record<string, any> = {};
|
||||
data.forEach(e => {
|
||||
content[e.projectedName] = {
|
||||
"$ifNull": [{ "$getField": { "field": e.fieldName, "input": { "$arrayElemAt": [`$${e.arrayName}`, 0] } } }, 0]
|
||||
}
|
||||
});
|
||||
return content;
|
||||
}
|
||||
|
||||
export default defineEventHandler(async event => {
|
||||
const userData = getRequestUser(event);
|
||||
@@ -19,9 +31,33 @@ export default defineEventHandler(async event => {
|
||||
}
|
||||
|
||||
const totalProjects = await ProjectModel.countDocuments({ ...matchQuery });
|
||||
const premiumProjects = await ProjectModel.countDocuments({ ...matchQuery, premium: true });
|
||||
const premiumProjects = await PremiumModel.countDocuments({ ...matchQuery, premium_type: { $ne: 0 } });
|
||||
|
||||
const deadProjects = await ProjectModel.countDocuments({ ...matchQuery });
|
||||
const deadProjects = await ProjectModel.aggregate([
|
||||
{ $match: matchQuery },
|
||||
{
|
||||
$lookup: {
|
||||
from: 'project_counts',
|
||||
localField: '_id',
|
||||
foreignField: 'project_id',
|
||||
as: 'counts'
|
||||
}
|
||||
},
|
||||
{
|
||||
$addFields: addFieldsFromArray([
|
||||
{ arrayName: 'counts', fieldName: 'counts', projectedName: 'counts' },
|
||||
{ arrayName: 'counts', fieldName: 'updated_at', projectedName: 'updated_at' },
|
||||
])
|
||||
},
|
||||
{
|
||||
$match: {
|
||||
updated_at: {
|
||||
$lte: new Date(Date.now() - 1000 * 60 * 60 * 24 * 7)
|
||||
}
|
||||
}
|
||||
},
|
||||
{ $count: 'count' }
|
||||
])
|
||||
|
||||
const totalUsers = await UserModel.countDocuments({ ...matchQuery });
|
||||
|
||||
@@ -30,7 +66,11 @@ export default defineEventHandler(async event => {
|
||||
const totalEvents = await EventModel.countDocuments({ ...matchQuery });
|
||||
|
||||
|
||||
return { totalProjects, premiumProjects, deadProjects, totalUsers, totalVisits, totalEvents }
|
||||
return {
|
||||
totalProjects, premiumProjects,
|
||||
deadProjects: (deadProjects && deadProjects.length > 0 ? deadProjects[0].count : 0) as number,
|
||||
totalUsers, totalVisits, totalEvents
|
||||
}
|
||||
|
||||
|
||||
});
|
||||
@@ -1,8 +1,11 @@
|
||||
import { ProjectModel, TProject } from "@schema/project/ProjectSchema";
|
||||
import { TProjectLimit } from "~/shared/schema/project/ProjectsLimits";
|
||||
import { TPremium } from "~/shared/schema/PremiumSchema";
|
||||
import { TUser } from "~/shared/schema/UserSchema";
|
||||
|
||||
|
||||
type ExtendedProject = {
|
||||
limits: TProjectLimit[],
|
||||
user: [TUser],
|
||||
premium: [TPremium],
|
||||
counts: [{
|
||||
events: number,
|
||||
visits: number,
|
||||
@@ -54,14 +57,14 @@ export default defineEventHandler(async event => {
|
||||
const count = await ProjectModel.countDocuments(matchQuery);
|
||||
|
||||
const projects = await ProjectModel.aggregate([
|
||||
{
|
||||
{
|
||||
$match: matchQuery
|
||||
},
|
||||
},
|
||||
{
|
||||
$lookup: {
|
||||
from: "project_limits",
|
||||
localField: "_id",
|
||||
foreignField: "project_id",
|
||||
from: "user_limits",
|
||||
localField: "owner",
|
||||
foreignField: "user_id",
|
||||
as: "limits"
|
||||
}
|
||||
},
|
||||
@@ -73,6 +76,22 @@ export default defineEventHandler(async event => {
|
||||
as: "counts"
|
||||
}
|
||||
},
|
||||
{
|
||||
$lookup: {
|
||||
from: "users",
|
||||
localField: "owner",
|
||||
foreignField: "_id",
|
||||
as: "user"
|
||||
}
|
||||
},
|
||||
{
|
||||
$lookup: {
|
||||
from: "premiums",
|
||||
localField: "owner",
|
||||
foreignField: "user_id",
|
||||
as: "premium"
|
||||
}
|
||||
},
|
||||
{
|
||||
$addFields: addFieldsFromArray([
|
||||
{ arrayName: 'counts', fieldName: 'visits', projectedName: 'visits' },
|
||||
|
||||
121
dashboard/server/api/admin/user_info.ts
Normal file
121
dashboard/server/api/admin/user_info.ts
Normal file
@@ -0,0 +1,121 @@
|
||||
import { ProjectModel, TProject } from "@schema/project/ProjectSchema";
|
||||
import { VisitModel } from "~/shared/schema/metrics/VisitSchema";
|
||||
import { TUser, UserModel } from "~/shared/schema/UserSchema";
|
||||
import { TPremium } from "~/shared/schema/PremiumSchema";
|
||||
import { Types } from "mongoose";
|
||||
import { TAdminProject } from "./projects";
|
||||
|
||||
export type TAdminUserInfo = {
|
||||
user: TUser,
|
||||
projects: (TAdminProject & { domains: string[] })[],
|
||||
premium: TPremium
|
||||
}
|
||||
|
||||
|
||||
async function getProjects(user_id: string) {
|
||||
|
||||
function addFieldsFromArray(data: { fieldName: string, projectedName: string, arrayName: string }[]) {
|
||||
const content: Record<string, any> = {};
|
||||
data.forEach(e => {
|
||||
content[e.projectedName] = {
|
||||
"$ifNull": [{ "$getField": { "field": e.fieldName, "input": { "$arrayElemAt": [`$${e.arrayName}`, 0] } } }, 0]
|
||||
}
|
||||
});
|
||||
return content;
|
||||
}
|
||||
|
||||
|
||||
const projects = await ProjectModel.aggregate([
|
||||
{
|
||||
$match: { owner: new Types.ObjectId(user_id) }
|
||||
},
|
||||
{
|
||||
$lookup: {
|
||||
from: "user_limits",
|
||||
localField: "owner",
|
||||
foreignField: "user_id",
|
||||
as: "limits"
|
||||
}
|
||||
},
|
||||
{
|
||||
$lookup: {
|
||||
from: "project_counts",
|
||||
localField: "_id",
|
||||
foreignField: "project_id",
|
||||
as: "counts"
|
||||
}
|
||||
},
|
||||
{
|
||||
$lookup: {
|
||||
from: "premiums",
|
||||
localField: "owner",
|
||||
foreignField: "user_id",
|
||||
as: "premium"
|
||||
}
|
||||
},
|
||||
{
|
||||
$addFields: addFieldsFromArray([
|
||||
{ arrayName: 'counts', fieldName: 'visits', projectedName: 'visits' },
|
||||
{ arrayName: 'counts', fieldName: 'events', projectedName: 'events' },
|
||||
{ arrayName: 'counts', fieldName: 'session', projectedName: 'session' },
|
||||
{ arrayName: 'counts', fieldName: 'updated_at', projectedName: 'last_log_at' },
|
||||
]),
|
||||
},
|
||||
{
|
||||
$addFields: addFieldsFromArray([
|
||||
{ arrayName: 'limits', fieldName: 'visits', projectedName: 'limit_visits' },
|
||||
{ arrayName: 'limits', fieldName: 'events', projectedName: 'limit_events' },
|
||||
{ arrayName: 'limits', fieldName: 'limit', projectedName: 'limit_max' },
|
||||
{ arrayName: 'limits', fieldName: 'ai_messages', projectedName: 'limit_ai_messages' },
|
||||
{ arrayName: 'limits', fieldName: 'ai_limit', projectedName: 'limit_ai_max' },
|
||||
]),
|
||||
},
|
||||
{
|
||||
$addFields: {
|
||||
limit_total: {
|
||||
$add: [
|
||||
{ $ifNull: ["$limit_visits", 0] },
|
||||
{ $ifNull: ["$limit_events", 0] }
|
||||
]
|
||||
},
|
||||
}
|
||||
},
|
||||
{ $unset: 'counts' },
|
||||
{ $unset: 'limits' },
|
||||
]);
|
||||
|
||||
return projects as TAdminProject[];
|
||||
}
|
||||
|
||||
export default defineEventHandler(async event => {
|
||||
|
||||
const userData = getRequestUser(event);
|
||||
if (!userData?.logged) return;
|
||||
if (!userData.user.roles.includes('ADMIN')) return;
|
||||
|
||||
const { user_id } = getQuery(event);
|
||||
|
||||
const result: any = {}
|
||||
|
||||
result.user = await UserModel.findOne({ _id: user_id });
|
||||
result.projects = await getProjects(user_id as string);
|
||||
|
||||
|
||||
const promises: any[] = [];
|
||||
|
||||
for (const project of result.projects) {
|
||||
promises.push(new Promise<void>(async resolve => {
|
||||
const domains = await VisitModel.aggregate([
|
||||
{ $match: { project_id: (project as TAdminProject)._id } },
|
||||
{ $group: { _id: '$website', } }
|
||||
]);
|
||||
project.domains = domains.map(e => e._id);
|
||||
resolve();
|
||||
}));
|
||||
}
|
||||
|
||||
await Promise.all(promises);
|
||||
|
||||
return result as TAdminUserInfo;
|
||||
|
||||
});
|
||||
Reference in New Issue
Block a user