Added Export CSV Monitor
git-svn-id: https://svn.d4science.research-infrastructures.eu/gcube/trunk/portlets/user/tabular-data-gwt-service@86338 82a268e6-3cf1-43bd-a215-b396298e98cf
This commit is contained in:
parent
c5bf5a1d4f
commit
1127ad51c2
|
@ -7,6 +7,8 @@ import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.AvailableCharsetList;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.AvailableCharsetList;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVExportMonitor;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVExportSession;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportMonitor;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportMonitor;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportSession;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportSession;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVRowError;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVRowError;
|
||||||
|
@ -24,7 +26,6 @@ import org.gcube.portlets.user.td.gwtservice.shared.tr.type.Agencies;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.tr.type.Codelist;
|
import org.gcube.portlets.user.td.gwtservice.shared.tr.type.Codelist;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.tr.type.Dataset;
|
import org.gcube.portlets.user.td.gwtservice.shared.tr.type.Dataset;
|
||||||
|
|
||||||
import com.google.gwt.user.client.rpc.AsyncCallback;
|
|
||||||
import com.google.gwt.user.client.rpc.RemoteService;
|
import com.google.gwt.user.client.rpc.RemoteService;
|
||||||
import com.google.gwt.user.client.rpc.RemoteServiceRelativePath;
|
import com.google.gwt.user.client.rpc.RemoteServiceRelativePath;
|
||||||
|
|
||||||
|
@ -241,4 +242,26 @@ public interface TDGWTService extends RemoteService {
|
||||||
*/
|
*/
|
||||||
public CSVImportMonitor getCSVImportMonitor() throws TDGWTServiceException;
|
public CSVImportMonitor getCSVImportMonitor() throws TDGWTServiceException;
|
||||||
|
|
||||||
|
|
||||||
|
//Export CSV
|
||||||
|
/**
|
||||||
|
* Get Operation Monitor during the CSV Export operation
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* @throws TDGWTServiceException
|
||||||
|
*/
|
||||||
|
public CSVExportMonitor getCSVExportMonitor() throws TDGWTServiceException;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Start CSV Export and invokes the client library
|
||||||
|
*
|
||||||
|
* @param csvExportSession
|
||||||
|
* @throws TDGWTServiceException
|
||||||
|
*/
|
||||||
|
public void startCSVExport(CSVExportSession csvExportSession) throws TDGWTServiceException;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,6 +7,8 @@ import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.AvailableCharsetList;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.AvailableCharsetList;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVExportMonitor;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVExportSession;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportMonitor;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportMonitor;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportSession;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportSession;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVRowError;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVRowError;
|
||||||
|
@ -84,5 +86,10 @@ public interface TDGWTServiceAsync {
|
||||||
|
|
||||||
void startCSVImport(CSVImportSession csvImportSession, AsyncCallback<Void> callback);
|
void startCSVImport(CSVImportSession csvImportSession, AsyncCallback<Void> callback);
|
||||||
|
|
||||||
|
//Export CSV
|
||||||
|
void getCSVExportMonitor(AsyncCallback<CSVExportMonitor> callback);
|
||||||
|
|
||||||
|
void startCSVExport(CSVExportSession csvExportSession, AsyncCallback<Void> callback);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -57,6 +57,11 @@ public class SessionUtil {
|
||||||
protected static final String CSV_IMPORT_TASK="CSV_IMPORT_TASK";
|
protected static final String CSV_IMPORT_TASK="CSV_IMPORT_TASK";
|
||||||
protected static final String CSV_IMPORT_TABULAR_RESOURCE = "CSV_IMPORT_TABULAR_RESOURCE";
|
protected static final String CSV_IMPORT_TABULAR_RESOURCE = "CSV_IMPORT_TABULAR_RESOURCE";
|
||||||
|
|
||||||
|
protected static final String CSV_EXPORT_FILE_SESSION = "CSV_EXPORT_FILE";
|
||||||
|
protected static final String CSV_EXPORT_FILE_TASK="CSV_EXPORT_FILE_TASK";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
protected static Logger logger = LoggerFactory.getLogger(SessionUtil.class);
|
protected static Logger logger = LoggerFactory.getLogger(SessionUtil.class);
|
||||||
|
|
||||||
protected static ASLSession getAslSession(HttpSession httpSession) {
|
protected static ASLSession getAslSession(HttpSession httpSession) {
|
||||||
|
@ -367,6 +372,22 @@ public class SessionUtil {
|
||||||
httpSession.setAttribute(CSV_IMPORT_TASK, task);
|
httpSession.setAttribute(CSV_IMPORT_TASK, task);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static Task getCSVExportFileTask(HttpSession httpSession) {
|
||||||
|
Task monitor = (Task) httpSession.getAttribute(CSV_EXPORT_FILE_TASK);
|
||||||
|
if (monitor == null) {
|
||||||
|
logger.error("CSV_EXPORT_FILE_TASK was not acquired");
|
||||||
|
}
|
||||||
|
return monitor;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void setCSVExportFileTask(HttpSession httpSession, Task task) {
|
||||||
|
Task monitor = (Task) httpSession.getAttribute(CSV_EXPORT_FILE_TASK);
|
||||||
|
if (monitor != null)
|
||||||
|
httpSession.removeAttribute(CSV_EXPORT_FILE_TASK);
|
||||||
|
httpSession.setAttribute(CSV_EXPORT_FILE_TASK, task);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public static TRTasksManager getTRTasksManager(HttpSession httpSession) {
|
public static TRTasksManager getTRTasksManager(HttpSession httpSession) {
|
||||||
TRTasksManager tasksManager = (TRTasksManager) httpSession.getAttribute(TR_TASK_MANAGER);
|
TRTasksManager tasksManager = (TRTasksManager) httpSession.getAttribute(TR_TASK_MANAGER);
|
||||||
|
|
|
@ -63,7 +63,10 @@ import org.gcube.portlets.user.td.gwtservice.server.file.FileUploadSession;
|
||||||
import org.gcube.portlets.user.td.gwtservice.server.file.FileUtil;
|
import org.gcube.portlets.user.td.gwtservice.server.file.FileUtil;
|
||||||
import org.gcube.portlets.user.td.gwtservice.server.storage.FilesStorage;
|
import org.gcube.portlets.user.td.gwtservice.server.storage.FilesStorage;
|
||||||
import org.gcube.portlets.user.td.gwtservice.server.trservice.OperationsId;
|
import org.gcube.portlets.user.td.gwtservice.server.trservice.OperationsId;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.Constants;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.AvailableCharsetList;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.AvailableCharsetList;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVExportMonitor;
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVExportSession;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVFileUtil;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVFileUtil;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportMonitor;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportMonitor;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportSession;
|
import org.gcube.portlets.user.td.gwtservice.shared.csv.CSVImportSession;
|
||||||
|
@ -190,11 +193,10 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
tData.setName(table.getName());
|
tData.setName(table.getName());
|
||||||
tData.setTypeName(table.getTableType().getName());
|
tData.setTypeName(table.getTableType().getName());
|
||||||
tData.setTypeCode(table.getTableType().getCode());
|
tData.setTypeCode(table.getTableType().getCode());
|
||||||
Collection<TableMetadata> cMeta=table.getAllMetadata();
|
Collection<TableMetadata> cMeta = table.getAllMetadata();
|
||||||
|
|
||||||
tData.setMetaData(cMeta.toString());
|
tData.setMetaData(cMeta.toString());
|
||||||
|
|
||||||
|
|
||||||
ArrayList<ColumnData> lColumnData = new ArrayList<ColumnData>();
|
ArrayList<ColumnData> lColumnData = new ArrayList<ColumnData>();
|
||||||
for (Column column : table.getColumns()) {
|
for (Column column : table.getColumns()) {
|
||||||
ColumnData colData = new ColumnData();
|
ColumnData colData = new ColumnData();
|
||||||
|
@ -569,8 +571,10 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
|
|
||||||
Map<String, Object> parameterInstance = retrieveOperationParameters(sdmxImportSession);
|
Map<String, Object> parameterInstance = retrieveOperationParameters(sdmxImportSession);
|
||||||
|
|
||||||
InvocationCreator ic=InvocationCreator.getCreator(importSDMXCodelistOperation);
|
InvocationCreator ic = InvocationCreator
|
||||||
OperationInvocation invocation = ic.setParameters(parameterInstance).create();
|
.getCreator(importSDMXCodelistOperation);
|
||||||
|
OperationInvocation invocation = ic
|
||||||
|
.setParameters(parameterInstance).create();
|
||||||
|
|
||||||
logger.debug("OperationInvocation: \n" + invocation.toString());
|
logger.debug("OperationInvocation: \n" + invocation.toString());
|
||||||
Task trTask = oService.execute(invocation, serviceTR.getId());
|
Task trTask = oService.execute(invocation, serviceTR.getId());
|
||||||
|
@ -592,19 +596,19 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
* @throws TDGWTServiceException
|
* @throws TDGWTServiceException
|
||||||
*/
|
*/
|
||||||
protected OperationDescriptor getOperationDescriptorWithId(String op,
|
protected OperationDescriptor getOperationDescriptorWithId(String op,
|
||||||
List<OperationDescriptor> capabilities) throws TDGWTServiceException {
|
List<OperationDescriptor> capabilities)
|
||||||
|
throws TDGWTServiceException {
|
||||||
for (OperationDescriptor operation : capabilities) {
|
for (OperationDescriptor operation : capabilities) {
|
||||||
if (Long.valueOf(op) == operation.getOperationId().getValue()) {
|
if (Long.valueOf(op) == operation.getOperationId().getValue()) {
|
||||||
return operation;
|
return operation;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
throw new TDGWTServiceException("OperationDescriptor not found");
|
throw new TDGWTServiceException("OperationDescriptor not found");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected State matchTaskState(TaskStatus status){
|
protected State matchTaskState(TaskStatus status) {
|
||||||
switch (status) {
|
switch (status) {
|
||||||
case INITIALIZING:
|
case INITIALIZING:
|
||||||
return State.INITIALIZING;
|
return State.INITIALIZING;
|
||||||
|
@ -623,7 +627,6 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
*/
|
*/
|
||||||
|
@ -656,13 +659,15 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
logger.debug("Service Task.getStatus(): "
|
logger.debug("Service Task.getStatus(): "
|
||||||
+ task.getStatus());
|
+ task.getStatus());
|
||||||
|
|
||||||
importMonitor.setStatus(matchTaskState(task.getStatus()));
|
importMonitor
|
||||||
|
.setStatus(matchTaskState(task.getStatus()));
|
||||||
|
|
||||||
switch (importMonitor.getStatus()) {
|
switch (importMonitor.getStatus()) {
|
||||||
case SUCCEDED:
|
case SUCCEDED:
|
||||||
importMonitor.setProgress(task.getProgress());
|
importMonitor.setProgress(task.getProgress());
|
||||||
logger.debug("Task Result: " + task.getResult());
|
logger.debug("Task Result: " + task.getResult());
|
||||||
trId.setTableId(String.valueOf(task.getResult().getPrimaryTable().getId().getValue()));
|
trId.setTableId(String.valueOf(task.getResult()
|
||||||
|
.getPrimaryTable().getId().getValue()));
|
||||||
sdmxImportTabResource.setTrId(trId);
|
sdmxImportTabResource.setTrId(trId);
|
||||||
SessionUtil.setSDMXImportTabResource(session,
|
SessionUtil.setSDMXImportTabResource(session,
|
||||||
sdmxImportTabResource);
|
sdmxImportTabResource);
|
||||||
|
@ -675,8 +680,7 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
if (task.getResult() != null) {
|
if (task.getResult() != null) {
|
||||||
logger.debug("Task exception:"
|
logger.debug("Task exception:"
|
||||||
+ task.getErrorCause());
|
+ task.getErrorCause());
|
||||||
importMonitor
|
importMonitor.setError(task.getErrorCause());
|
||||||
.setError(task.getErrorCause());
|
|
||||||
} else {
|
} else {
|
||||||
logger.debug("Task exception: Error In Import");
|
logger.debug("Task exception: Error In Import");
|
||||||
importMonitor.setError(new Throwable(
|
importMonitor.setError(new Throwable(
|
||||||
|
@ -913,22 +917,18 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
protected Map<String, Object> csvImportFileParameter(
|
protected Map<String, Object> csvImportFileParameter(
|
||||||
String fileUrlOnStorage, FileUploadSession fileUploadSession,
|
String fileUrlOnStorage, FileUploadSession fileUploadSession,
|
||||||
CSVImportSession csvImportSession) {
|
CSVImportSession csvImportSession) {
|
||||||
final String ENCODING = "encoding";
|
|
||||||
final String HASHEADER = "hasHeader";
|
|
||||||
final String SEPARATOR = "separator";
|
|
||||||
final String URL = "url";
|
|
||||||
|
|
||||||
Map<String, Object> parameterInstances = new HashMap<String, Object>();
|
Map<String, Object> parameterInstances = new HashMap<String, Object>();
|
||||||
parameterInstances.put(URL, fileUrlOnStorage);
|
parameterInstances.put(Constants.URL, fileUrlOnStorage);
|
||||||
parameterInstances.put(SEPARATOR, String.valueOf(fileUploadSession
|
parameterInstances.put(Constants.SEPARATOR, String
|
||||||
.getParserConfiguration().getDelimiter()));// ','
|
.valueOf(fileUploadSession.getParserConfiguration()
|
||||||
parameterInstances.put(ENCODING, fileUploadSession
|
.getDelimiter()));// ','
|
||||||
|
parameterInstances.put(Constants.ENCODING, fileUploadSession
|
||||||
.getParserConfiguration().getCharset().name());// "UTF-8"
|
.getParserConfiguration().getCharset().name());// "UTF-8"
|
||||||
boolean hasHeader = true;
|
boolean hasHeader = true;
|
||||||
if (fileUploadSession.getParserConfiguration().getHeaderPresence() == HeaderPresence.NONE) {
|
if (fileUploadSession.getParserConfiguration().getHeaderPresence() == HeaderPresence.NONE) {
|
||||||
hasHeader = false;
|
hasHeader = false;
|
||||||
}
|
}
|
||||||
parameterInstances.put(HASHEADER, hasHeader);// true
|
parameterInstances.put(Constants.HASHEADER, hasHeader);// true
|
||||||
return parameterInstances;
|
return parameterInstances;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -948,8 +948,7 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
|
|
||||||
String fileUrlOnStorage = filesStorage.storageCSVTempFile(user,
|
String fileUrlOnStorage = filesStorage.storageCSVTempFile(user,
|
||||||
fileUploadSession.getCsvFile());
|
fileUploadSession.getCsvFile());
|
||||||
logger.debug("File Url On Storage:"+fileUrlOnStorage);
|
logger.debug("File Url On Storage:" + fileUrlOnStorage);
|
||||||
|
|
||||||
|
|
||||||
Map<String, Object> parameterInstance = csvImportFileParameter(
|
Map<String, Object> parameterInstance = csvImportFileParameter(
|
||||||
fileUrlOnStorage, fileUploadSession, csvImportSession);
|
fileUrlOnStorage, fileUploadSession, csvImportSession);
|
||||||
|
@ -964,8 +963,10 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
OperationDescriptor importCSVFileOperation = getOperationDescriptorWithId(
|
OperationDescriptor importCSVFileOperation = getOperationDescriptorWithId(
|
||||||
OperationsId.CSVImport.toString(), capabilities);
|
OperationsId.CSVImport.toString(), capabilities);
|
||||||
|
|
||||||
InvocationCreator ic=InvocationCreator.getCreator(importCSVFileOperation);
|
InvocationCreator ic = InvocationCreator
|
||||||
OperationInvocation invocation = ic.setParameters(parameterInstance).create();
|
.getCreator(importCSVFileOperation);
|
||||||
|
OperationInvocation invocation = ic.setParameters(parameterInstance)
|
||||||
|
.create();
|
||||||
|
|
||||||
logger.debug("OperationInvocation: \n" + invocation.toString());
|
logger.debug("OperationInvocation: \n" + invocation.toString());
|
||||||
TabularResource tabularResource = service.createTabularResource();
|
TabularResource tabularResource = service.createTabularResource();
|
||||||
|
@ -1019,14 +1020,15 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
} else {
|
} else {
|
||||||
logger.debug("Status: " + task.getStatus());
|
logger.debug("Status: " + task.getStatus());
|
||||||
|
|
||||||
importMonitor.setStatus(matchTaskState(task.getStatus()));
|
importMonitor
|
||||||
|
.setStatus(matchTaskState(task.getStatus()));
|
||||||
switch (importMonitor.getStatus()) {
|
switch (importMonitor.getStatus()) {
|
||||||
case FAILED:
|
case FAILED:
|
||||||
if (task.getResult() != null) {
|
if (task.getResult() != null) {
|
||||||
logger.debug("Task exception:"
|
logger.debug("Task exception:"
|
||||||
+ task.getErrorCause());
|
+ task.getErrorCause());
|
||||||
importMonitor
|
importMonitor.setError(task
|
||||||
.setError(new Throwable(task.getErrorCause()));
|
.getErrorCause());
|
||||||
} else {
|
} else {
|
||||||
logger.debug("Task exception: Error In Import");
|
logger.debug("Task exception: Error In Import");
|
||||||
importMonitor.setError(new Throwable(
|
importMonitor.setError(new Throwable(
|
||||||
|
@ -1079,6 +1081,10 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void getFileFromWorkspace(CSVImportSession csvImportSession)
|
public void getFileFromWorkspace(CSVImportSession csvImportSession)
|
||||||
throws TDGWTServiceException {
|
throws TDGWTServiceException {
|
||||||
|
@ -1157,6 +1163,10 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
SessionUtil.setFileUploadSession(session, fileUploadSession);
|
SessionUtil.setFileUploadSession(session, fileUploadSession);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
@Override
|
@Override
|
||||||
public ArrayList<TRMetadata> getTableMetadata(TRId trId)
|
public ArrayList<TRMetadata> getTableMetadata(TRId trId)
|
||||||
throws TDGWTServiceException {
|
throws TDGWTServiceException {
|
||||||
|
@ -1167,71 +1177,94 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
service = TabularDataServiceFactory.getService(aslSession
|
service = TabularDataServiceFactory.getService(aslSession
|
||||||
.getUsername());
|
.getUsername());
|
||||||
|
|
||||||
Table table = service.getTable(new TableId(Long.valueOf(trId.getTableId())));
|
Table table = service.getTable(new TableId(Long.valueOf(trId
|
||||||
|
.getTableId())));
|
||||||
|
|
||||||
Collection<TableMetadata> cMeta=table.getAllMetadata();
|
Collection<TableMetadata> cMeta = table.getAllMetadata();
|
||||||
|
|
||||||
ArrayList<TRMetadata> listTRMetadata=new ArrayList<TRMetadata>();
|
ArrayList<TRMetadata> listTRMetadata = new ArrayList<TRMetadata>();
|
||||||
|
|
||||||
for(TableMetadata tMetadata:cMeta){
|
for (TableMetadata tMetadata : cMeta) {
|
||||||
if(tMetadata instanceof DescriptionsMetadata){
|
if (tMetadata instanceof DescriptionsMetadata) {
|
||||||
TRDescriptionsMetadata trDescriptionsMetadata=new TRDescriptionsMetadata();
|
TRDescriptionsMetadata trDescriptionsMetadata = new TRDescriptionsMetadata();
|
||||||
ArrayList<TRLocalizedText> listTRLocalizedText=new ArrayList<TRLocalizedText>();
|
ArrayList<TRLocalizedText> listTRLocalizedText = new ArrayList<TRLocalizedText>();
|
||||||
List<LocalizedText> lLocalizedText=((DescriptionsMetadata) tMetadata).getTexts();
|
List<LocalizedText> lLocalizedText = ((DescriptionsMetadata) tMetadata)
|
||||||
int i=0;
|
.getTexts();
|
||||||
for(LocalizedText lt:lLocalizedText){
|
int i = 0;
|
||||||
TRLocalizedText trLocalizedText=new TRLocalizedText();
|
for (LocalizedText lt : lLocalizedText) {
|
||||||
|
TRLocalizedText trLocalizedText = new TRLocalizedText();
|
||||||
trLocalizedText.setId(i);
|
trLocalizedText.setId(i);
|
||||||
trLocalizedText.setValue(lt.getValue());
|
trLocalizedText.setValue(lt.getValue());
|
||||||
trLocalizedText.setLocaleCode(lt.getLocale());
|
trLocalizedText.setLocaleCode(lt.getLocale());
|
||||||
listTRLocalizedText.add(trLocalizedText);
|
listTRLocalizedText.add(trLocalizedText);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
trDescriptionsMetadata.setListTRLocalizedText(listTRLocalizedText);
|
trDescriptionsMetadata
|
||||||
|
.setListTRLocalizedText(listTRLocalizedText);
|
||||||
listTRMetadata.add(trDescriptionsMetadata);
|
listTRMetadata.add(trDescriptionsMetadata);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if(tMetadata instanceof NamesMetadata){
|
if (tMetadata instanceof NamesMetadata) {
|
||||||
TRNamesMetadata trNamesMetadata=new TRNamesMetadata();
|
TRNamesMetadata trNamesMetadata = new TRNamesMetadata();
|
||||||
ArrayList<TRLocalizedText> listTRLocalizedText=new ArrayList<TRLocalizedText>();
|
ArrayList<TRLocalizedText> listTRLocalizedText = new ArrayList<TRLocalizedText>();
|
||||||
List<LocalizedText> lLocalizedText=((NamesMetadata) tMetadata).getTexts();
|
List<LocalizedText> lLocalizedText = ((NamesMetadata) tMetadata)
|
||||||
int i=0;
|
.getTexts();
|
||||||
for(LocalizedText lt:lLocalizedText){
|
int i = 0;
|
||||||
TRLocalizedText trLocalizedText=new TRLocalizedText();
|
for (LocalizedText lt : lLocalizedText) {
|
||||||
|
TRLocalizedText trLocalizedText = new TRLocalizedText();
|
||||||
trLocalizedText.setId(i);
|
trLocalizedText.setId(i);
|
||||||
trLocalizedText.setValue(lt.getValue());
|
trLocalizedText.setValue(lt.getValue());
|
||||||
trLocalizedText.setLocaleCode(lt.getLocale());
|
trLocalizedText.setLocaleCode(lt.getLocale());
|
||||||
listTRLocalizedText.add(trLocalizedText);
|
listTRLocalizedText.add(trLocalizedText);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
trNamesMetadata.setListTRLocalizedText(listTRLocalizedText);
|
trNamesMetadata
|
||||||
|
.setListTRLocalizedText(listTRLocalizedText);
|
||||||
listTRMetadata.add(trNamesMetadata);
|
listTRMetadata.add(trNamesMetadata);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if(tMetadata instanceof VersionMetadata){
|
if (tMetadata instanceof VersionMetadata) {
|
||||||
TRVersionMetadata trVersionMetadata=new TRVersionMetadata();
|
TRVersionMetadata trVersionMetadata = new TRVersionMetadata();
|
||||||
trVersionMetadata.setVersion(((VersionMetadata)tMetadata).getVersion());
|
trVersionMetadata
|
||||||
|
.setVersion(((VersionMetadata) tMetadata)
|
||||||
|
.getVersion());
|
||||||
listTRMetadata.add(trVersionMetadata);
|
listTRMetadata.add(trVersionMetadata);
|
||||||
}else{
|
} else {
|
||||||
if(tMetadata instanceof ExportMetadata){
|
if (tMetadata instanceof ExportMetadata) {
|
||||||
TRExportMetadata trExportMetadata=new TRExportMetadata();
|
TRExportMetadata trExportMetadata = new TRExportMetadata();
|
||||||
trExportMetadata.setDestinationType(((ExportMetadata)tMetadata).getDestinationType());
|
trExportMetadata
|
||||||
trExportMetadata.setExportDate(sdf.format(((ExportMetadata)tMetadata).getExportDate()));
|
.setDestinationType(((ExportMetadata) tMetadata)
|
||||||
trExportMetadata.setUrl(((ExportMetadata)tMetadata).getUri());
|
.getDestinationType());
|
||||||
|
trExportMetadata.setExportDate(sdf
|
||||||
|
.format(((ExportMetadata) tMetadata)
|
||||||
|
.getExportDate()));
|
||||||
|
trExportMetadata
|
||||||
|
.setUrl(((ExportMetadata) tMetadata)
|
||||||
|
.getUri());
|
||||||
listTRMetadata.add(trExportMetadata);
|
listTRMetadata.add(trExportMetadata);
|
||||||
}else{
|
} else {
|
||||||
if(tMetadata instanceof ImportMetadata){
|
if (tMetadata instanceof ImportMetadata) {
|
||||||
TRImportMetadata trImportMetadata=new TRImportMetadata();
|
TRImportMetadata trImportMetadata = new TRImportMetadata();
|
||||||
trImportMetadata.setSourceType(((ImportMetadata)tMetadata).getSourceType());
|
trImportMetadata
|
||||||
trImportMetadata.setImportDate(sdf.format(((ImportMetadata)tMetadata).getImportDate()));
|
.setSourceType(((ImportMetadata) tMetadata)
|
||||||
trImportMetadata.setUrl(((ImportMetadata)tMetadata).getUri());
|
.getSourceType());
|
||||||
|
trImportMetadata
|
||||||
|
.setImportDate(sdf
|
||||||
|
.format(((ImportMetadata) tMetadata)
|
||||||
|
.getImportDate()));
|
||||||
|
trImportMetadata
|
||||||
|
.setUrl(((ImportMetadata) tMetadata)
|
||||||
|
.getUri());
|
||||||
listTRMetadata.add(trImportMetadata);
|
listTRMetadata.add(trImportMetadata);
|
||||||
}else{
|
} else {
|
||||||
if(tMetadata instanceof GenericMapMetadata){
|
if (tMetadata instanceof GenericMapMetadata) {
|
||||||
TRGenericMapMetadata trGenericMapMetadata=new TRGenericMapMetadata();
|
TRGenericMapMetadata trGenericMapMetadata = new TRGenericMapMetadata();
|
||||||
trGenericMapMetadata.setMetadataMap(((GenericMapMetadata)tMetadata).getMetadataMap());
|
trGenericMapMetadata
|
||||||
listTRMetadata.add(trGenericMapMetadata);
|
.setMetadataMap(((GenericMapMetadata) tMetadata)
|
||||||
}else{
|
.getMetadataMap());
|
||||||
|
listTRMetadata
|
||||||
|
.add(trGenericMapMetadata);
|
||||||
|
} else {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1242,15 +1275,194 @@ public class TDGWTServiceImpl extends RemoteServiceServlet implements
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return listTRMetadata;
|
return listTRMetadata;
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
logger.error("Error in getTableMetadata(): " + e.getLocalizedMessage(),
|
logger.error(
|
||||||
|
"Error in getTableMetadata(): " + e.getLocalizedMessage(),
|
||||||
e);
|
e);
|
||||||
throw new TDGWTServiceException("Error in getTableMetadata(): "
|
throw new TDGWTServiceException("Error in getTableMetadata(): "
|
||||||
+ e.getLocalizedMessage());
|
+ e.getLocalizedMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param exportSession
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
protected Map<String, Object> csvExportFileParameter(
|
||||||
|
CSVExportSession exportSession) {
|
||||||
|
Map<String, Object> parameterInstances = new HashMap<String, Object>();
|
||||||
|
parameterInstances.put(Constants.ENCODING, exportSession.getEncoding());
|
||||||
|
parameterInstances.put(Constants.SEPARATOR,
|
||||||
|
exportSession.getSeparator());
|
||||||
|
parameterInstances.put(Constants.COLUMNS, exportSession.getColumns());
|
||||||
|
// TODO
|
||||||
|
|
||||||
|
/*
|
||||||
|
* List<String> columns = Lists.newArrayList(); for(Column column :
|
||||||
|
* table.getColumns()) if (!(column.getColumnType() instanceof
|
||||||
|
* IdColumnType)) columns.add(column.getName());
|
||||||
|
*
|
||||||
|
* instances.put(Constants.COLUMNS, columns);
|
||||||
|
*/
|
||||||
|
|
||||||
|
return parameterInstances;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public void startCSVExport(CSVExportSession exportSession)
|
||||||
|
throws TDGWTServiceException {
|
||||||
|
logger.debug("Start CSV Export");
|
||||||
|
session = this.getThreadLocalRequest().getSession();
|
||||||
|
if (session == null) {
|
||||||
|
throw new TDGWTServiceException(
|
||||||
|
"Error retrieving the session: null");
|
||||||
|
}
|
||||||
|
logger.info("Session:" + session.getId());
|
||||||
|
|
||||||
|
aslSession = SessionUtil.getAslSession(session);
|
||||||
|
if (aslSession == null) {
|
||||||
|
throw new TDGWTServiceException(
|
||||||
|
"Error retrieving the asl session: null");
|
||||||
|
}
|
||||||
|
String user = aslSession.getUsername();
|
||||||
|
logger.info("Session User:" + user);
|
||||||
|
|
||||||
|
TRId trId = SessionUtil.getTRId(session);
|
||||||
|
if (trId == null) {
|
||||||
|
throw new TDGWTServiceException(
|
||||||
|
"Error no tabular resource in session");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (trId.getTableId() == null) {
|
||||||
|
throw new TDGWTServiceException("Error no table present in session");
|
||||||
|
}
|
||||||
|
|
||||||
|
Map<String, Object> parameterInstance = csvExportFileParameter(exportSession);
|
||||||
|
|
||||||
|
logger.debug("Tabular Data Service");
|
||||||
|
service = TabularDataServiceFactory
|
||||||
|
.getService(aslSession.getUsername());
|
||||||
|
|
||||||
|
List<OperationDescriptor> capabilities = service.getCapabilities();
|
||||||
|
|
||||||
|
// Export CSV file
|
||||||
|
|
||||||
|
OperationDescriptor exportCSVFileOperation = getOperationDescriptorWithId(
|
||||||
|
OperationsId.CSVExport.toString(), capabilities);
|
||||||
|
|
||||||
|
InvocationCreator ic = InvocationCreator
|
||||||
|
.getCreator(exportCSVFileOperation);
|
||||||
|
OperationInvocation invocation = ic
|
||||||
|
.setTargetTable(new TableId(Long.valueOf(trId.getTableId())))
|
||||||
|
.setParameters(parameterInstance).create();
|
||||||
|
|
||||||
|
logger.debug("OperationInvocation: \n" + invocation.toString());
|
||||||
|
|
||||||
|
Task trTask;
|
||||||
|
try {
|
||||||
|
trTask = service.execute(invocation,
|
||||||
|
new TabularResourceId(Long.valueOf(trId.getId())));
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
throw new TDGWTServiceException(
|
||||||
|
"Tabular Data Service error exporting TabularResource: "
|
||||||
|
+ e.getLocalizedMessage());
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.debug("Start Task on service: TaskId " + trTask.getId());
|
||||||
|
SessionUtil.setCSVExportFileTask(session, trTask);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public CSVExportMonitor getCSVExportMonitor() throws TDGWTServiceException {
|
||||||
|
try {
|
||||||
|
session = this.getThreadLocalRequest().getSession();
|
||||||
|
aslSession = SessionUtil.getAslSession(session);
|
||||||
|
Task task = SessionUtil.getCSVExportFileTask(session);
|
||||||
|
CSVExportMonitor exportMonitor = new CSVExportMonitor();
|
||||||
|
|
||||||
|
if (task == null) {
|
||||||
|
logger.debug("Task null");
|
||||||
|
throw new TDGWTServiceException("Error in exportCSV task null");
|
||||||
|
} else {
|
||||||
|
TaskStatus status = task.getStatus();
|
||||||
|
if (status == null) {
|
||||||
|
throw new TDGWTServiceException(
|
||||||
|
"Error in exportCSV Status null");
|
||||||
|
} else {
|
||||||
|
logger.debug("Status: " + task.getStatus());
|
||||||
|
|
||||||
|
exportMonitor.setStatus(matchTaskState(task.getStatus()));
|
||||||
|
switch (exportMonitor.getStatus()) {
|
||||||
|
case FAILED:
|
||||||
|
if (task.getResult() != null) {
|
||||||
|
logger.debug("Task exception:"
|
||||||
|
+ task.getErrorCause());
|
||||||
|
exportMonitor.setError(task
|
||||||
|
.getErrorCause());
|
||||||
|
} else {
|
||||||
|
logger.debug("Task exception: Error In Export");
|
||||||
|
exportMonitor.setError(new Throwable(
|
||||||
|
"Error In Export"));
|
||||||
|
}
|
||||||
|
exportMonitor.setProgress(task.getProgress());
|
||||||
|
break;
|
||||||
|
case SUCCEDED:
|
||||||
|
logger.debug("Task Result:" + task.getResult());
|
||||||
|
exportMonitor.setProgress(task.getProgress());
|
||||||
|
Table table = task.getResult().getPrimaryTable();
|
||||||
|
logger.debug("Table retrived: " + table.toString());
|
||||||
|
ExportMetadata exportMetadata = table
|
||||||
|
.getMetadata(ExportMetadata.class);
|
||||||
|
logger.debug("ExportMetadata: " + exportMetadata);
|
||||||
|
|
||||||
|
exportMonitor.setTrId(SessionUtil.getTRId(session));
|
||||||
|
TRExportMetadata trExportMetadata = new TRExportMetadata();
|
||||||
|
trExportMetadata.setUrl(exportMetadata.getUri());
|
||||||
|
trExportMetadata.setDestinationType(exportMetadata
|
||||||
|
.getDestinationType());
|
||||||
|
trExportMetadata.setExportDate(sdf
|
||||||
|
.format(exportMetadata.getExportDate()));
|
||||||
|
exportMonitor.setTrExportMetadata(trExportMetadata);
|
||||||
|
|
||||||
|
break;
|
||||||
|
case IN_PROGRESS:
|
||||||
|
exportMonitor.setProgress(task.getProgress());
|
||||||
|
break;
|
||||||
|
case ABORTED:
|
||||||
|
break;
|
||||||
|
case INITIALIZING:
|
||||||
|
break;
|
||||||
|
case WAITING:
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
SessionUtil.setCSVExportFileTask(session, task);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
logger.info("getExportMonitor(): " + exportMonitor);
|
||||||
|
return exportMonitor;
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
throw new TDGWTServiceException(
|
||||||
|
"Error in exportCSV CSVExportMonitor: "
|
||||||
|
+ e.getLocalizedMessage());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,5 +16,10 @@ public class Constants {
|
||||||
public final static String DEFAULT_USER = "giancarlo.panichi";
|
public final static String DEFAULT_USER = "giancarlo.panichi";
|
||||||
public final static String DEFAULT_SCOPE = "/gcube/devsec";
|
public final static String DEFAULT_SCOPE = "/gcube/devsec";
|
||||||
|
|
||||||
|
public static final String ENCODING = "encoding";
|
||||||
|
public static final String HASHEADER = "hasHeader";
|
||||||
|
public static final String SEPARATOR = "separator";
|
||||||
|
public static final String COLUMNS = "columns";
|
||||||
|
public static final String URL = "url";
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,10 @@
|
||||||
package org.gcube.portlets.user.td.gwtservice.shared.csv;
|
package org.gcube.portlets.user.td.gwtservice.shared.csv;
|
||||||
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import org.gcube.portlets.user.td.gwtservice.shared.Constants;
|
||||||
import org.gcube.portlets.user.td.gwtservice.shared.destination.Destination;
|
import org.gcube.portlets.user.td.gwtservice.shared.destination.Destination;
|
||||||
|
|
||||||
|
|
||||||
|
@ -25,6 +28,29 @@ public class CSVExportSession implements Serializable {
|
||||||
protected String itemId;
|
protected String itemId;
|
||||||
protected String fileName;
|
protected String fileName;
|
||||||
|
|
||||||
|
protected ArrayList<String> columns;
|
||||||
|
protected String encoding;
|
||||||
|
protected String separator;
|
||||||
|
|
||||||
|
|
||||||
|
public ArrayList<String> getColumns() {
|
||||||
|
return columns;
|
||||||
|
}
|
||||||
|
public void setColumns(ArrayList<String> columns) {
|
||||||
|
this.columns = columns;
|
||||||
|
}
|
||||||
|
public String getEncoding() {
|
||||||
|
return encoding;
|
||||||
|
}
|
||||||
|
public void setEncoding(String encoding) {
|
||||||
|
this.encoding = encoding;
|
||||||
|
}
|
||||||
|
public String getSeparator() {
|
||||||
|
return separator;
|
||||||
|
}
|
||||||
|
public void setSeparator(String separator) {
|
||||||
|
this.separator = separator;
|
||||||
|
}
|
||||||
public String getId() {
|
public String getId() {
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
@ -52,11 +78,15 @@ public class CSVExportSession implements Serializable {
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "CSVExportSession [id=" + id + ", destination=" + destination
|
return "CSVExportSession [id=" + id + ", destination=" + destination
|
||||||
+ ", itemId=" + itemId + ", fileName=" + fileName + "]";
|
+ ", itemId=" + itemId + ", fileName=" + fileName
|
||||||
|
+ ", columns=" + columns + ", encoding=" + encoding
|
||||||
|
+ ", separator=" + separator + "]";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,7 +28,10 @@ public class TestServiceOperations {
|
||||||
System.out
|
System.out
|
||||||
.println("------------Tabular Resource Operation--------------");
|
.println("------------Tabular Resource Operation--------------");
|
||||||
for (OperationDescriptor operation : trOperations) {
|
for (OperationDescriptor operation : trOperations) {
|
||||||
System.out.println(operation.toString());
|
System.out.println("Name: "+operation.getName());
|
||||||
|
System.out.println("Scope: "+operation.getScope());
|
||||||
|
System.out.println("Desc: "+operation.toString());
|
||||||
|
System.out.println("-----------------------------------");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue