use of org.jkiss.dbeaver.runtime.jobs.InvalidateJob in project dbeaver by serge-rider.
the class DataSourceInvalidateHandler method execute.
public static void execute(final Shell shell, final DBCExecutionContext context) {
if (context != null) {
//final DataSourceDescriptor dataSourceDescriptor = (DataSourceDescriptor) context;
if (!ArrayUtils.isEmpty(Job.getJobManager().find(context.getDataSource().getContainer()))) {
// Already connecting/disconnecting - just return
return;
}
final InvalidateJob invalidateJob = new InvalidateJob(context);
invalidateJob.addJobChangeListener(new JobChangeAdapter() {
@Override
public void done(IJobChangeEvent event) {
StringBuilder message = new StringBuilder();
Throwable error = null;
int totalNum = 0, connectedNum = 0, aliveNum = 0;
for (InvalidateJob.ContextInvalidateResult result : invalidateJob.getInvalidateResults()) {
totalNum++;
if (result.error != null) {
error = result.error;
}
switch(result.result) {
case CONNECTED:
case RECONNECTED:
connectedNum++;
break;
case ALIVE:
aliveNum++;
break;
default:
break;
}
}
if (connectedNum > 0) {
message.insert(0, "Connections reopened: " + connectedNum + " (of " + totalNum + ")");
} else if (message.length() == 0) {
message.insert(0, "All connections (" + totalNum + ") are alive!");
}
if (error != null) {
// UIUtils.showErrorDialog(
// shell,
// "Invalidate data source [" + context.getDataSource().getContainer().getName() + "]",
// "Error while connecting to the datasource",// + "\nTime spent: " + RuntimeUtils.formatExecutionTime(invalidateJob.getTimeSpent()),
// error);
DBeaverUI.syncExec(new Runnable() {
@Override
public void run() {
}
});
final DBPDataSourceContainer container = context.getDataSource().getContainer();
final Throwable dialogError = error;
final Integer result = new UITask<Integer>() {
@Override
protected Integer runTask() {
ConnectionLostDialog clDialog = new ConnectionLostDialog(shell, container, dialogError, "Disconnect");
return clDialog.open();
}
}.execute();
if (result == IDialogConstants.STOP_ID) {
// Disconnect - to notify UI and reflect model changes
new DisconnectJob(container).schedule();
} else if (result == IDialogConstants.RETRY_ID) {
execute(shell, context);
}
} else {
log.info(message);
}
}
});
invalidateJob.schedule();
}
}
Aggregations