Java tutorial
/* * < KURA, This application manages the daily activities of a Teacher and a Student of a School> * * Copyright (C) 2012 Virtusa Corporation. * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. */ package com.virtusa.akura.staff.validator; import java.util.regex.Matcher; import java.util.regex.Pattern; import org.springframework.validation.Errors; import org.springframework.validation.ValidationUtils; import org.springframework.validation.Validator; import com.virtusa.akura.api.dto.StaffCategory; import com.virtusa.akura.common.AkuraWebConstant; import com.virtusa.akura.util.ValidatorExpressionUtil; /** * This class validates the fields of the StaffCategory domain object. * * @author Virtusa Corporation */ public class StaffCategoryValidator implements Validator { /** the field name to check. */ private static final String DESCRIPTION = "description"; /** description can only have alphabet characters with space. */ private static final String REGEX_PATTERN = ""; /** attribute for holding space. */ private static final String STRING_SPACE = " "; /** attribute for holding regex for replace. */ private static final String STRING_CHECK = "( )+"; /** * Return whether or not this object can validate objects of the StaffCategory class. * * @param clazz - the class of the StaffCategory * @return - a boolean true or false */ public boolean supports(Class<?> clazz) { return StaffCategory.class.isAssignableFrom(clazz); } /** * Validates the object of the StaffCategory. * * @param target - Populated object of StaffCategory to validate * @param errors - Errors object that is building. May contain errors for the fields relating to types. */ public void validate(Object target, Errors errors) { ValidationUtils.rejectIfEmptyOrWhitespace(errors, DESCRIPTION, AkuraWebConstant.MANDATORY_FIELD_ERROR_CODE); StaffCategory staffCategory = (StaffCategory) target; String validatorPattern = ValidatorExpressionUtil.getValidatorPattern("STAFF.CATEGORY.VALIDATOR"); Pattern stringOnly = Pattern.compile(validatorPattern); String description = staffCategory.getDescription().trim(); description = description.replaceAll(STRING_CHECK, STRING_SPACE); Matcher makeMatch = stringOnly.matcher(description); if (makeMatch.find()) { errors.rejectValue(DESCRIPTION, AkuraWebConstant.MISMATCH_ERROR); } } }