Changes for page Get in Touch About Your XWiki Project
Last modified by Agnease on 2026/06/16 17:18
Summary
-
Page properties (1 modified, 0 added, 0 removed)
-
Objects (2 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -5,20 +5,37 @@ 5 5 6 6 #set ($name = '') 7 7 #set ($email = '') 8 + ## Fields to help preventing bots filled forms. 8 8 #set ($contactWebsite = '') 10 + #set ($startedAtRaw = '') 9 9 10 10 #foreach ($parameterName in $request.parameterNames) 11 - #set ($propertyName = $parameterName.split('_0_')[1]) 12 - #if ($propertyName == 'name') 13 - #set ($name = $stringtool.trim($request.get($parameterName))) 14 - #elseif ($propertyName == 'email') 15 - #set ($email = $stringtool.trim($request.get($parameterName))) 16 - #elseif ($propertyName == 'contactWebsite') 17 - #set ($contactWebsite = $stringtool.trim($request.get($parameterName))) 13 + #set ($propertyParts = $parameterName.split('_0_')) 14 + #if ($propertyParts.size() > 1) 15 + #set ($propertyName = $parameterName.split('_0_')[1]) 16 + #if ($propertyName == 'name') 17 + #set ($name = $stringtool.trim($request.get($parameterName))) 18 + #elseif ($propertyName == 'email') 19 + #set ($email = $stringtool.trim($request.get($parameterName))) 20 + #elseif ($propertyName == 'contactWebsite') 21 + #set ($contactWebsite = $stringtool.trim($request.get($parameterName))) 22 + #elseif ($propertyName == 'contactStartedAt') 23 + #set ($startedAtRaw = $stringtool.trim($request.get($parameterName))) 24 + #end 18 18 #end 19 19 #end 20 20 21 - #if ("$!contactWebsite.trim()" != '') 28 + #if ("$!startedAtRaw" != '') 29 + #set ($startedAt = $numbertool.toNumber($startedAtRaw)) 30 + #set ($now = $datetool.systemDate.time) 31 + #set ($elapsed = $now - $startedAt) 32 + 33 + ## Reject submissions faster than 10 seconds. 34 + #if ($elapsed > 0 && $elapsed < 10000) 35 + #set ($discard = $response.setStatus(400)) 36 + #jsonResponse({'message': 'Please take a moment to describe your XWiki request before submitting.'}) 37 + #end 38 + #elseif ("$!contactWebsite.trim()" != '') 22 22 #set ($statusCode = 400) 23 23 #set ($message = 'The request could not be sent. Please try again or contact Agnease by email.') 24 24 #elseif ("$!name" == '' && "$!email" == '') ... ... @@ -107,15 +107,16 @@ 107 107 <p class="xHint">* Your information will only be used to respond to this request.</p> 108 108 ## Hidden fields to catch requests filled by bots. 109 109 <div class="contact-hp-wrapper" aria-hidden="true"> 110 - <label for="contactWebsite">Website</label> 127 + <label for="Agnease.Code.ContactRequest.ContactRequestClass_0_contactWebsite">Website</label> 111 111 <input 112 112 id="contactWebsite" 113 113 type="text" 114 - name="contactWebsite" 131 + name="Agnease.Code.ContactRequest.ContactRequestClass_0_contactWebsite" 115 115 autocomplete="off" 116 116 tabindex="-1" 117 117 /> 118 118 </div> 136 + <input type="hidden" name="Agnease.Code.ContactRequest.ContactRequestClass_0_contactStartedAt" value="$datetool.getsystemDate.time" /> 119 119 <input id="contactSubmit" type="submit" class="btn btn-primary" value="Send my request"> 120 120 </form> 121 121 #end
- XWiki.JavaScriptExtension[0]
-
- code
-
... ... @@ -16,7 +16,6 @@ 16 16 errorBox.find('.box div p').text(''); 17 17 18 18 submitButton.prop('disabled', true); 19 - console.log(form.serializeArray()) 20 20 21 21 $.post({ 22 22 url: serviceURL,
- XWiki.StyleSheetExtension[0]
-
- code
-
... ... @@ -67,7 +67,7 @@ 67 67 font-weight: 700; 68 68 } 69 69 /* CSS for hidden field to identify requests filled by bots. */ 70 -.contact-hp-wrapper ss{70 +.contact-hp-wrapper { 71 71 position: absolute; 72 72 left: -9999px; 73 73 width: 1px;