/* https://github.com/benixal https://www.youtube.com/@benixal */ export default { // @ts-ignore async fetch(request, env, ctx) { const botToken = ''; const chatId = ''; const url = new URL(request.url); const domain = url.hostname; const pathParts = url.pathname.split('/'); if (request.method === 'GET' && url.pathname === '/') { // @ts-ignore const isBotTokenInvalid = !botToken || botToken === ''; // @ts-ignore const isChatIdInvalid = !chatId || chatId === ''; let warningMessage = ''; if (isBotTokenInvalid) { warningMessage += '

Warning: botToken is not defined

'; } if (isChatIdInvalid) { warningMessage += '

Warning: chatId is not defined

'; } const htmlForm = ` File Upload

Upload a File

${warningMessage}
`; return new Response(htmlForm, { headers: { 'Content-Type': 'text/html' } }); } if (request.method === 'GET' && pathParts[1] === 'init') { const telegramResponse = await postReq("setWebhook", [ { "url": `https://${domain}/hook` } ]); const telegramResult = await telegramResponse.text(); return new Response(telegramResult); } // Handle file download request if (pathParts[1] === 'download' && pathParts[2]) { const fileResponse = await postReq(`getFile`, [ { "file_id": pathParts[2] } ]); const fileData = await fileResponse.json(); const telegramFileResponse = await fetch(`https://api.telegram.org/file/bot${botToken}/${fileData.result.file_path}`); // Modify response headers const newHeaders = new Headers(telegramFileResponse.headers); // Optionally change Content-Type if it's 'application/octet-stream' const contentType = newHeaders.get('Content-Type'); if (contentType === 'application/octet-stream') { newHeaders.set('Content-Type', ''); // Adjust or leave blank } newHeaders.delete('Content-Disposition'); // Prevent forced download return new Response(telegramFileResponse.body, { headers: newHeaders }); } function extractFileIds(obj) { const fileIds = []; function searchForFileIds(item) { if (item && typeof item === 'object') { // Check if the item has 'file_id' if (item.file_id) fileIds.push(item.file_id); // Recursively search through all object properties Object.values(item).forEach(searchForFileIds); } else if (Array.isArray(item)) { item.forEach(searchForFileIds); } } searchForFileIds(obj); const uniquefileIds = [...new Set(fileIds)]; return uniquefileIds; } async function postReq(url, fields) { const tgFormData = new FormData(); fields.forEach(obj => { for (let key in obj) { tgFormData.append(key, obj[key]); } }); const telegramResponse = await fetch(`https://api.telegram.org/bot${botToken}/${url}`, { method: 'POST', body: tgFormData, }); return await telegramResponse; } if (url.pathname === '/hook' && ['POST', 'PUT'].includes(request.method)) { const json = await request.json(); const fileIds = extractFileIds(json); if (fileIds.length > 0) { const downloadLinks = await Promise.all( fileIds.map(async (fid) => { const fileResponse = await postReq(`getFile`, [ { "file_id": fid } ]); const fileData = await fileResponse.json(); if (fileData.ok) { return `https://${domain}/download/${fid}/${fileData.result.file_path}`; } else { await postReq(`sendMessage`, [ { "chat_id": json.message.from.id }, { "text": "error" }, { "parse_mode": "MarkdownV2" }, { "reply_to_message_id": json.message.message_id } ]) return false; } }) ); let msg = []; for (const item of downloadLinks) { if (item) { msg.push(`Download Link: \`${item}\``); } } if (msg.length > 0) { await postReq(`sendMessage`, [ { "chat_id": json.message.from.id }, { "text": msg.join("\n\n") }, { "parse_mode": "MarkdownV2" }, { "reply_to_message_id": json.message.message_id } ]) } } else { if ('text' in json.message && json.message.text.toLowerCase().includes('chatid')) { await postReq(`sendMessage`, [ { "chat_id": json.message.from.id }, { "text": `your chatId is: \`${json.message.from.id}\`` }, { "parse_mode": "MarkdownV2" }, { "reply_to_message_id": json.message.message_id } ]) } else if ('text' in json.message && json.message.text.includes('/start')) { await postReq(`sendMessage`, [ { "chat_id": json.message.from.id }, { "text": "Welcome!" }, ]) } else { await postReq(`sendMessage`, [ { "chat_id": json.message.from.id }, { "text": "send me a file" }, { "reply_to_message_id": json.message.message_id } ]) } } return new Response(""); } if (url.pathname === '/upload' && request.method === 'POST') { const formData = await request.formData(); const file = formData.get('file'); if (file) { const sendFileToChat = await postReq("sendDocument", [ { "chat_id": chatId }, { "document": file } ]) const sendFileToChatResponse = await sendFileToChat.json(); if (sendFileToChat.ok) { const fileIds = extractFileIds(sendFileToChatResponse); const downloadLinks = await Promise.all( fileIds.map(async (fid) => { const fileResponse = await postReq(`getFile`, [ { "file_id": fid } ]); const fileData = await fileResponse.json(); if (fileData.ok) { return `https://${domain}/download/${fid}/${fileData.result.file_path}`; } else { await postReq(`sendMessage`, [ { "chat_id": chatId }, { "text": "error" }, { "parse_mode": "MarkdownV2" } ]) return false; } }) ); let msg = []; for (const itemx of downloadLinks) { if (itemx) { msg.push(`Download Link: \`${itemx}\``); } } if (msg.length > 0) { await postReq("editMessageCaption", [ { "chat_id": chatId }, { "message_id": sendFileToChatResponse['result']['message_id'] }, { "parse_mode": "MarkdownV2" }, { "caption": msg.join("\n\n") } ]) } const html = ` Uploads

My Uploads

${downloadLinks.map(url => { // Check file extension for image types const fileExtension = url.split('.').pop().toLowerCase(); const imageExtensions = ['jpg', 'jpeg', 'png', 'webp']; const isImage = imageExtensions.includes(fileExtension); // Set the preview image, either the actual image or a generic icon const previewImage = isImage ? url : ''; return `
File Preview
`; }).join('')}
`; return new Response(html, { headers: { 'content-type': 'text/html;charset=UTF-8' }, }); } else { return new Response(`Failed`, { status: 500 }); } } else { return new Response('No file uploaded', { status: 400 }); } } } }