/** * The contents of this file are subject to the OpenMRS Public License * Version 1.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://license.openmrs.org * * Software distributed under the License is distributed on an "AS IS" * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the * License for the specific language governing rights and limitations * under the License. * * Copyright (C) OpenMRS, LLC. All Rights Reserved. */ package org.openmrs.util; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.Date; import java.util.Locale; import java.util.regex.Matcher; import java.util.regex.Pattern; /** * An extension of SimpleDateFormat that defaults to setLenient(true) and rejects * parsing any dates that don't have a 4-digit year */ public class OpenmrsDateFormat extends SimpleDateFormat { private static final long serialVersionUID = 1L; public OpenmrsDateFormat(SimpleDateFormat sdf, Locale locale) { super(sdf.toPattern(), locale); this.setLenient(false); } public Date parse(String text) throws ParseException { // first test to see if the pattern ends in "{non-alphanumeric-character}yyyy" Matcher patternMatch = Pattern.compile("\\Wyyyy$").matcher(this.toPattern()); if (patternMatch.find()) { // if it does, make sure that the string to parse ends in "{non-alphanumeric-character}{digit}{digit}{digit}{digit}" Matcher dateMatch = Pattern.compile("\\W\\d{4}$").matcher(text); if (!dateMatch.find()) { throw new ParseException("Unparseable date \"" + text + "\" - year must have 4 digits", 0); } } // otherwise, verify that the pattern and the string are the same length else { if (this.toPattern().length() != text.length()) { throw new ParseException("Unparseable date \"" + text + "\" - length of date string doesn't match length of date pattern", 0); } } // if we've passed this validation, just call the SimpleDateFormat.parse() method return super.parse(text); } }