From 6c6e4c3414d0850bbeeefa8be8ffd08625c1f32a Mon Sep 17 00:00:00 2001 From: multipleof4 Date: Fri, 3 Oct 2025 14:31:27 -0700 Subject: [PATCH] Refactor: Loosen Gemini moderation to check for 'yes' --- functions/api/comments.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/functions/api/comments.js b/functions/api/comments.js index d7a3838..1c594d7 100644 --- a/functions/api/comments.js +++ b/functions/api/comments.js @@ -34,7 +34,7 @@ export async function onRequestPost({request,env}){ const mod=await fetch(`https://generativelanguage.googleapis.com/v1beta/models/gemini-2.5-flash-lite:generateContent?key=${env.GOOGLE_KEY}`,{method:'POST',headers:{'Content-Type':'application/json'},body:JSON.stringify({contents:[{parts:[{text:`Is this appropriate for a public forum? Respond ONLY "yes" or "no".\n\n${content}`}]}]})}); if(!mod.ok){const err=await mod.text();return json({error:{message:`Moderation failed: ${err}`}},{status:500},request)} - if((await mod.json()).candidates?.[0]?.content.parts[0].text.trim().toLowerCase()!=='yes')return json({error:{message:'Comment rejected by Gemini 2.5 Flash Lite.'}},{status:400},request); + if(!(await mod.json()).candidates?.[0]?.content.parts[0].text.trim().toLowerCase().includes('yes'))return json({error:{message:'Comment rejected by Gemini 2.5 Flash Lite.'}},{status:400},request); const{meta}=await env.D1_SPCHCAP.prepare('INSERT INTO comments(post_id,user_id,parent_id,content)VALUES(?,?,?,?)').bind(post_id,user.id,parent_id||null,content).run(); await env.D1_SPCHCAP.prepare('UPDATE posts SET comment_count=comment_count+1 WHERE id=?').bind(post_id).run();