001/*
002 * Copyright (C) 2014 konik.io
003 *
004 * This file is part of Konik library.
005 *
006 * Konik library is free software: you can redistribute it and/or modify
007 * it under the terms of the GNU Affero General Public License as published by
008 * the Free Software Foundation, either version 3 of the License, or
009 * (at your option) any later version.
010 *
011 * Konik library is distributed in the hope that it will be useful,
012 * but WITHOUT ANY WARRANTY; without even the implied warranty of
013 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
014 * GNU Affero General Public License for more details.
015 *
016 * You should have received a copy of the GNU Affero General Public License
017 * along with Konik library.  If not, see <http://www.gnu.org/licenses/>.
018 */
019package io.konik.zugferd;
020
021import javax.xml.bind.JAXBElement;
022import javax.xml.bind.annotation.XmlElementDecl;
023import javax.xml.bind.annotation.XmlRegistry;
024import javax.xml.namespace.QName;
025
026/**
027 * A factory for creating Object objects.
028 */
029@XmlRegistry
030public class ObjectFactory {
031
032   /** The Constant QNAME. */
033   private static final QName QNAME = new QName("urn:ferd:CrossIndustryDocument:invoice:1p0", "CrossIndustryDocument");
034
035   /**
036    * Creates a new Object object.
037    *
038    * @return the invoice
039    */
040   public Invoice createInvoice() {
041      return new Invoice();
042   }
043
044   /**
045    * Creates a new Object object.
046    *
047    * @param invoice the invoice
048    * @return the JAXB element
049    */
050   @XmlElementDecl(namespace = "urn:ferd:CrossIndustryDocument:invoice:1p0", name = "CrossIndustryDocument")
051   public JAXBElement<Invoice> createInvoice(Invoice invoice) {
052      return new JAXBElement<Invoice>(QNAME, Invoice.class, null, invoice);
053   }
054
055}