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.jaxb.adapter;
019
020import io.konik.jaxb.bindable.entity.DueDatePeriod;
021import io.konik.zugferd.unqualified.ZfDate;
022
023import java.util.logging.Level;
024import java.util.logging.Logger;
025
026import javax.xml.bind.annotation.adapters.XmlAdapter;
027
028/**
029 * = Adapter to map the Period's complete property to a DateTime property .
030 */
031public class PeriodCompleteToDateTimeAdapter extends XmlAdapter<DueDatePeriod, ZfDate> {
032
033   private static final Logger LOG = Logger.getLogger(PeriodCompleteToDateTimeAdapter.class.getName());
034
035   @Override
036   public ZfDate unmarshal(DueDatePeriod period) throws Exception {
037      if (period == null) { return null; }
038      if (period.getContractualDueDate() == null) {
039         LOG.log(Level.WARNING, "Specified Period exist but no complete Date Time");
040         return null;
041      }
042      return period.getContractualDueDate();
043   }
044
045   @Override
046   public DueDatePeriod marshal(ZfDate complete) throws Exception {
047      if (complete == null) { return null; }
048      return new DueDatePeriod(complete);
049   }
050
051}