fix csv endpoint

This commit is contained in:
Emily
2024-10-08 15:24:23 +02:00
parent 79e956e930
commit 62c72b3ff9
8 changed files with 24 additions and 146 deletions

View File

@@ -1,8 +1,6 @@
import { ProjectModel } from "@schema/ProjectSchema";
import { UserModel } from "@schema/UserSchema";
import { UserSettingsModel } from "@schema/UserSettings";
import { EventModel } from '@schema/metrics/EventSchema';
import { VisitModel } from "@schema/metrics/VisitSchema";
import { google } from 'googleapis';
@@ -60,16 +58,10 @@ async function exportToGoogle(data: string, user_id: string) {
export default defineEventHandler(async event => {
const userData = getRequestUser(event);
if (!userData?.logged) return setResponseStatus(event, 400, 'NotLogged');
const data = await getRequestData(event, { requireSchema: false });
if (!data) return;
const currentActiveProject = await UserSettingsModel.findOne({ user_id: userData.id });
if (!currentActiveProject) return setResponseStatus(event, 400, 'You need to select a project');
const project_id = currentActiveProject.active_project_id;
const project = await ProjectModel.findById(project_id);
if (!project) return setResponseStatus(event, 400, 'Project not found');
const { project, project_id, user } = data;
const PREMIUM_TYPE = project.premium_type;
@@ -127,7 +119,7 @@ export default defineEventHandler(async event => {
const isGoogle = getHeader(event, 'x-google-export');
if (isGoogle === 'true') {
const data = await exportToGoogle(result, userData.id);
const data = await exportToGoogle(result, user.id);
return data;
}

View File

@@ -1,19 +0,0 @@
import { AuthContext, AuthContextLogged } from "~/server/middleware/01-authorization";
import { ProjectModel } from "@schema/ProjectSchema";
import { UserSettingsModel } from "@schema/UserSettings";
export default defineEventHandler(async event => {
const userData = getRequestUser(event);
if (!userData?.logged) return;
const userSettings = await UserSettingsModel.findOne({ user_id: userData.id }, {
active_project_id: 1
});
if (!userSettings) {
const projectOwned = await ProjectModel.findOne({ owner: userData.id }, { _id: 1 });
return projectOwned?._id.toString();
}
return userSettings?.active_project_id.toString();
});

View File

@@ -1,24 +0,0 @@
import { ProjectModel } from "@schema/ProjectSchema";
import { UserSettingsModel } from "@schema/UserSettings";
import { hasAccessToProject } from "~/server/utils/hasAccessToProject";
export default defineEventHandler(async event => {
if (!event.context) return;
const userData = getRequestUser(event);
if (!userData?.logged) return;
const { project_id } = getQuery(event);
const [hasAccess] = await hasAccessToProject(userData.id, project_id as string);
if (!hasAccess) return setResponseStatus(event, 400, 'No access to project');
await UserSettingsModel.updateOne({ user_id: userData.id }, { active_project_id: project_id }, { upsert: true });
return;
});