All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.databene.domain.us.SSNValidator Maven / Gradle / Ivy

/*
 * (c) Copyright 2008-2009 by Volker Bergmann. All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, is permitted under the terms of the
 * GNU General Public License.
 *
 * For redistributing this software or a derivative work under a license other
 * than the GPL-compatible Free Software License as defined by the Free
 * Software Foundation or approved by OSI, you must first obtain a commercial
 * license to this software product from Volker Bergmann.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * WITHOUT A WARRANTY OF ANY KIND. ALL EXPRESS OR IMPLIED CONDITIONS,
 * REPRESENTATIONS AND WARRANTIES, INCLUDING ANY IMPLIED WARRANTY OF
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT, ARE
 * HEREBY EXCLUDED. IN NO EVENT SHALL THE COPYRIGHT OWNER 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.
 */

package org.databene.domain.us;

import javax.validation.ConstraintValidator;
import javax.validation.ConstraintValidatorContext;

import org.databene.commons.StringUtil;
import org.databene.commons.Validator;

/**
 * Validates US Social Security Numbers.
*
* Created at 17.11.2008 07:08:34 * @since 0.5.6 * @author Volker Bergmann * @see "http://en.wikipedia.org/wiki/Social_security_number" * @see "http://www.socialsecurity.gov/history/ssn/geocard.html" * @see "http://www.socialsecurity.gov/employer/stateweb.htm" * @see "http://www.socialsecurity.gov/employer/ssnvhighgroup.htm" */ public class SSNValidator implements ConstraintValidator, Validator { private int maxAreaCode; public SSNValidator() { this(SSN.DEFAULT_MAX_AREA_CODE); } public SSNValidator(int maxAreaCode) { this.maxAreaCode = maxAreaCode; } public void initialize(SSN parameters) { this.maxAreaCode = parameters.maxAreaCode(); } public boolean isValid(String ssn, ConstraintValidatorContext context) { return valid(ssn); } public boolean valid(String ssn) { if (ssn == null || ssn.length() != 11) return false; String[] tokens = StringUtil.tokenize(ssn, '-'); if (tokens.length != 3) return false; try { // validate area number if (tokens[0].length() != 3) return false; int areaNumber = Integer.parseInt(tokens[0]); // Currently, a valid SSN cannot have an area number between 734 and 749, or above 772, // the highest area number which the Social Security Administration has allocated if (areaNumber < 1 || areaNumber == 666 || areaNumber > maxAreaCode || (areaNumber > 733 && areaNumber < 750)) return false; // validate group number if (tokens[1].length() != 2) return false; int groupNumber = Integer.parseInt(tokens[1]); if (groupNumber < 1) return false; // validate serial number if (tokens[2].length() != 4) return false; int serialNumber = Integer.parseInt(tokens[2]); if (serialNumber < 1) return false; // Numbers from 987-65-4320 to 987-65-4329 are reserved for use in advertisements if (areaNumber == 987 && areaNumber == 65 && (serialNumber >= 4320 && serialNumber <= 4329)) return false; } catch (NumberFormatException e) { return false; } return true; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy