mirror of
https://github.com/dreamhunter2333/cloudflare_temp_email.git
synced 2026-05-06 20:32:55 +08:00
fix: update address timestamp on send mail and refactor TG attachment guard (#896)
fix: update address timestamp on send mail, refactor TG attachment guard - Call updateAddressUpdatedAt after successful send mail to keep address activity timestamp up to date - Refactor Telegram attachment push: replace early return with if block to prevent skipping future logic after attachment section Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -8,7 +8,7 @@ import i18n from '../i18n';
|
||||
import { CONSTANTS } from '../constants'
|
||||
import { getJsonSetting, getDomains, getIntValue, getBooleanValue, getStringValue, getJsonObjectValue, getSplitStringListValue } from '../utils';
|
||||
import { GeoData } from '../models'
|
||||
import { handleListQuery } from '../common'
|
||||
import { handleListQuery, updateAddressUpdatedAt } from '../common'
|
||||
|
||||
|
||||
export const api = new Hono<HonoCustomType>()
|
||||
@@ -222,6 +222,8 @@ export const sendMail = async (
|
||||
console.warn(`Failed to update balance for ${address}`);
|
||||
}
|
||||
}
|
||||
// update address updated_at
|
||||
updateAddressUpdatedAt(c, address);
|
||||
// save to sendbox
|
||||
try {
|
||||
const reqIp = c.req.raw.headers.get("cf-connecting-ip")
|
||||
|
||||
@@ -439,28 +439,29 @@ export async function sendMailToTelegram(
|
||||
...Markup.inlineKeyboard([...buttons])
|
||||
});
|
||||
// send attachments
|
||||
if (!getBooleanValue(c.env.ENABLE_TG_PUSH_ATTACHMENT)) return;
|
||||
const validAttachments = attachments.filter(att => {
|
||||
if (att.content.byteLength > TG_MAX_FILE_SIZE) {
|
||||
console.log(`Skipping attachment ${att.filename}: ${(att.content.byteLength / 1024 / 1024).toFixed(1)}MB exceeds 50MB limit`);
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
});
|
||||
if (validAttachments.length > 0) {
|
||||
const caption = `From: ${parsedEmailContext.parsedEmail?.sender || ""}\nSubject: ${parsedEmailContext.parsedEmail?.subject || ""}`;
|
||||
const batchSize = 6;
|
||||
for (let i = 0; i < validAttachments.length; i += batchSize) {
|
||||
const batch = validAttachments.slice(i, i + batchSize);
|
||||
try {
|
||||
const mediaGroup: InputMediaDocument[] = batch.map((att, idx) => ({
|
||||
type: 'document',
|
||||
media: { source: Buffer.from(att.content), filename: att.filename },
|
||||
...(i === 0 && idx === 0 ? { caption } : {}),
|
||||
}));
|
||||
await bot.telegram.sendMediaGroup(targetUserId, mediaGroup);
|
||||
} catch (e) {
|
||||
console.error(`Failed to send attachment batch ${i / batchSize + 1}:`, e);
|
||||
if (getBooleanValue(c.env.ENABLE_TG_PUSH_ATTACHMENT)) {
|
||||
const validAttachments = attachments.filter(att => {
|
||||
if (att.content.byteLength > TG_MAX_FILE_SIZE) {
|
||||
console.log(`Skipping attachment ${att.filename}: ${(att.content.byteLength / 1024 / 1024).toFixed(1)}MB exceeds 50MB limit`);
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
});
|
||||
if (validAttachments.length > 0) {
|
||||
const caption = `From: ${parsedEmailContext.parsedEmail?.sender || ""}\nSubject: ${parsedEmailContext.parsedEmail?.subject || ""}`;
|
||||
const batchSize = 6;
|
||||
for (let i = 0; i < validAttachments.length; i += batchSize) {
|
||||
const batch = validAttachments.slice(i, i + batchSize);
|
||||
try {
|
||||
const mediaGroup: InputMediaDocument[] = batch.map((att, idx) => ({
|
||||
type: 'document',
|
||||
media: { source: Buffer.from(att.content), filename: att.filename },
|
||||
...(i === 0 && idx === 0 ? { caption } : {}),
|
||||
}));
|
||||
await bot.telegram.sendMediaGroup(targetUserId, mediaGroup);
|
||||
} catch (e) {
|
||||
console.error(`Failed to send attachment batch ${i / batchSize + 1}:`, e);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user