001/* Copyright (C) 2014 konik.io
002 *
003 * This file is part of the Konik library.
004 *
005 * The Konik library is free software: you can redistribute it and/or modify
006 * it under the terms of the GNU Affero General Public License as
007 * published by the Free Software Foundation, either version 3 of the
008 * License, or (at your option) any later version.
009 *
010 * The Konik library is distributed in the hope that it will be useful,
011 * but WITHOUT ANY WARRANTY; without even the implied warranty of
012 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
013 * GNU Affero General Public License for more details.
014 *
015 * You should have received a copy of the GNU Affero General Public License
016 * along with the Konik library. If not, see <http://www.gnu.org/licenses/>.
017 */
018package io.konik.zugferd.entity;
019
020import io.konik.zugferd.unqualified.ZfDate;
021
022import javax.validation.constraints.NotNull;
023import javax.xml.bind.annotation.XmlElement;
024import javax.xml.bind.annotation.XmlType;
025
026/**
027 * = The period of time
028 * 
029 */
030@XmlType(name = "SpecifiedPeriodType", propOrder = { "start", "end" })
031public class Period {
032
033   @XmlElement(name = "StartDateTime")
034   private ZfDate start;
035
036   @XmlElement(name = "EndDateTime")
037   private ZfDate end;
038
039
040   /**
041    * Gets the start date time.
042    * 
043    * @return the start date time
044    */
045   @NotNull
046   public ZfDate getStart() {
047      return start;
048   }
049
050   /**
051    * Sets the start date time.
052    *
053    * @param start the new start date time
054    * @return the period
055    */
056   public Period setStart(ZfDate start) {
057      this.start = start;
058      return this;
059   }
060
061   /**
062    * Gets the end date time.
063    * 
064    * @return the end date time
065    */
066   @NotNull
067   public ZfDate getEnd() {
068      return end;
069   }
070
071   /**
072    * Sets the end date time.
073    *
074    * @param end the new end date time
075    * @return the period
076    */
077   public Period setEnd(ZfDate end) {
078      this.end = end;
079      return this;
080   }
081
082}