ServiceCtrl.java
7.49 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
/*
* 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
* <http://www.gnu.org/licenses/>.
*/
package eu.omp.irap.vespa.epntapclient.service;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import javax.xml.datatype.XMLGregorianCalendar;
import eu.omp.irap.vespa.epntapclient.voresource.model.ContentLevel;
import eu.omp.irap.vespa.epntapclient.voresource.model.Creator;
import eu.omp.irap.vespa.epntapclient.voresource.model.Resource;
import eu.omp.irap.vespa.epntapclient.voresource.model.Type;
import eu.omp.irap.vespa.epntapclient.votable.model.Table;
import eu.omp.irap.vespa.epntapclient.votable.model.VOTABLE;
import eu.omp.irap.vespa.votable.Consts;
import eu.omp.irap.vespa.votable.controller.VOTableController;
import eu.omp.irap.vespa.votable.controller.VOTableException;
import eu.omp.irap.vespa.votable.controller.VOTableException.CanNotParseDataException;
import eu.omp.irap.vespa.votable.utils.StringJoiner;
import eu.omp.irap.vespa.votable.votabledata.VOTableData;
import eu.omp.irap.vespa.votable.votabledata.VOTableDataParser;
/**
* @author N. Jourdane
*/
public class ServiceCtrl {
/** The date format used to serialize date parameters. */
public static final String DATE_FORMAT = "yyyy/MM/dd HH:mm:ss";
/** Private constructor to hide the implicit public one. */
private ServiceCtrl() {
}
/**
* @param ivoid The ivoid of the service.
* @param parameter The unique parameter to get.
* @return The value of the parameter.
* @throws VOTableException Can not get the VOTable.
*/
public static Object getParameter(String ivoid, String parameter)
throws VOTableException {
String query = String.format(Queries.SELECT_TAP_SERVICES_WHERE_IVOID, parameter, ivoid);
return getVoTableData(query).getCell(0, 0);
}
/**
* @param ivoid The ivoid of the service.
* @param parameters A list of parameters to get.
* @return A map of <parameter name, value> resulting the request.
* @throws VOTableException Can not get the VOTable.
*/
public static Map<String, Object> getParameters(String ivoid, List<String> parameters)
throws VOTableException {
return getParameters(ivoid, StringJoiner.join(parameters));
}
/**
* @param ivoid The ivoid of the service.
* @param parameters The parameters to get, separated by commas.
* @return A map of <parameter name, value> resulting the request.
* @throws VOTableException Can not get the VOTable.
*/
public static Map<String, Object> getParameters(String ivoid, String parameters)
throws VOTableException {
String query = String.format(Queries.SELECT_TAP_SERVICES_WHERE_IVOID, parameters, ivoid);
return getVoTableData(query).getRowMap(0);
}
/**
* Parse a Resource and returns the corresponding Service.
*
* @param resource the resource to parse.
* @return The corresponding service.
*/
public static final Service getService(Resource resource) {
Service service = new Service(resource.getIdentifier());
service.setTitle(resource.getTitle());
service.setShortName(resource.getShortName());
StringJoiner types = new StringJoiner(", ");
for (Type type : resource.getContent().getType()) {
types.add(type.toString());
}
service.setType(types.toString());
service.setDescription(resource.getContent().getDescription());
StringJoiner creators = new StringJoiner(", ");
for (Creator creator : resource.getCuration().getCreator()) {
creators.add(creator.getName().getValue());
}
service.setCreator(creators.toString());
StringJoiner contentLevels = new StringJoiner(", ");
for (ContentLevel contentLevel : resource.getContent().getContentLevel()) {
contentLevels.add(contentLevel.value());
}
service.setContentLevel(contentLevels.toString());
service.setReferenceURL(resource.getContent().getReferenceURL());
service.setCreated(ServiceCtrl.xmlDateToString(resource.getCreated()));
service.setUpdated(ServiceCtrl.xmlDateToString(resource.getUpdated()));
return service;
}
/**
* Parse a VOTableData and returns the corresponding list of services.
*
* @param data The VOTableData of the service, created by the VOTable parser. Each row of the
* data set is a service.
* @return The corresponding list of service.
* @throws CanNotParseDataException The column name was not found in the list.
*/
public static final List<Service> getServices(VOTableData data)
throws CanNotParseDataException {
List<Service> services = new ArrayList<>();
for (int i = 0; i < data.getNbRows(); i++) {
Service service = new Service((String) data.getCell(i, "ivoid"));
service.setTitle((String) data.getCell(i, "res_title"));
service.setShortName((String) data.getCell(i, "short_name"));
service.setType((String) data.getCell(i, "content_type"));
service.setDescription((String) data.getCell(i, "res_description"));
service.setCreator((String) data.getCell(i, "creator_seq"));
service.setContentLevel((String) data.getCell(i, "content_level"));
service.setReferenceURL((String) data.getCell(i, "reference_url"));
service.setCreated((String) data.getCell(i, "created"));
service.setUpdated((String) data.getCell(i, "updated"));
services.add(service);
}
return services;
}
/**
* @param query The query.
* @return The VOTable resulting the query.
* @throws VOTableException Can not get the VOTable.
*/
public static VOTABLE getVoTable(String query) throws VOTableException {
VOTableController voTableCtrl = new VOTableController();
voTableCtrl.newVOTable(Consts.DEFAULT_REGISTRY_URL, query);
return voTableCtrl.getVOTable();
}
/**
* @param query The query to get the service.
* @return The VOTableData
* @throws VOTableException Can not get the VOTable.
*/
public static VOTableData getVoTableData(String query) throws VOTableException {
return getVoTableData(getVoTable(query));
}
/**
* Parse a VOTable and returns the corresponding VOTableData.
*
* @param voTable The VOTable parsed.
* @return The corresponding VOTableData.
* @throws VOTableException Can not get the VOTable.
*/
public static VOTableData getVoTableData(VOTABLE voTable) throws VOTableException {
VOTableController.checkVOTable(voTable);
Table table = (Table) voTable.getRESOURCE().get(0).getLINKAndTABLEOrRESOURCE().get(0);
VOTableDataParser dataParser = new VOTableDataParser(table);
dataParser.parseData();
return dataParser.getData();
}
/**
* Convert a date from XMLGregorianCalendar to a string literal.
*
* @param date The date to convert
* @return The serialized date.
*/
private static String xmlDateToString(XMLGregorianCalendar date) {
SimpleDateFormat sdf = new SimpleDateFormat(ServiceCtrl.DATE_FORMAT);
return sdf.format(date.toGregorianCalendar().getTime());
}
}