From f6fab6abfb02b1a76c71405f46a880e170338b8f Mon Sep 17 00:00:00 2001 From: multipleof4 Date: Wed, 21 Jan 2026 16:07:03 -0800 Subject: [PATCH] Feat: Add ntfy alert for user login --- functions/api/login.js | 3 +++ 1 file changed, 3 insertions(+) diff --git a/functions/api/login.js b/functions/api/login.js index d885f4b..11cd9fc 100644 --- a/functions/api/login.js +++ b/functions/api/login.js @@ -4,6 +4,7 @@ const json = (d, o = {}) => { return new Response(JSON.stringify(d), { ...o, headers: h }); }; const tsEq=(a,b)=>{let d=a.length^b.length;for(let i=0;i{if(!url)return;const target=url.startsWith('http')?url:`https://${url}`;fetch(target,{method:'POST',body:msg,headers:{'X-Priority':prio.toString()}}).catch(()=>{})}; export async function onRequestPost({ request, env }) { try { @@ -21,6 +22,8 @@ export async function onRequestPost({ request, env }) { const user = await env.D1_SPCHCAP.prepare('SELECT id, pass_hash, role FROM users WHERE username = ?').bind(username).first(); if (!user || !tsEq(user.pass_hash, pass_hash)) return json({ error: 'Invalid credentials' }, { status: 401 }); + notify(env.NTFY_URL, `User Login: ${username}`, 3); + const exp = new Date(Date.now() + 2592e6); // 30 days const opts = `Domain=.speech.capital; Path=/; Expires=${exp.toUTCString()}; HttpOnly; Secure; SameSite=Strict`; const headers = new Headers();