From 678a2ccdf31d20166f3830c9c267d678b0fbf01b Mon Sep 17 00:00:00 2001 From: Prince EKPINSE Date: Wed, 12 Nov 2025 00:08:36 +0100 Subject: [PATCH 1/4] fix: correct autocomplete attributes to enable password manager autofill --- src/app/login/LoginForm.tsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/app/login/LoginForm.tsx b/src/app/login/LoginForm.tsx index c1c2c431..8a859e04 100644 --- a/src/app/login/LoginForm.tsx +++ b/src/app/login/LoginForm.tsx @@ -44,7 +44,7 @@ export function LoginForm() { name="username" rules={{ required: formatMessage(labels.required) }} > - + - + Date: Wed, 12 Nov 2025 00:15:05 +0100 Subject: [PATCH 2/4] fix: enable password manager autofill on login form (#3735) --- src/app/login/LoginForm.tsx | 1 + 1 file changed, 1 insertion(+) diff --git a/src/app/login/LoginForm.tsx b/src/app/login/LoginForm.tsx index 8a859e04..b151b94e 100644 --- a/src/app/login/LoginForm.tsx +++ b/src/app/login/LoginForm.tsx @@ -46,6 +46,7 @@ export function LoginForm() { > + Date: Wed, 12 Nov 2025 17:51:19 +0800 Subject: [PATCH 3/4] feat(geo): add support for direct .mmdb URL and custom GEO_DATABASE_URL - Support GEO_DATABASE_URL environment variable for custom database URL - Auto-detect .mmdb files and skip decompression - Maintain backward compatibility with tar.gz archives --- scripts/build-geo.js | 90 ++++++++++++++++++++++++++++++++------------ 1 file changed, 66 insertions(+), 24 deletions(-) diff --git a/scripts/build-geo.js b/scripts/build-geo.js index b6ac42c4..379f6e70 100644 --- a/scripts/build-geo.js +++ b/scripts/build-geo.js @@ -13,12 +13,18 @@ if (process.env.VERCEL && !process.env.BUILD_GEO) { const db = 'GeoLite2-City'; -let url = `https://raw.githubusercontent.com/GitSquared/node-geolite2-redist/master/redist/${db}.tar.gz`; +// Support custom URL via environment variable +let url = process.env.GEO_DATABASE_URL; -if (process.env.MAXMIND_LICENSE_KEY) { - url = - `https://download.maxmind.com/app/geoip_download` + - `?edition_id=${db}&license_key=${process.env.MAXMIND_LICENSE_KEY}&suffix=tar.gz`; +// Fallback to default URLs if not provided +if (!url) { + if (process.env.MAXMIND_LICENSE_KEY) { + url = + `https://download.maxmind.com/app/geoip_download` + + `?edition_id=${db}&license_key=${process.env.MAXMIND_LICENSE_KEY}&suffix=tar.gz`; + } else { + url = `https://raw.githubusercontent.com/GitSquared/node-geolite2-redist/master/redist/${db}.tar.gz`; + } } const dest = path.resolve(process.cwd(), 'geo'); @@ -27,30 +33,66 @@ if (!fs.existsSync(dest)) { fs.mkdirSync(dest); } -const download = url => +// Check if URL points to a direct .mmdb file (already extracted) +const isDirectMmdb = url.endsWith('.mmdb'); + +// Download handler for compressed tar.gz files +const downloadCompressed = url => new Promise(resolve => { https.get(url, res => { resolve(res.pipe(zlib.createGunzip({})).pipe(tar.t())); }); }); -download(url).then( - res => - new Promise((resolve, reject) => { - res.on('entry', entry => { - if (entry.path.endsWith('.mmdb')) { - const filename = path.join(dest, path.basename(entry.path)); - entry.pipe(fs.createWriteStream(filename)); - - console.log('Saved geo database:', filename); - } - }); - - res.on('error', e => { - reject(e); - }); - res.on('finish', () => { +// Download handler for direct .mmdb files +const downloadDirect = url => + new Promise((resolve, reject) => { + https.get(url, res => { + const filename = path.join(dest, path.basename(url)); + const fileStream = fs.createWriteStream(filename); + + res.pipe(fileStream); + + fileStream.on('finish', () => { + fileStream.close(); + console.log('Saved geo database:', filename); resolve(); }); - }), -); + + fileStream.on('error', e => { + reject(e); + }); + }); + }); + +// Execute download based on file type +if (isDirectMmdb) { + downloadDirect(url).catch(e => { + console.error('Failed to download geo database:', e); + process.exit(1); + }); +} else { + downloadCompressed(url).then( + res => + new Promise((resolve, reject) => { + res.on('entry', entry => { + if (entry.path.endsWith('.mmdb')) { + const filename = path.join(dest, path.basename(entry.path)); + entry.pipe(fs.createWriteStream(filename)); + + console.log('Saved geo database:', filename); + } + }); + + res.on('error', e => { + reject(e); + }); + res.on('finish', () => { + resolve(); + }); + }), + ).catch(e => { + console.error('Failed to download geo database:', e); + process.exit(1); + }); +} From e13362bfec5d4b2e6d33f56f4277bcb0d903036e Mon Sep 17 00:00:00 2001 From: Mintimate Date: Wed, 12 Nov 2025 19:18:44 +0800 Subject: [PATCH 4/4] feat(geo): add redirect support for direct .mmdb downloads --- scripts/build-geo.js | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/scripts/build-geo.js b/scripts/build-geo.js index 379f6e70..f0aedeba 100644 --- a/scripts/build-geo.js +++ b/scripts/build-geo.js @@ -45,10 +45,16 @@ const downloadCompressed = url => }); // Download handler for direct .mmdb files -const downloadDirect = url => +const downloadDirect = (url, originalUrl) => new Promise((resolve, reject) => { https.get(url, res => { - const filename = path.join(dest, path.basename(url)); + // Follow redirects + if (res.statusCode === 301 || res.statusCode === 302) { + downloadDirect(res.headers.location, originalUrl || url).then(resolve).catch(reject); + return; + } + + const filename = path.join(dest, path.basename(originalUrl || url)); const fileStream = fs.createWriteStream(filename); res.pipe(fileStream);