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 (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -5,20 +5,40 @@ 5 5 6 6 #set ($name = '') 7 7 #set ($email = '') 8 + #set ($scope = '') 9 + ## Fields to help preventing bots filled forms. 8 8 #set ($contactWebsite = '') 11 + #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))) 14 + #set ($propertyParts = $parameterName.split('_0_')) 15 + #if ($propertyParts.size() > 1) 16 + #set ($propertyName = $parameterName.split('_0_')[1]) 17 + #if ($propertyName == 'name') 18 + #set ($name = $stringtool.trim($request.get($parameterName))) 19 + #elseif ($propertyName == 'email') 20 + #set ($email = $stringtool.trim($request.get($parameterName))) 21 + #elseif ($propertyName == 'scope') 22 + #set ($scope = $stringtool.trim($request.get($parameterName))) 23 + #elseif ($propertyName == 'contactWebsite') 24 + #set ($contactWebsite = $stringtool.trim($request.get($parameterName))) 25 + #elseif ($propertyName == 'contactStartedAt') 26 + #set ($startedAtRaw = $stringtool.trim($request.get($parameterName))) 27 + #end 18 18 #end 19 19 #end 20 20 21 - #if ("$!contactWebsite.trim()" != '') 31 + #if ("$!startedAtRaw" != '') 32 + #set ($startedAt = $numbertool.toNumber($startedAtRaw)) 33 + #set ($now = $datetool.systemDate.time) 34 + #set ($elapsed = $now - $startedAt) 35 + 36 + ## Reject submissions faster than 10 seconds. 37 + #if ($elapsed > 0 && $elapsed < 10000) 38 + #set ($statusCode = 400) 39 + #set ($message = 'Please take a moment to describe your XWiki request before submitting.') 40 + #end 41 + #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" == '') ... ... @@ -30,6 +30,9 @@ 30 30 #elseif ("$!email" == '') 31 31 #set ($statusCode = 400) 32 32 #set ($message = 'Please enter your email address.') 53 + #elseif ("$!scope" == '' || $scope.length() < 30) 54 + #set ($statusCode = 400) 55 + #set ($message = 'Please add a short description of your XWiki project, question or issue.') 33 33 #else 34 34 #try('contactException') 35 35 #set ($now = $datetool.get('yyyyMMddHHmm')) ... ... @@ -40,6 +40,7 @@ 40 40 41 41 #foreach ($parameterName in $request.parameterNames) 42 42 #set ($propertyName = $parameterName.split('_0_')[1]) 66 + #if (!['contactWebsite', 'contactStartedAt'].contains($propertyName)) 43 43 #set ($discard = $contactRequestObj.set($propertyName, $request.get($parameterName))) 44 44 #end 45 45 ... ... @@ -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> 134 + <label for="Agnease.Code.ContactRequest.ContactRequestClass_0_contactWebsite">Website</label> 111 111 <input 112 112 id="contactWebsite" 113 113 type="text" 114 - name="contactWebsite" 138 + name="Agnease.Code.ContactRequest.ContactRequestClass_0_contactWebsite" 115 115 autocomplete="off" 116 116 tabindex="-1" 117 117 /> 118 118 </div> 143 + <input type="hidden" name="Agnease.Code.ContactRequest.ContactRequestClass_0_contactStartedAt" value="$datetool.systemDate.time" /> 119 119 <input id="contactSubmit" type="submit" class="btn btn-primary" value="Send my request"> 120 120 </form> 121 121 #end
- 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;