use of org.pentaho.ui.database.event.IDatabaseConnectionList in project data-access by pentaho.
the class ConnectionService method getConnections.
/**
* Returns the list of database connections
*
* @return List of database connections
*
* @throws ConnectionServiceException
*/
@GET
@Path("/list")
@Produces({ APPLICATION_JSON })
@Facet(name = "Unsupported")
public IDatabaseConnectionList getConnections() throws ConnectionServiceException {
IDatabaseConnectionList databaseConnections = new DefaultDatabaseConnectionList();
List<IDatabaseConnection> conns = connectionService.getConnections(true);
databaseConnections.setDatabaseConnections(conns);
return databaseConnections;
}
use of org.pentaho.ui.database.event.IDatabaseConnectionList in project data-access by pentaho.
the class AnalysisImportDialogController method reloadConnections.
private void reloadConnections() {
String cacheBuster = "?ts=" + new java.util.Date().getTime();
RequestBuilder listConnectionBuilder = new RequestBuilder(RequestBuilder.GET, getBaseURL() + "list" + cacheBuster);
listConnectionBuilder.setHeader("Content-Type", "application/json");
listConnectionBuilder.setHeader("If-Modified-Since", "01 Jan 1970 00:00:00 GMT");
try {
listConnectionBuilder.sendRequest(null, new RequestCallback() {
@Override
public void onError(Request request, Throwable exception) {
exception.printStackTrace();
MessageHandler.getInstance().showErrorDialog(exception.getMessage());
}
@Override
public void onResponseReceived(Request request, Response response) {
AutoBean<IDatabaseConnectionList> bean = AutoBeanCodex.decode(connectionAutoBeanFactory, IDatabaseConnectionList.class, response.getText());
List<IDatabaseConnection> databaseConnections = bean.as().getDatabaseConnections();
List<IDatabaseConnection> standardDatabaseConnections = new ArrayList();
// take anything except connections where STANDARD_CONNECTION == false
for (IDatabaseConnection databaseConnection : databaseConnections) {
if ((databaseConnection.getAttributes() == null) || (databaseConnection.getAttributes().get(ATTRIBUTE_STANDARD_CONNECTION) == null) || (databaseConnection.getAttributes().get(ATTRIBUTE_STANDARD_CONNECTION) == Boolean.TRUE.toString())) {
standardDatabaseConnections.add(databaseConnection);
}
}
importDialogModel.setConnectionList(standardDatabaseConnections);
}
});
} catch (RequestException e) {
MessageHandler.getInstance().showErrorDialog(MessageHandler.getString("ERROR"), "DatasourceEditor.ERROR_0004_CONNECTION_SERVICE_NULL");
}
}
use of org.pentaho.ui.database.event.IDatabaseConnectionList in project data-access by pentaho.
the class ConnectionController method reloadConnections.
public void reloadConnections() {
String cacheBuster = String.valueOf(new java.util.Date().getTime());
String[][] params = new String[][] { { "ts", cacheBuster } };
RequestBuilder listConnectionBuilder = new RequestBuilder(RequestBuilder.GET, getServiceURL("list", params));
listConnectionBuilder.setHeader("Content-Type", "application/json");
try {
listConnectionBuilder.sendRequest(null, new RequestCallback() {
@Override
public void onError(Request request, Throwable exception) {
MessageHandler.getInstance().showErrorDialog(MessageHandler.getString("ERROR"), MessageHandler.getString("DatasourceEditor.ERROR_0002_UNABLE_TO_SHOW_DIALOG", exception.getLocalizedMessage()));
}
@Override
public void onResponseReceived(Request request, Response response) {
AutoBean<IDatabaseConnectionList> bean = AutoBeanCodex.decode(connectionAutoBeanFactory, IDatabaseConnectionList.class, response.getText());
List<IDatabaseConnection> connectionBeanList = bean.as().getDatabaseConnections();
List<IDatabaseConnection> connectionImplList = new ArrayList<IDatabaseConnection>();
for (IDatabaseConnection connectionBean : connectionBeanList) {
try {
// take anything except connections where STANDARD_CONNECTION == false
if ((connectionBean.getAttributes() == null) || (connectionBean.getAttributes().get(ATTRIBUTE_STANDARD_CONNECTION) == null) || (connectionBean.getAttributes().get(ATTRIBUTE_STANDARD_CONNECTION) == Boolean.TRUE.toString())) {
connectionImplList.add(AutobeanUtilities.connectionBeanToImpl(connectionBean));
}
} catch (Exception e) {
// skip invalid connections that couldn't be converted to IDatabaseConnection
}
}
if (datasourceModel != null) {
datasourceModel.getGuiStateModel().setConnections(connectionImplList);
}
}
});
} catch (RequestException e) {
MessageHandler.getInstance().showErrorDialog(MessageHandler.getString("ERROR"), "DatasourceEditor.ERROR_0004_CONNECTION_SERVICE_NULL");
}
}
use of org.pentaho.ui.database.event.IDatabaseConnectionList in project data-access by pentaho.
the class JdbcDatasourceService method getIds.
@Override
public void getIds(final XulServiceCallback<List<IDatasourceInfo>> callback) {
RequestBuilder requestBuilder = new RequestBuilder(RequestBuilder.GET, getMetadataBaseURL() + "getDatasourcePermissions");
requestBuilder.setHeader("Content-Type", "application/json");
try {
requestBuilder.sendRequest(null, new RequestCallback() {
public void onError(Request request, Throwable exception) {
callback.error(exception.getMessage(), exception);
}
public void onResponseReceived(Request request, Response response) {
if (response.getText().equals("EDIT")) {
String cacheBuster = "?ts=" + new java.util.Date().getTime();
RequestBuilder listConnectionBuilder = new RequestBuilder(RequestBuilder.GET, getBaseURL() + "list" + cacheBuster);
listConnectionBuilder.setHeader("Content-Type", "application/json");
try {
listConnectionBuilder.sendRequest(null, new RequestCallback() {
@Override
public void onError(Request request, Throwable exception) {
callback.error(exception.getMessage(), exception);
}
@Override
public void onResponseReceived(Request request, Response response) {
AutoBean<IDatabaseConnectionList> bean = AutoBeanCodex.decode(connectionAutoBeanFactory, IDatabaseConnectionList.class, response.getText());
List<IDatabaseConnection> connections = bean.as().getDatabaseConnections();
List<IDatasourceInfo> datasourceInfos = new ArrayList<IDatasourceInfo>();
for (IDatabaseConnection connection : connections) {
// check attributes to make sure we only return "standard" connections which can be managed
Map<String, String> attributes = connection.getAttributes();
if (attributes.containsKey(ATTRIBUTE_STANDARD_CONNECTION)) {
if (attributes.get(ATTRIBUTE_STANDARD_CONNECTION).equals(Boolean.FALSE.toString())) {
continue;
}
}
datasourceInfos.add(new DatasourceInfo(connection.getName(), connection.getName(), TYPE, editable, removable, importable, exportable));
}
callback.success(datasourceInfos);
}
});
} catch (RequestException e) {
callback.error(e.getMessage(), e);
}
}
}
});
} catch (RequestException e) {
callback.error(e.getMessage(), e);
}
}
Aggregations