GeolocationAddressPatternValidator.java
/*
* Copyright (c) 2002-2025, City of Paris
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright notice
* and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright notice
* and the following disclaimer in the documentation and/or other materials
* provided with the distribution.
*
* 3. Neither the name of 'Mairie de Paris' nor 'Lutece' nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
* License 1.0
*/
package fr.paris.lutece.plugins.forms.validation;
import java.util.List;
import org.apache.commons.lang3.StringUtils;
import fr.paris.lutece.plugins.forms.service.entrytype.EntryTypeGeolocation;
import fr.paris.lutece.plugins.genericattributes.business.Response;
/**
*
* Validator to verify the postal address pattern of a response, from an @link{EntryTypeGeolocation} entry
*
*/
public class GeolocationAddressPatternValidator extends AbstractPatternValidator
{
/**
* Constructor of the GeolocationAddressPatternValidator
*
* @param strValidatorName
* The validator bean name
* @param strValidatorDisplayName
* The validator display name
* @param listAvailableEntryType
* The list of available entrytype
*/
public GeolocationAddressPatternValidator( String strValidatorName, String strValidatorDisplayName, List<String> listAvailableEntryType )
{
super( strValidatorName, strValidatorDisplayName, listAvailableEntryType );
}
/**
* Get the value that will be verified/validated, from a given Response
*
* @param response
* The Response from which the value to validate will be extracted
*
* @return the value to validate or an empty String if no value was found
*/
@Override
protected String getValueToValidate( Response response )
{
// Get the value of the Field's code being processed
String fieldCodeName = response.getField( ).getCode( );
// The value of the postal address we want to validate is stored in the 'address' entry field
if ( fieldCodeName.equals( EntryTypeGeolocation.FIELD_ADDRESS ) )
{
return response.getResponseValue( );
}
return StringUtils.EMPTY;
}
}