=================================================================== RCS file: /cvs/cvs/draft/form.min.js,v retrieving revision 1.47 retrieving revision 1.95 diff -u -p -r1.47 -r1.95 --- draft/form.min.js 2024/03/29 19:58:37 1.47 +++ draft/form.min.js 2024/03/31 16:51:24 1.95 @@ -1,91 +1,86 @@ const form = document.querySelector("#cform"); -function validateEmail(email) { - const regex = /^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*$/; +function parseString(str) { + return str.replace(/[~`!@#$%^&*(){}\[\];:"'<,.>?\/\\|+=-]/g, '_'); +} + +function parseMail(email) { + return email.toLowerCase().slice(0,96); +} + +function validateMail(email) { + const regex = /^[a-z0-9._%+-]+@[a-z0-9.-]+(\.[a-z]{2,})+$/; return regex.test(email); }; -function validateSubject(subject) { - return (subject.length>5); +function parseSubj(subject) { + return parseString(subject).slice(0,96); } -function validateMsg(msg) { - return (msg.length>5); +function validateSubj(subject) { + return (subject.length>3); } +function parseMess(msg) { + return parseString(msg).slice(0,3904); +} + +function validateMess(msg) { + return (msg.length>3); +} + async function sendData() { - var er = 0; - em = document.getElementById("cfem").value, - su = document.getElementById("cfsu").value, - ms = document.getElementById("cfme").value, - ii = document.getElementById("cfinfo"); - er=validateEmail(em)?er:++er; - er=validateSubject(su)?er:++er; - er=validateMsg(ms)?er:++er; - if(er){ - ii.textContent="One or more fields have an error. Please check and try again."; + var erro = 0, + info = document.getElementById("cfinfo"), + mail = parseMail(document.getElementById("cfem").value), + subj = parseSubj(document.getElementById("cfsu").value), + mess = parseMess(document.getElementById("cfme").value); + + erro=validateMail(mail)?erro:++erro; + erro=validateSubj(subj)?erro:++erro; + erro=validateMess(mess)?erro:++erro; + + if(erro) { + info.textContent="One or more fields have an error. Please check and try again." } else { - var fc = document.querySelectorAll(".wpcf7-form-control"); - ii.textContent="All good."; - fc.forEach((f) => { + var fcon = document.querySelectorAll(".wpcf7-form-control"), + + info.textContent="Verifying..." + fcon.forEach((f) => { f.disabled=true; l=f; }); l.style.visibility="hidden"; turnstile.ready(function() { turnstile.render('#cfcontainer', { + retry: 'never', theme: 'light', - sitekey: '0x4AAAAAAAVpXFEy152AON1L', 'response-field': false, - retry: 'never', + sitekey: '0x4AAAAAAAVpXFEy152AON1L', 'error-callback': function(e) { + info.textContent="Verification error. Try again later."; turnstile.remove(); }, callback: function(token) { - ii.textContent="Sent"; - console.log(`Challenge Success ${token}`); -/* --------------------- */ -const ob = {mail: em, sub: su, msg: ms, id: token }; -var data="", - status="", - feed=JSON.stringify(ob); -$.post("/feedbk/", feed, function(data, status){ - console.log("Data: " + data + "\nStatus: " + status); -}); -/* --------------------- */ -//ovar re=""; -//const dataToSend = JSON.stringify({"email": "hey@mail.com", "password": "101010"}); -//let dataReceived = ""; -//fetch("/feedbk/", { -// credentials: "same-origin", -// mode: "same-origin", -// method: "post", -// headers: { "Content-Type": "application/json" }, -// body: dataToSend -//}) -// .then(resp => { -// if (resp.status === 200) { -// return resp.json() -// } else { -// console.log("Status: " + resp.status) -// return Promise.reject("server") -// } -// }) -// .then(dataJson => { -// dataReceived = JSON.parse(dataJson) -// }) -// .catch(err => { -// if (err === "server") return -// console.log(err) -// }) -//console.log(`Received: ${dataReceived}`) - - - }, + const data = JSON.stringify({"add": mail, "sub": subj, "msg": mess, "tok": token}); + turnstile.remove(); + info.textContent="Sending..."; + console.log(data); +// fetch("/feedbk/", { +// headers: { "Content-Type": "application/json" }, +// credentials: "same-origin", +// mode: "same-origin", +// method: "post", +// body: data +// }) +// .then(response => response.json()) +// .then(json => info.textContent=json['msg']) + + } }); }); - } -}; + }; +} form.addEventListener("submit", (event) => { event.preventDefault();