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}