/*
* This file is a part of EpnTAPClient.
* This program aims to provide EPN-TAP support for software clients, like CASSIS spectrum analyzer.
* See draft specifications: https://voparis-confluence.obspm.fr/pages/viewpage.action?pageId=559861
* Copyright (C) 2016 Institut de Recherche en Astrophysique et Planétologie.
*
* This program is free software: you can
* redistribute it and/or modify it under the terms of the GNU General Public License as published
* by the Free Software Foundation, either version 3 of the License, or (at your option) any later
* version. This program 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 General Public License for more details. You should have received a copy of
* the GNU General Public License along with this program. If not, see
* .
*/
package eu.omp.irap.vespa.epntapclient.epntap;
import java.util.List;
import eu.omp.irap.vespa.epntapclient.Query;
import eu.omp.irap.vespa.epntapclient.granule.Granule;
import eu.omp.irap.vespa.epntapclient.granule.GranuleEnum;
import eu.omp.irap.vespa.epntapclient.voresource.VOResourceException;
import eu.omp.irap.vespa.epntapclient.voresource.model.Resource;
import eu.omp.irap.vespa.epntapclient.votable.model.VOTABLE;
import eu.omp.irap.vespa.votable.votable.VOTableException;
/**
* @author N. Jourdane
*/
public interface EpnTapInterface {
// *** Resource ***
/**
* Returns the name of the EPNCore Table related to a service.
*
* @param ivoid The ivoid of the service.
* @return The table name of the service, used usually in the 'FROM' keyword in a ADQL query.
* @throws VOTableException Can not get the VOTable.
*/
String getEPNCoreTableName(String ivoid) throws VOTableException;
// *** Resources ***
/**
* Returns a VOTable containing the attributes of the corresponding service (from a predefined
* list).
*
* @param ivoid The ivoid of the service to get.
* @return A VOTable containing the service.
* @throws VOTableException Can not get the VOTable.
*/
VOTABLE getEPNService(String ivoid) throws VOTableException;
/**
* Returns a VOTable containing the attributes of the corresponding service (from the list of
* attributes).
*
* @param ivoid The ivoid of the service to get.
* @param attributes A list of attributes, which are the column names to get.
* @return A VOTable containing the service.
* @see GranuleEnum The EpnTapv2 column names.
* @throws VOTableException Can not get the VOTable.
*/
VOTABLE getEPNService(String ivoid, List attributes)
throws VOTableException;
// *** Service ***
/**
* Returns a VOTable containing the list of EPN-TAP services and their attributes (from a
* predefined list).
*
* @return A VOTable containing the services.
* @throws VOTableException Can not get the VOTable.
*/
VOTABLE getEPNServices() throws VOTableException;
/**
* Returns a VOTable containing the list of EPN-TAP services and their attributes (from the list
* of attributes)
*
* @param attributes A list of attributes, which are the column names to get.
* @return A VOTable containing the services.
* @throws VOTableException Can not get the VOTable.
*/
VOTABLE getEPNServices(List attributes) throws VOTableException;
// *** Services ***
/**
* Returns a VOTable containing the list of EPN-TAP services corresponding to the keywords and
* their attributes (from the list of attributes).
*
* @param keywords A list of keywords, which are the *res_subject* column content of the table
* rr.res_subject of a registry.
* @param attributes A list of attributes, which are the column names to get.
* @return A VOTable containing the services.
* @throws VOTableException Can not get the VOTable.
*/
VOTABLE getEPNServices(List keywords, List attributes)
throws VOTableException;
/**
* Returns the VOResource element of the service identified by the ivoID.
*
* @param ivoid the ivoid of the service.
* @return The Resource of a service corresponding to the ivoid
* @throws VOResourceException Can not get the VOResource.
*/
Resource getEPNVOresource(String ivoid) throws VOResourceException;
/**
* Returns a set of VOResource elements (one per EPN-TAP service).
*
* @return A list containing the VOResources of all EpnTap services.
* @throws VOResourceException Can not get the VOResource.
*/
List getEPNVOResources() throws VOResourceException;
// *** Getters ***
/**
* Returns a set of VOREsource elements (one per EPN-TAP service corresponding to the keywords).
* The way keywords are defined is still to be defined.
*
* @param keywords A list of keywords, which are the content of the *subject* JSON node in the
* query.
* @see
* this example request
* @return A list containing the selected VOResources.
* @throws VOResourceException Can not get the VOResource.
*/
List getEPNVOResources(List keywords) throws VOResourceException;
/**
* Returns the Access URL of an EPN-TAP Service.
*
* @param ivoid the ivoid of the service.
* @return The target URL of the service, used usually to process requests on it.
* @throws VOTableException Can not get the VOTable.
*/
String getTAPURL(String ivoid) throws VOTableException;
// *** Queries ***
/**
* Returns the list of granules which are compliant with the ADQL Query, in VOTable format .
* TAPURL is build from elements taken in VOResource. "ADQLQuery" is created by the Client. It
* is a full query containing the name of the EPNCore table, taken in VOResource.
*
* @param tapURL The URL of the service.
* @param adqlQuery The ADQL query.
* @return A list of Granules resulting the query.
* @throws VOTableException Can not get the VOTable.
*/
List sendADQLQuery(String tapURL, String adqlQuery) throws VOTableException;
/**
* Returns the list of granules which are compliant with the Query, in VOTable format. "Query"
* is not an ADQL query. It is taken from a list of predefined queries. This list must be
* created.
*
* @param tapURL The URL of the service.
* @param schemaName The name of the service schema.
* @param query The query, from a list a predefined queries.
* @return A list of granules resulting the query.
* @throws VOTableException Can not get the VOTable.
*/
List sendQuery(String tapURL, String schemaName, Query query) throws VOTableException;
}