From bb427facf45e9af5c563eef1bd66c3bd7f584a87 Mon Sep 17 00:00:00 2001 From: EduardPrigoanaAlt <196915955+EduardPrigoanaAlt@users.noreply.github.com> Date: Sat, 21 Feb 2026 17:19:46 +0000 Subject: [PATCH] style: auto-fix linting issues --- functions/upload.js | 107 +++++++++++++++++++++----------------------- 1 file changed, 52 insertions(+), 55 deletions(-) diff --git a/functions/upload.js b/functions/upload.js index 83eb78e..4b4cb3c 100644 --- a/functions/upload.js +++ b/functions/upload.js @@ -1,23 +1,23 @@ -const API_BASE = "https://temp.imgur.gg/api/upload"; -const COMPLETE_URL = "https://temp.imgur.gg/api/upload/complete"; -const PING_URL = "https://temp.imgur.gg/api/ping"; +const API_BASE = 'https://temp.imgur.gg/api/upload'; +const COMPLETE_URL = 'https://temp.imgur.gg/api/upload/complete'; +const PING_URL = 'https://temp.imgur.gg/api/ping'; export async function onRequest(context) { const { request } = context; - if (request.method === "OPTIONS") { + if (request.method === 'OPTIONS') { return new Response(null, { status: 204, - headers: corsHeaders() + headers: corsHeaders(), }); } - if (request.method !== "POST") { - return jsonError("Method not allowed", 405); + if (request.method !== 'POST') { + return jsonError('Method not allowed', 405); } try { - const contentType = request.headers.get("content-type") || ""; + const contentType = request.headers.get('content-type') || ''; let file; let fileName; let fileType; @@ -26,32 +26,32 @@ export async function onRequest(context) { HANDLE FILE INPUT ========================== */ - if (contentType.includes("application/json")) { + if (contentType.includes('application/json')) { const body = await request.json(); if (!body.fileUrl) { - return jsonError("No fileUrl provided", 400); + return jsonError('No fileUrl provided', 400); } const res = await fetch(body.fileUrl); - if (!res.ok) throw new Error("Failed to fetch remote file"); + if (!res.ok) throw new Error('Failed to fetch remote file'); file = await res.arrayBuffer(); - fileName = body.fileName || body.fileUrl.split("/").pop(); - fileType = res.headers.get("content-type") || "application/octet-stream"; + fileName = body.fileName || body.fileUrl.split('/').pop(); + fileType = res.headers.get('content-type') || 'application/octet-stream'; } else { const form = await request.formData(); - const uploaded = form.get("file"); + const uploaded = form.get('file'); - if (!uploaded) return jsonError("No file provided", 400); + if (!uploaded) return jsonError('No file provided', 400); if (uploaded.size > 500 * 1024 * 1024) { - return jsonError("File exceeds 500MB", 400); + return jsonError('File exceeds 500MB', 400); } file = await uploaded.arrayBuffer(); fileName = uploaded.name; - fileType = uploaded.type || "application/octet-stream"; + fileType = uploaded.type || 'application/octet-stream'; } /* ========================== @@ -59,30 +59,29 @@ export async function onRequest(context) { ========================== */ const ping = await fetch(PING_URL, { - method: "GET", - headers: userAgentHeaders() + method: 'GET', + headers: userAgentHeaders(), }); - const cookieHeader = ping.headers.get("set-cookie") || ""; - const sessionCookie = - cookieHeader.split(";").find(c => c.trim().startsWith("_s=")) || ""; + const cookieHeader = ping.headers.get('set-cookie') || ''; + const sessionCookie = cookieHeader.split(';').find((c) => c.trim().startsWith('_s=')) || ''; const metadataResp = await fetch(API_BASE, { - method: "POST", + method: 'POST', headers: { ...userAgentHeaders(), - "Content-Type": "application/json", - Cookie: sessionCookie + 'Content-Type': 'application/json', + Cookie: sessionCookie, }, body: JSON.stringify({ files: [ { fileName, fileType, - fileSize: file.byteLength - } - ] - }) + fileSize: file.byteLength, + }, + ], + }), }); const metadataText = await metadataResp.text(); @@ -95,7 +94,7 @@ export async function onRequest(context) { const fileInfo = metadata.files?.[0]; if (!fileInfo || !fileInfo.success) { - throw new Error("Invalid metadata response"); + throw new Error('Invalid metadata response'); } /* ========================== @@ -116,9 +115,8 @@ export async function onRequest(context) { success: true, url: publicUrl, fileId: fileInfo.fileId, - fileName: fileInfo.fileName + fileName: fileInfo.fileName, }); - } catch (err) { return jsonError(err.message, 500); } @@ -130,15 +128,15 @@ export async function onRequest(context) { async function handleSingle(uploadUrl, fileBuffer, fileType) { if (!uploadUrl) { - throw new Error("Missing uploadUrl for single upload"); + throw new Error('Missing uploadUrl for single upload'); } const res = await fetch(uploadUrl, { - method: "PUT", + method: 'PUT', body: fileBuffer, headers: { - "Content-Type": fileType - } + 'Content-Type': fileType, + }, }); if (!res.ok) { @@ -157,7 +155,7 @@ async function handleMultipart(fileInfo, fileBuffer) { const { partUrls, partSize, uploadId, fileId } = fileInfo; if (!partUrls || !uploadId) { - throw new Error("Invalid multipart metadata"); + throw new Error('Invalid multipart metadata'); } const parts = []; @@ -168,8 +166,8 @@ async function handleMultipart(fileInfo, fileBuffer) { const chunk = fileBuffer.slice(start, end); const uploadRes = await fetch(partUrls[i].url, { - method: "PUT", - body: chunk + method: 'PUT', + body: chunk, }); if (!uploadRes.ok) { @@ -177,27 +175,27 @@ async function handleMultipart(fileInfo, fileBuffer) { throw new Error(`Multipart part ${i + 1} failed: ${txt}`); } - let etag = uploadRes.headers.get("etag") || ""; - etag = etag.replace(/"/g, ""); // clean quotes + let etag = uploadRes.headers.get('etag') || ''; + etag = etag.replace(/"/g, ''); // clean quotes parts.push({ PartNumber: i + 1, - ETag: `"${etag}"` + ETag: `"${etag}"`, }); } /* ===== FINALIZE MULTIPART ===== */ const complete = await fetch(COMPLETE_URL, { - method: "PUT", + method: 'PUT', headers: { - "Content-Type": "application/json" + 'Content-Type': 'application/json', }, body: JSON.stringify({ fileId, uploadId, - parts - }) + parts, + }), }); const completeText = await complete.text(); @@ -209,7 +207,7 @@ async function handleMultipart(fileInfo, fileBuffer) { const completeData = JSON.parse(completeText); if (!completeData.success) { - throw new Error("Multipart finalize returned failure"); + throw new Error('Multipart finalize returned failure'); } return completeData; @@ -223,9 +221,9 @@ function jsonResponse(obj, status = 200) { return new Response(JSON.stringify(obj), { status, headers: { - "Content-Type": "application/json", - ...corsHeaders() - } + 'Content-Type': 'application/json', + ...corsHeaders(), + }, }); } @@ -235,15 +233,14 @@ function jsonError(message, status) { function corsHeaders() { return { - "Access-Control-Allow-Origin": "*", - "Access-Control-Allow-Methods": "POST, OPTIONS", - "Access-Control-Allow-Headers": "*" + 'Access-Control-Allow-Origin': '*', + 'Access-Control-Allow-Methods': 'POST, OPTIONS', + 'Access-Control-Allow-Headers': '*', }; } function userAgentHeaders() { return { - "User-Agent": - "Mozilla/5.0 (Windows NT 10.0; Win64; x64) Chrome/120.0.0.0" + 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) Chrome/120.0.0.0', }; }