aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/at
diff options
context:
space:
mode:
Diffstat (limited to 'src/main/java/at')
-rw-r--r--src/main/java/at/knowcenter/wag/egov/egiz/pdf/EGIZDate.java340
1 files changed, 185 insertions, 155 deletions
diff --git a/src/main/java/at/knowcenter/wag/egov/egiz/pdf/EGIZDate.java b/src/main/java/at/knowcenter/wag/egov/egiz/pdf/EGIZDate.java
index 7b71d27..8b8475c 100644
--- a/src/main/java/at/knowcenter/wag/egov/egiz/pdf/EGIZDate.java
+++ b/src/main/java/at/knowcenter/wag/egov/egiz/pdf/EGIZDate.java
@@ -17,9 +17,15 @@
*/
package at.knowcenter.wag.egov.egiz.pdf;
+import java.text.ParseException;
+import java.util.Calendar;
+import java.util.Date;
+import java.util.GregorianCalendar;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
+import org.apache.commons.lang.time.DateUtils;
+
/**
* Represents a signature date and the signing time as can be found in the
* SIG_DATE field.
@@ -30,160 +36,184 @@ import java.util.regex.Pattern;
*
* @author wprinz
*/
-public class EGIZDate
-{
-
- /**
- * The year.
- */
- protected int year;
-
- /**
- * The month.
- */
- protected int month;
-
- /**
- * The day.
- */
- protected int day;
-
- /**
- * The hour.
- */
- protected int hour;
-
- /**
- * The minute.
- */
- protected int minute;
-
- /**
- * The second.
- */
- protected int second;
-
- /**
- * Constructor that fills the date with values.
- *
- * @param year
- * The year.
- * @param month
- * The month.
- * @param day
- * The day.
- * @param hour
- * The hour.
- * @param minute
- * The minute.
- * @param second
- * The second.
- */
- public EGIZDate(int year, int month, int day, int hour, int minute, int second)
- {
- this.year = year;
- this.month = month;
- this.day = day;
- this.hour = hour;
- this.minute = minute;
- this.second = second;
- }
-
- /**
- * Parses the date information from a given date value.
- *
- * <p>
- * Usually the date value is one extracted from the value of the SIG_DATE
- * field.
- * </p>
- *
- * @param date_value
- * The date value String.
- * @return Returns the parsed EGIZDate. An IllegalArgumentException is thrown
- * if the date String has an illegal format.
- */
- public static EGIZDate parseFromString(String date_value)
- {
- // find the according RFC standard and cite it
-
- // BKU writes a Z after the date for some reason.
- Pattern date_pattern = Pattern.compile("^\\d\\d\\d\\d-\\d\\d-\\d\\dT\\d\\d:\\d\\d:\\d\\d[Z]?$");
- Matcher date_matcher = date_pattern.matcher(date_value);
- if (!date_matcher.matches())
- {
- throw new IllegalArgumentException("The date_value (" + date_value + " has an illegal format.");
- }
- // for some strange reasons capture groups don't work
-
- int year = Integer.parseInt(date_value.substring(0, 4));
- int month = Integer.parseInt(date_value.substring(5, 7));
- int day = Integer.parseInt(date_value.substring(8, 10));
- int hour = Integer.parseInt(date_value.substring(11, 13));
- int minute = Integer.parseInt(date_value.substring(14, 16));
- int second = Integer.parseInt(date_value.substring(17, 19));
-
- return new EGIZDate(year, month, day, hour, minute, second);
- }
-
- /**
- * @see java.lang.Object#equals(java.lang.Object)
- */
- public boolean equals(Object obj)
- {
- if (!(obj instanceof EGIZDate))
- {
- return false;
- }
-
- return toString().equals(obj.toString());
- }
-
- /**
- * @see java.lang.Object#hashCode()
- */
- public int hashCode()
- {
- return toString().hashCode();
- }
-
- /**
- * @see java.lang.Object#toString()
- */
- public String toString()
- {
- return "parsed date = " + year + "-" + month + "-" + day + "T" + hour + ":" + minute + ":" + second;
- }
-
- /**
- * Converts the date to a long integer.
- *
- * <p>
- * An earlier date is lower than a later date.
- * </p>
- * <p>
- * E.g. a date in 1999 will get a smaller number than a date in 2006.
- * </p>
- *
- * @return Returns the compareable long.
- */
- protected long toCompareableLong()
- {
- return +this.year * 12 * 31 * 24 * 60 * 60 + this.month * 31 * 24 * 60 * 60 + this.day * 24 * 60 * 60 + this.hour * 60 * 60 + this.minute * 60 + this.second;
- }
-
- /**
- * Compares this EGIZDate to another EXIZDate.
- *
- * @param other
- * The other EGIZDate.
- * @return Returns negative if this date is earlier (lower) than the other
- * date. Returns 0 if both dates are equal. Returns positive if this
- * date is later (higher) than the other date.
- */
- public int compareTo(EGIZDate other)
- {
- long diff = toCompareableLong() - other.toCompareableLong();
- return (int) diff;
- }
+public class EGIZDate {
+
+ /**
+ * The year.
+ */
+ protected int year;
+
+ /**
+ * The month.
+ */
+ protected int month;
+
+ /**
+ * The day.
+ */
+ protected int day;
+
+ /**
+ * The hour.
+ */
+ protected int hour;
+
+ /**
+ * The minute.
+ */
+ protected int minute;
+
+ /**
+ * The second.
+ */
+ protected int second;
+
+ /**
+ * Constructor that fills the date with values.
+ *
+ * @param year
+ * The year.
+ * @param month
+ * The month.
+ * @param day
+ * The day.
+ * @param hour
+ * The hour.
+ * @param minute
+ * The minute.
+ * @param second
+ * The second.
+ */
+ public EGIZDate(int year, int month, int day, int hour, int minute,
+ int second) {
+ this.year = year;
+ this.month = month;
+ this.day = day;
+ this.hour = hour;
+ this.minute = minute;
+ this.second = second;
+ }
+
+ /**
+ * Parses the date information from a given date value.
+ *
+ * <p>
+ * Usually the date value is one extracted from the value of the SIG_DATE
+ * field.
+ * </p>
+ *
+ * @param date_value
+ * The date value String.
+ * @return Returns the parsed EGIZDate. An IllegalArgumentException is
+ * thrown if the date String has an illegal format.
+ */
+ public static EGIZDate parseFromString(String date_value) {
+ // find the according RFC standard and cite it
+
+ /*
+ * Pattern date_pattern =
+ * Pattern.compile("^\\d\\d\\d\\d-\\d\\d-\\d\\dT\\d\\d:\\d\\d:\\d\\d(Z|((\\+|\\-)\\d\\d:\\d\\d))?$");
+ * Matcher date_matcher = date_pattern.matcher(date_value); if
+ * (!date_matcher.matches()) { throw new IllegalArgumentException("The
+ * date_value (" + date_value + ") has an illegal format."); } // for
+ * some strange reasons capture groups don't work
+ *
+ * int year = Integer.parseInt(date_value.substring(0, 4)); int month =
+ * Integer.parseInt(date_value.substring(5, 7)); int day =
+ * Integer.parseInt(date_value.substring(8, 10)); int hour =
+ * Integer.parseInt(date_value.substring(11, 13)); int minute =
+ * Integer.parseInt(date_value.substring(14, 16)); int second =
+ * Integer.parseInt(date_value.substring(17, 19)); return new
+ * EGIZDate(year, month, day, hour, minute, second);
+ */
+
+ String[] parsePatterns = { "yyyy-MM-dd'T'HH:mm:ss",
+ "yyyy-MM-dd'T'HH:mm:ssZ", "yyyy-MM-dd'T'HH:mm:ssZZ" };
+ if (date_value.length() > 19) {
+ int li = date_value.lastIndexOf(":");
+ if (li >= 19) {
+ date_value = new StringBuffer(date_value).deleteCharAt(li).toString();
+ }
+ if (date_value.endsWith("Z")) {
+ date_value = date_value.substring(0, date_value.length()-2) + "UTC";
+ }
+ } else {
+ date_value += "UTC";
+ }
+
+ Date date;
+ try {
+ date = DateUtils.parseDate(date_value, parsePatterns);
+ } catch (ParseException e) {
+ throw new IllegalArgumentException("The date_value (" + date_value
+ + ") has an illegal format.");
+ }
+ Calendar calendar = new GregorianCalendar();
+ calendar.setTime(date);
+
+ return new EGIZDate(calendar.get(Calendar.YEAR), calendar
+ .get(Calendar.MONTH), calendar.get(Calendar.DAY_OF_MONTH),
+ calendar.get(Calendar.HOUR), calendar.get(Calendar.MINUTE),
+ calendar.get(Calendar.SECOND));
+
+ }
+
+ /**
+ * @see java.lang.Object#equals(java.lang.Object)
+ */
+ public boolean equals(Object obj) {
+ if (!(obj instanceof EGIZDate)) {
+ return false;
+ }
+
+ return toString().equals(obj.toString());
+ }
+
+ /**
+ * @see java.lang.Object#hashCode()
+ */
+ public int hashCode() {
+ return toString().hashCode();
+ }
+
+ /**
+ * @see java.lang.Object#toString()
+ */
+ public String toString() {
+ return "parsed date = " + year + "-" + month + "-" + day + "T" + hour
+ + ":" + minute + ":" + second;
+ }
+
+ /**
+ * Converts the date to a long integer.
+ *
+ * <p>
+ * An earlier date is lower than a later date.
+ * </p>
+ * <p>
+ * E.g. a date in 1999 will get a smaller number than a date in 2006.
+ * </p>
+ *
+ * @return Returns the compareable long.
+ */
+ protected long toCompareableLong() {
+ return +this.year * 12 * 31 * 24 * 60 * 60 + this.month * 31 * 24 * 60
+ * 60 + this.day * 24 * 60 * 60 + this.hour * 60 * 60
+ + this.minute * 60 + this.second;
+ }
+
+ /**
+ * Compares this EGIZDate to another EXIZDate.
+ *
+ * @param other
+ * The other EGIZDate.
+ * @return Returns negative if this date is earlier (lower) than the other
+ * date. Returns 0 if both dates are equal. Returns positive if this
+ * date is later (higher) than the other date.
+ */
+ public int compareTo(EGIZDate other) {
+ long diff = toCompareableLong() - other.toCompareableLong();
+ return (int) diff;
+ }
}