#843: Add readonly field and update the layout of the assignment
This commit is contained in:
		| @ -34,7 +34,7 @@ public class BypassRestrictionsFieldRestrictions extends AssignmentEndpoint { | |||||||
|  |  | ||||||
|     @PostMapping("/BypassRestrictions/FieldRestrictions") |     @PostMapping("/BypassRestrictions/FieldRestrictions") | ||||||
|     @ResponseBody |     @ResponseBody | ||||||
|     public AttackResult completed(@RequestParam String select, @RequestParam String radio, @RequestParam String checkbox, @RequestParam String shortInput) { |     public AttackResult completed(@RequestParam String select, @RequestParam String radio, @RequestParam String checkbox, @RequestParam String shortInput, @RequestParam String readOnlyInput) { | ||||||
|         if (select.equals("option1") || select.equals("option2")) { |         if (select.equals("option1") || select.equals("option2")) { | ||||||
|             return failed(this).build(); |             return failed(this).build(); | ||||||
|         } |         } | ||||||
| @ -47,6 +47,9 @@ public class BypassRestrictionsFieldRestrictions extends AssignmentEndpoint { | |||||||
|         if (shortInput.length() <= 5) { |         if (shortInput.length() <= 5) { | ||||||
|             return failed(this).build(); |             return failed(this).build(); | ||||||
|         } |         } | ||||||
|  |         if ("change".equals(readOnlyInput)) { | ||||||
|  |             return failed(this).build(); | ||||||
|  |         } | ||||||
|         return success(this).build(); |         return success(this).build(); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -0,0 +1,5 @@ | |||||||
|  | .bypass-input-container { | ||||||
|  |     position: relative; | ||||||
|  |     padding: 7px; | ||||||
|  |     margin-top: 7px; | ||||||
|  | } | ||||||
| @ -1,6 +1,6 @@ | |||||||
| <!DOCTYPE html> | <!DOCTYPE html> | ||||||
|  |  | ||||||
| <html xmlns:th="http://www.thymeleaf.org"> | <html xmlns:th="http://www.thymeleaf.org" xmlns="http://www.w3.org/1999/html"> | ||||||
|  |  | ||||||
| <div class="lesson-page-wrapper"> | <div class="lesson-page-wrapper"> | ||||||
|     <!-- reuse this lesson-page-wrapper block for each 'page' of content in your lesson --> |     <!-- reuse this lesson-page-wrapper block for each 'page' of content in your lesson --> | ||||||
| @ -12,28 +12,47 @@ | |||||||
| <div class="lesson-page-wrapper"> | <div class="lesson-page-wrapper"> | ||||||
|     <!-- stripped down without extra comments --> |     <!-- stripped down without extra comments --> | ||||||
|     <div class="adoc-content" th:replace="doc:BypassRestrictions_FieldRestrictions.adoc"></div> |     <div class="adoc-content" th:replace="doc:BypassRestrictions_FieldRestrictions.adoc"></div> | ||||||
|  |     <link rel="stylesheet" type="text/css" th:href="@{/lesson_css/bypass-restrictions.css}"/> | ||||||
|     <div class="attack-container"> |     <div class="attack-container"> | ||||||
|         <div class="assignment-success"><i class="fa fa-2 fa-check hidden" aria-hidden="true"></i></div> |         <div class="assignment-success"><i class="fa fa-2 fa-check hidden" aria-hidden="true"></i></div> | ||||||
|  |         <div class="container-fluid"> | ||||||
|             <form class="attack-form" accept-charset="UNKNOWN" name="fieldRestrictions" |             <form class="attack-form" accept-charset="UNKNOWN" name="fieldRestrictions" | ||||||
|                   method="POST" |                   method="POST" | ||||||
|                   action="/WebGoat/BypassRestrictions/FieldRestrictions"> |                   action="/WebGoat/BypassRestrictions/FieldRestrictions"> | ||||||
|  |  | ||||||
|                 <div>Select field with two possible values</div> |                 <div class="bypass-input-container"><b>Select field with two possible value</b> | ||||||
|  |                     <div class="input-group"> | ||||||
|                         <select name="select"> |                         <select name="select"> | ||||||
|                             <option value="option1">Option 1</option> |                             <option value="option1">Option 1</option> | ||||||
|                             <option value="option2">Option 2</option> |                             <option value="option2">Option 2</option> | ||||||
|                         </select> |                         </select> | ||||||
|                 <div>Radio button with two possible values</div> |                     </div> | ||||||
|  |                 </div> | ||||||
|  |                 <div class="bypass-input-container"><b>Radio button with two possible values</b> | ||||||
|  |                     <div class="input-group"> | ||||||
|                         <input type="radio" name="radio" value="option1" checked="checked"/> Option 1<br/> |                         <input type="radio" name="radio" value="option1" checked="checked"/> Option 1<br/> | ||||||
|                         <input type="radio" name="radio" value="option2"/> Option 2<br/> |                         <input type="radio" name="radio" value="option2"/> Option 2<br/> | ||||||
|                 <div>Checkbox: value either on or off</div> |                     </div> | ||||||
|                 <input type="checkbox" name="checkbox" checked="checked"/> Checkbox |                 </div> | ||||||
|                 <div>Input restricted to max 5 characters</div> |                 <div class="bypass-input-container"><b>Checkbox: value either on or off</b> | ||||||
|                 <input type="text" value="12345" name="shortInput" maxlength="5"/> |                     <div class="input-group"> | ||||||
|                 <div>Disabled input field</div> |                         <input type="checkbox" name="checkbox" checked="checked"> Checkbox</input> | ||||||
|                 <input type="submit" value="submit"/> |                     </div> | ||||||
|  |                 </div> | ||||||
|  |                 <div class="bypass-input-container"><b>Input restricted to max 5 characters</b> | ||||||
|  |                     <div class="input-group"><input type="text" value="12345" name="shortInput" maxlength="5"/> | ||||||
|  |                     </div> | ||||||
|  |                 </div> | ||||||
|  |                 <div class="bypass-input-container"><b>Readonly input field</b> | ||||||
|  |                     <div class="input-group"> | ||||||
|  |                         <input type="text" value="change" readonly="readonly" name="readOnlyInput"/> | ||||||
|  |                     </div> | ||||||
|  |                 </div> | ||||||
|  |                 <br> | ||||||
|  |                 <input type="submit" class="btn btn-primary" value="Submit"/> | ||||||
|             </form> |             </form> | ||||||
|  |         </div> | ||||||
|  |         <br/> | ||||||
|         <div class="attack-feedback"></div> |         <div class="attack-feedback"></div> | ||||||
|         <div class="attack-output"></div> |         <div class="attack-output"></div> | ||||||
|     </div> |     </div> | ||||||
| @ -66,7 +85,8 @@ | |||||||
|                 <textarea cols="25" name="field3" rows="1">abc 123 ABC</textarea> |                 <textarea cols="25" name="field3" rows="1">abc 123 ABC</textarea> | ||||||
|             </div> |             </div> | ||||||
|             <p></p> |             <p></p> | ||||||
|                 <div><strong>Field 4:</strong> enumeration of numbers (^(one|two|three|four|five|six|seven|eight|nine)$)</div> |             <div><strong>Field 4:</strong> enumeration of numbers (^(one|two|three|four|five|six|seven|eight|nine)$) | ||||||
|  |             </div> | ||||||
|             <div> |             <div> | ||||||
|                 <textarea cols="25" name="field4" rows="1">seven</textarea> |                 <textarea cols="25" name="field4" rows="1">seven</textarea> | ||||||
|             </div> |             </div> | ||||||
| @ -86,7 +106,9 @@ | |||||||
|                 <textarea cols="25" name="field7" rows="1">301-604-4882</textarea> |                 <textarea cols="25" name="field7" rows="1">301-604-4882</textarea> | ||||||
|             </div> |             </div> | ||||||
|             <input type="hidden" value="" name="error"/> |             <input type="hidden" value="" name="error"/> | ||||||
|                 <p><button type="submit" class="btn btn-primary">Submit</button></p> |             <p> | ||||||
|  |                 <button type="submit" class="btn btn-primary">Submit</button> | ||||||
|  |             </p> | ||||||
|         </form> |         </form> | ||||||
|  |  | ||||||
|         <script> |         <script> | ||||||
| @ -100,13 +122,34 @@ | |||||||
|             var validate = function () { |             var validate = function () { | ||||||
|                 var msg = 'JavaScript found form errors'; |                 var msg = 'JavaScript found form errors'; | ||||||
|                 var err = 0; |                 var err = 0; | ||||||
|               if (!regex1.test(document.frontendValidation.field1.value)) {err+=1; msg+='\n  Value entered for field 1 is not correct';} |                 if (!regex1.test(document.frontendValidation.field1.value)) { | ||||||
|               if (!regex2.test(document.frontendValidation.field2.value)) {err+=1; msg+='\n  Value entered for field 2 is not correct';} |                     err += 1; | ||||||
|               if (!regex3.test(document.frontendValidation.field3.value)) {err+=1; msg+='\n  Value entered for field 3 is not correct';} |                     msg += '\n  Value entered for field 1 is not correct'; | ||||||
|               if (!regex4.test(document.frontendValidation.field4.value)) {err+=1; msg+='\n  Value entered for field 4 is not correct';} |                 } | ||||||
|               if (!regex5.test(document.frontendValidation.field5.value)) {err+=1; msg+='\n  Value entered for field 5 is not correct';} |                 if (!regex2.test(document.frontendValidation.field2.value)) { | ||||||
|               if (!regex6.test(document.frontendValidation.field6.value)) {err+=1; msg+='\n  Value entered for field 6 is not correct';} |                     err += 1; | ||||||
|               if (!regex7.test(document.frontendValidation.field7.value)) {err+=1; msg+='\n  Value entered for field 7 is not correct';} |                     msg += '\n  Value entered for field 2 is not correct'; | ||||||
|  |                 } | ||||||
|  |                 if (!regex3.test(document.frontendValidation.field3.value)) { | ||||||
|  |                     err += 1; | ||||||
|  |                     msg += '\n  Value entered for field 3 is not correct'; | ||||||
|  |                 } | ||||||
|  |                 if (!regex4.test(document.frontendValidation.field4.value)) { | ||||||
|  |                     err += 1; | ||||||
|  |                     msg += '\n  Value entered for field 4 is not correct'; | ||||||
|  |                 } | ||||||
|  |                 if (!regex5.test(document.frontendValidation.field5.value)) { | ||||||
|  |                     err += 1; | ||||||
|  |                     msg += '\n  Value entered for field 5 is not correct'; | ||||||
|  |                 } | ||||||
|  |                 if (!regex6.test(document.frontendValidation.field6.value)) { | ||||||
|  |                     err += 1; | ||||||
|  |                     msg += '\n  Value entered for field 6 is not correct'; | ||||||
|  |                 } | ||||||
|  |                 if (!regex7.test(document.frontendValidation.field7.value)) { | ||||||
|  |                     err += 1; | ||||||
|  |                     msg += '\n  Value entered for field 7 is not correct'; | ||||||
|  |                 } | ||||||
|                 document.frontendValidation.error.value = err |                 document.frontendValidation.error.value = err | ||||||
|                 if (err > 0) { |                 if (err > 0) { | ||||||
|                     alert(msg) |                     alert(msg) | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user