Files
archtika/web-app/src/routes/(authenticated)/+page.server.ts

115 lines
3.0 KiB
TypeScript
Raw Normal View History

import type { Actions, PageServerLoad } from "./$types";
2024-09-25 21:45:01 +02:00
import { apiRequest } from "$lib/server/utils";
import { API_BASE_PREFIX } from "$lib/server/utils";
import { rm } from "node:fs/promises";
import { join } from "node:path";
2024-09-25 21:45:01 +02:00
import type { Website } from "$lib/db-schema";
2024-09-25 21:45:01 +02:00
export const load: PageServerLoad = async ({ fetch, url, locals }) => {
const searchQuery = url.searchParams.get("website_search_query");
const filterBy = url.searchParams.get("website_filter");
const params = new URLSearchParams();
const baseFetchUrl = `${API_BASE_PREFIX}/website?order=last_modified_at.desc,created_at.desc`;
if (searchQuery) {
2024-10-03 18:51:30 +02:00
params.append("title", `wfts.${searchQuery}`);
}
switch (filterBy) {
case "creations":
params.append("user_id", `eq.${locals.user.id}`);
break;
case "shared":
params.append("user_id", `not.eq.${locals.user.id}`);
break;
}
const constructedFetchUrl = `${baseFetchUrl}&${params.toString()}`;
2024-09-25 21:45:01 +02:00
const totalWebsites = await apiRequest(fetch, baseFetchUrl, "HEAD", {
2024-08-01 18:09:35 +02:00
headers: {
Prefer: "count=exact"
2024-09-25 21:45:01 +02:00
},
returnData: true
2024-08-01 18:09:35 +02:00
});
const totalWebsiteCount = Number(
2024-09-25 21:45:01 +02:00
totalWebsites.data.headers.get("content-range")?.split("/").at(-1)
2024-08-01 18:09:35 +02:00
);
2024-09-25 21:45:01 +02:00
const websites: Website[] = (
await apiRequest(fetch, constructedFetchUrl, "GET", {
returnData: true
})
).data;
return {
2024-08-01 18:09:35 +02:00
totalWebsiteCount,
websites
};
};
export const actions: Actions = {
2024-09-25 21:45:01 +02:00
createWebsite: async ({ request, fetch }) => {
const data = await request.formData();
2024-09-25 21:45:01 +02:00
return await apiRequest(fetch, `${API_BASE_PREFIX}/rpc/create_website`, "POST", {
body: {
content_type: data.get("content-type"),
title: data.get("title")
},
2024-09-25 21:45:01 +02:00
successMessage: "Successfully created website"
});
},
2024-09-25 21:45:01 +02:00
updateWebsite: async ({ request, fetch }) => {
const data = await request.formData();
2024-09-25 21:45:01 +02:00
return await apiRequest(fetch, `${API_BASE_PREFIX}/website?id=eq.${data.get("id")}`, "PATCH", {
body: {
title: data.get("title")
2024-09-25 21:45:01 +02:00
},
successMessage: "Successfully updated website"
});
},
2024-09-25 21:45:01 +02:00
deleteWebsite: async ({ request, fetch }) => {
const data = await request.formData();
2024-09-25 21:45:01 +02:00
const id = data.get("id");
2024-09-25 21:45:01 +02:00
const oldDomainPrefix = (
await apiRequest(fetch, `${API_BASE_PREFIX}/domain_prefix?website_id=eq.${id}`, "GET", {
headers: {
Accept: "application/vnd.pgrst.object+json"
2024-09-25 21:45:01 +02:00
},
returnData: true
})
).data;
2024-09-25 21:45:01 +02:00
const deleteWebsite = await apiRequest(
fetch,
`${API_BASE_PREFIX}/website?id=eq.${id}`,
"DELETE",
{
successMessage: "Successfully deleted website"
}
2024-09-25 21:45:01 +02:00
);
2024-09-25 21:45:01 +02:00
if (!deleteWebsite.success) {
return deleteWebsite;
}
2024-09-25 21:45:01 +02:00
await rm(join("/", "var", "www", "archtika-websites", "previews", id as string), {
recursive: true,
force: true
});
2024-09-25 21:45:01 +02:00
await rm(join("/", "var", "www", "archtika-websites", oldDomainPrefix?.prefix ?? id), {
recursive: true,
force: true
});
2024-09-25 21:45:01 +02:00
return deleteWebsite;
}
};