blob: e46dcfe96bd10a8415126d2d5827c48ef63525ff [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package javax.faces.webapp;
import javax.faces.application.Application;
import javax.faces.component.EditableValueHolder;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.el.ValueBinding;
import javax.faces.validator.Validator;
import javax.servlet.jsp.JspException;
import javax.servlet.jsp.tagext.Tag;
import javax.servlet.jsp.tagext.TagSupport;
/**
* Creates a validator and associates it with the nearest parent
* UIComponent. During the validation phase (or the apply-request-values
* phase for immediate components), if the associated component has any
* submitted value and the conversion of that value to the required
* type has succeeded then the specified validator type is
* invoked to test the validity of the converted value.
* <p>
* Commonly associated with an h:inputText entity, but may be applied to
* any input component.
* </p><p>
* Some validators may allow the component to use attributes to define
* component-specific validation constraints; see the f:attribute tag.
* See also the "validator" attribute of all input components, which
* allows a component to specify an arbitrary validation <i>method</i>
* (rather than a registered validation type, as this tag does).
* </p>
* Unless otherwise specified, all attributes accept static values
* or EL expressions.
*
* see Javadoc of <a href="http://java.sun.com/j2ee/javaserverfaces/1.1_01/docs/api/index.html">JSF Specification</a>
*
* @JSFJspTag
* name="f:validator"
* bodyContent="empty"
*
* @author Manfred Geiler (latest modification by $Author$)
* @version $Revision$ $Date$
*/
public class ValidatorTag
extends TagSupport
{
private static final long serialVersionUID = 8794036166323016663L;
private String _validatorId;
/**
* The registered ID of the desired Validator.
*
* @JSFJspAttribute
* required="true"
*/
public void setValidatorId(String validatorId)
{
_validatorId = validatorId;
}
public int doStartTag()
throws javax.servlet.jsp.JspException
{
UIComponentTag componentTag = UIComponentTag.getParentUIComponentTag(pageContext);
if (componentTag == null)
{
throw new JspException("no parent UIComponentTag found");
}
if (!componentTag.getCreated())
{
return Tag.SKIP_BODY;
}
Validator validator = createValidator();
UIComponent component = componentTag.getComponentInstance();
if (component == null)
{
throw new JspException("parent UIComponentTag has no UIComponent");
}
if (!(component instanceof EditableValueHolder))
{
throw new JspException("UIComponent is no ValueHolder");
}
((EditableValueHolder)component).addValidator(validator);
return Tag.SKIP_BODY;
}
public void release()
{
super.release();
_validatorId = null;
}
protected Validator createValidator()
throws JspException
{
FacesContext facesContext = FacesContext.getCurrentInstance();
Application application = facesContext.getApplication();
if (UIComponentTag.isValueReference(_validatorId))
{
ValueBinding vb = facesContext.getApplication().createValueBinding(_validatorId);
return application.createValidator((String)vb.getValue(facesContext));
}
else
{
return application.createValidator(_validatorId);
}
}
}