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 final static QName QNAME = new QName("urn:un:unece:uncefact:data:standard:CBFBUY:5","Invoice","rsm");
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:un:unece:uncefact:data:standard:CBFBUY:5", name = "Invoice")
051        public JAXBElement<Invoice> createInvoice(Invoice invoice) {
052                return new JAXBElement<Invoice>(QNAME, Invoice.class, null, invoice);
053        }
054
055}