135 lines
3.7 KiB
TypeScript
Raw Normal View History

import { z } from 'zod';
import startercode from './startercode';
export interface Env {
R2: R2Bucket;
}
2024-04-22 00:30:50 -04:00
export default {
async fetch(request: Request, env: Env, ctx: ExecutionContext): Promise<Response> {
const success = new Response('Success', { status: 200 });
2024-04-26 00:10:43 -04:00
const invalidRequest = new Response('Invalid Request', { status: 400 });
const notFound = new Response('Not Found', { status: 404 });
const methodNotAllowed = new Response('Method Not Allowed', { status: 405 });
const url = new URL(request.url);
const path = url.pathname;
const method = request.method;
2024-05-09 22:32:21 -07:00
if (path === '/api/size' && method === 'GET') {
const params = url.searchParams;
const sandboxId = params.get('sandboxId');
if (sandboxId) {
const res = await env.R2.list({ prefix: `projects/${sandboxId}` });
// sum up the size of all files
let size = 0;
for (const file of res.objects) {
size += file.size;
}
return new Response(JSON.stringify({ size }), { status: 200 });
} else return invalidRequest;
}
else if (path === '/api') {
2024-04-26 00:10:43 -04:00
if (method === 'GET') {
const params = url.searchParams;
const sandboxId = params.get('sandboxId');
2024-05-11 17:23:45 -07:00
const folderId = params.get('folderId');
const fileId = params.get('fileId');
if (sandboxId) {
const res = await env.R2.list({ prefix: `projects/${sandboxId}` });
return new Response(JSON.stringify(res), { status: 200 });
2024-05-11 17:23:45 -07:00
} else if (folderId) {
const res = await env.R2.list({ prefix: folderId });
return new Response(JSON.stringify(res), { status: 200 });
} else if (fileId) {
const obj = await env.R2.get(fileId);
if (obj === null) {
return new Response(`${fileId} not found`, { status: 404 });
}
const headers = new Headers();
headers.set('etag', obj.httpEtag);
obj.writeHttpMetadata(headers);
const text = await obj.text();
return new Response(text, {
headers,
});
} else return invalidRequest;
2024-04-26 00:10:43 -04:00
} else if (method === 'POST') {
2024-04-29 00:50:25 -04:00
const createSchema = z.object({
fileId: z.string(),
});
const body = await request.json();
const { fileId } = createSchema.parse(body);
await env.R2.put(fileId, '');
2024-04-30 01:56:43 -04:00
return success;
} else if (method === 'DELETE') {
const deleteSchema = z.object({
fileId: z.string(),
});
const body = await request.json();
const { fileId } = deleteSchema.parse(body);
await env.R2.delete(fileId);
2024-04-29 00:50:25 -04:00
return success;
2024-04-26 00:10:43 -04:00
} else return methodNotAllowed;
2024-04-27 14:23:09 -04:00
} else if (path === '/api/rename' && method === 'POST') {
const renameSchema = z.object({
fileId: z.string(),
newFileId: z.string(),
data: z.string(),
});
const body = await request.json();
const { fileId, newFileId, data } = renameSchema.parse(body);
await env.R2.delete(fileId);
await env.R2.put(newFileId, data);
2024-04-27 19:12:25 -04:00
return success;
} else if (path === '/api/save' && method === 'POST') {
const renameSchema = z.object({
fileId: z.string(),
data: z.string(),
});
const body = await request.json();
const { fileId, data } = renameSchema.parse(body);
await env.R2.put(fileId, data);
2024-04-27 14:23:09 -04:00
return success;
2024-04-26 00:10:43 -04:00
} else if (path === '/api/init' && method === 'POST') {
const initSchema = z.object({
sandboxId: z.string(),
type: z.enum(['react', 'node']),
});
const body = await request.json();
const { sandboxId, type } = initSchema.parse(body);
2024-04-24 01:07:20 -04:00
console.log(startercode[type]);
await Promise.all(
2024-04-24 01:07:20 -04:00
startercode[type].map(async (file) => {
await env.R2.put(`projects/${sandboxId}/${file.name}`, file.body);
})
);
return success;
} else {
return notFound;
}
2024-04-22 00:30:50 -04:00
},
};