001    /*
002     *    GeoAPI - Java interfaces for OGC/ISO standards
003     *    http://www.geoapi.org
004     *
005     *    Copyright (C) 2004-2012 Open Geospatial Consortium, Inc.
006     *    All Rights Reserved. http://www.opengeospatial.org/ogc/legal
007     *
008     *    Permission to use, copy, and modify this software and its documentation, with
009     *    or without modification, for any purpose and without fee or royalty is hereby
010     *    granted, provided that you include the following on ALL copies of the software
011     *    and documentation or portions thereof, including modifications, that you make:
012     *
013     *    1. The full text of this NOTICE in a location viewable to users of the
014     *       redistributed or derivative work.
015     *    2. Notice of any changes or modifications to the OGC files, including the
016     *       date changes were made.
017     *
018     *    THIS SOFTWARE AND DOCUMENTATION IS PROVIDED "AS IS," AND COPYRIGHT HOLDERS MAKE
019     *    NO REPRESENTATIONS OR WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED
020     *    TO, WARRANTIES OF MERCHANTABILITY OR FITNESS FOR ANY PARTICULAR PURPOSE OR THAT
021     *    THE USE OF THE SOFTWARE OR DOCUMENTATION WILL NOT INFRINGE ANY THIRD PARTY
022     *    PATENTS, COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS.
023     *
024     *    COPYRIGHT HOLDERS WILL NOT BE LIABLE FOR ANY DIRECT, INDIRECT, SPECIAL OR
025     *    CONSEQUENTIAL DAMAGES ARISING OUT OF ANY USE OF THE SOFTWARE OR DOCUMENTATION.
026     *
027     *    The name and trademarks of copyright holders may NOT be used in advertising or
028     *    publicity pertaining to the software without specific, written prior permission.
029     *    Title to copyright in this software and any associated documentation will at all
030     *    times remain with copyright holders.
031     */
032    package org.opengis.metadata.distribution;
033    
034    import java.util.Date;
035    import org.opengis.util.InternationalString;
036    import org.opengis.annotation.UML;
037    
038    import static org.opengis.annotation.Obligation.*;
039    import static org.opengis.annotation.Specification.*;
040    
041    
042    /**
043     * Common ways in which the resource may be obtained or received, and related instructions
044     * and fee information.
045     *
046     * @author  Martin Desruisseaux (IRD)
047     * @version 3.0
048     * @since   2.0
049     */
050    @UML(identifier="MD_StandardOrderProcess", specification=ISO_19115)
051    public interface StandardOrderProcess {
052        /**
053         * Fees and terms for retrieving the resource.
054         * Include monetary units (as specified in ISO 4217).
055         *
056         * @return Fees and terms for retrieving the resource, or {@code null}.
057         */
058        @UML(identifier="fees", obligation=OPTIONAL, specification=ISO_19115)
059        InternationalString getFees();
060    
061        /**
062         * Date and time when the dataset will be available.
063         * <p>
064         * <TABLE WIDTH="80%" ALIGN="center" CELLPADDING="18" BORDER="4" BGCOLOR="#FFE0B0">
065         *   <TR><TD>
066         *     <P align="justify"><B>Warning:</B> The return type of this method may change
067         *     in GeoAPI 3.1 release. It may be replaced by a type matching more closely
068         *     either ISO 19108 (<cite>Temporal Schema</cite>) or ISO 19103.</P>
069         *   </TD></TR>
070         * </TABLE>
071         *
072         * @return Date and time when the dataset will be available, or {@code null}.
073         */
074        @UML(identifier="plannedAvailableDateTime", obligation=OPTIONAL, specification=ISO_19115)
075        Date getPlannedAvailableDateTime();
076    
077        /**
078         * General instructions, terms and services provided by the distributor.
079         *
080         * @return General instructions, terms and services provided by the distributor, or {@code null}.
081         */
082        @UML(identifier="orderingInstructions", obligation=OPTIONAL, specification=ISO_19115)
083        InternationalString getOrderingInstructions();
084    
085        /**
086         * Typical turnaround time for the filling of an order.
087         *
088         * @return Typical turnaround time for the filling of an order, or {@code null}.
089         */
090        @UML(identifier="turnaround", obligation=OPTIONAL, specification=ISO_19115)
091        InternationalString getTurnaround();
092    }