<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">

<head>
<meta http-equiv=Content-Type content="text/html; charset=us-ascii">
<meta name=Generator content="Microsoft Word 12 (filtered medium)">
<style>
<!--
 /* Font Definitions */
 @font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:Tahoma;
        panose-1:2 11 6 4 3 5 4 4 2 4;}
@font-face
        {font-family:"Book Antiqua";
        panose-1:2 4 6 2 5 3 5 3 3 4;}
 /* Style Definitions */
 p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
span.EmailStyle17
        {mso-style-type:personal;
        font-family:"Book Antiqua","serif";
        color:black;
        font-weight:normal;
        font-style:normal;
        text-decoration:none none;}
span.EmailStyle18
        {mso-style-type:personal-reply;
        font-family:"Calibri","sans-serif";
        color:#1F497D;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page Section1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.Section1
        {page:Section1;}
-->
</style>
<!--[if gte mso 9]><xml>
 <o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
 <o:shapelayout v:ext="edit">
  <o:idmap v:ext="edit" data="1" />
 </o:shapelayout></xml><![endif]-->
</head>

<body lang=EN-US link=blue vlink=purple>

<div class=Section1>

<p class=MsoNormal><span style='color:#1F497D'>ESAPI hasn&#8217;t gone this far
yet.&nbsp; On the one hand, it would be great if developers had a&nbsp;
standard, consistent, understandable way to report error messages (and other
security-to-human interfaces).&nbsp; &nbsp;But to date, we have only gone as far
as giving the developer a detailed error message, an error list manager to
collect multiple errors, and some protection against shooting themselves in the
foot in ESAPIResponse. <o:p></o:p></span></p>

<p class=MsoNormal><span style='color:#1F497D'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal><span style='color:#1F497D'>Every framework presumably
already has a way to report errors to users, and I&#8217;m not sure it&#8217;s
a good idea to try to create another one.&nbsp; That said, I think some guidance
on hooking ESAPI up to frameworks for this purpose would be great.&nbsp; For
example, you might put the Validation message in an HttpServletRequest
attribute, and then set up a standard error page in web.xml that pulls the
error message and displays it nicely.&nbsp; Something more complex like
highlighting form-fields that are in error is a bit more complex and tied into
the framework itself, but really it&#8217;s just checking the ValidationErrorList
as you&#8217;re rendering the page.<o:p></o:p></span></p>

<div>

<p class=MsoNormal><span style='color:#1F497D'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal><span style='color:#1F497D'>--Jeff<o:p></o:p></span></p>

<p class=MsoNormal><span style='color:#1F497D'><o:p>&nbsp;</o:p></span></p>

</div>

<p class=MsoNormal><span style='color:#1F497D'><o:p>&nbsp;</o:p></span></p>

<div>

<div style='border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in'>

<p class=MsoNormal><b><span style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'>From:</span></b><span
style='font-size:10.0pt;font-family:"Tahoma","sans-serif"'>
esapi-user-bounces@lists.owasp.org [mailto:esapi-user-bounces@lists.owasp.org] <b>On
Behalf Of </b>Boberski, Michael [USA]<br>
<b>Sent:</b> Monday, April 26, 2010 10:56 AM<br>
<b>To:</b> ESAPI-Users<br>
<b>Subject:</b> [Esapi-user] Has anyone created a &quot;UserEffect&quot; kind
of ESAPIcontrol...<o:p></o:p></span></p>

</div>

</div>

<p class=MsoNormal><o:p>&nbsp;</o:p></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'>&#8230; that triggers on failures, regardless of IntrusionDetector
use/configuration?<o:p></o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'>E.g., to wrap HTTP 500 error message generation, or e.g. to do a
lookup for some kind of context-specific error to display on a user form, and hook
this up to other ESAPI controls?<o:p></o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'>E.g.,<o:p></o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal style='margin-left:.5in'><span style='font-size:8.0pt;
font-family:"Courier New";color:black'>if( !validator.isValidXX() ) {<o:p></o:p></span></p>

<p class=MsoNormal style='margin-left:.5in'><span style='font-size:8.0pt;
font-family:"Courier New";color:black'>&nbsp;&nbsp;&nbsp;
ESAPI.effect().rejectUserInput(); //maybe, generate an HTTP 500, cause a form
error, ?<o:p></o:p></span></p>

<p class=MsoNormal style='margin-left:.5in'><span style='font-size:8.0pt;
font-family:"Courier New";color:black'>}<o:p></o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'>This would be towards the end of standardizing how e.g. user input
validation failures (ESAPI isWhatever failures and failures causing exceptions
to be thrown more generally) should be handled. I think by adding an interface
to ESAPI might help proactively answer (and promote the wrapping and
standardization of security-relevant behaviors inside of ESAPI) what is one of
the first questions dev teams ask me on how to use ESAPI. <o:p></o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'>If I&#8217;m missing something obvious, please be kind, and
explain what the/a preferred approach <i>using ESAPI</i> is, to wrap and
standardize such things for an application, generally/according to best
practices.<o:p></o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'>Best,</span><span style='font-size:12.0pt;color:black'><o:p></o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'><o:p>&nbsp;</o:p></span></p>

<p class=MsoNormal><span style='font-size:12.0pt;font-family:"Book Antiqua","serif";
color:black'>Mike B.<o:p></o:p></span></p>

</div>

</body>

</html>