/* Copyright (C) 2014 konik.io * * This file is part of the Konik library. * * The Konik library is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * The Konik library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with the Konik library. If not, see <http://www.gnu.org/licenses/>. */ package io.konik.jaxb.adapter; import io.konik.jaxb.bindable.entity.DueDatePeriod; import io.konik.zugferd.unqualified.ZfDate; import java.util.logging.Level; import java.util.logging.Logger; import javax.xml.bind.annotation.adapters.XmlAdapter; /** * = Adapter to map the Period's complete property to a DateTime property . */ public class PeriodCompleteToDateTimeAdapter extends XmlAdapter<DueDatePeriod, ZfDate> { private static final Logger LOG = Logger.getLogger(PeriodCompleteToDateTimeAdapter.class.getName()); @Override public ZfDate unmarshal(DueDatePeriod period) throws Exception { if (period == null) { return null; } if (period.getContractualDueDate() == null) { LOG.log(Level.WARNING, "Specified Period exist but no complete Date Time"); return null; } return period.getContractualDueDate(); } @Override public DueDatePeriod marshal(ZfDate complete) throws Exception { if (complete == null) { return null; } return new DueDatePeriod(complete); } }