mirror of
https://github.com/ckaczor/sqltoolsservice.git
synced 2026-02-13 11:38:33 -05:00
Close connection after backup execution (#449)
This commit is contained in:
@@ -308,8 +308,6 @@ namespace Microsoft.SqlTools.ServiceLayer.DisasterRecovery
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
catch(Exception)
|
catch(Exception)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ using Microsoft.SqlTools.ServiceLayer.TaskServices;
|
|||||||
using System.Threading;
|
using System.Threading;
|
||||||
using Microsoft.SqlTools.ServiceLayer.DisasterRecovery.RestoreOperation;
|
using Microsoft.SqlTools.ServiceLayer.DisasterRecovery.RestoreOperation;
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
|
using Microsoft.SqlTools.ServiceLayer.Connection.Contracts;
|
||||||
|
|
||||||
namespace Microsoft.SqlTools.ServiceLayer.DisasterRecovery
|
namespace Microsoft.SqlTools.ServiceLayer.DisasterRecovery
|
||||||
{
|
{
|
||||||
@@ -281,6 +282,7 @@ namespace Microsoft.SqlTools.ServiceLayer.DisasterRecovery
|
|||||||
TaskMetadata metadata = TaskMetadata.Create(backupParams, SR.BackupTaskName, backupOperation, ConnectionServiceInstance);
|
TaskMetadata metadata = TaskMetadata.Create(backupParams, SR.BackupTaskName, backupOperation, ConnectionServiceInstance);
|
||||||
|
|
||||||
sqlTask = SqlTaskManagerInstance.CreateAndRun<SqlTask>(metadata);
|
sqlTask = SqlTaskManagerInstance.CreateAndRun<SqlTask>(metadata);
|
||||||
|
sqlTask.StatusChanged += CloseConnection;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -352,6 +354,18 @@ namespace Microsoft.SqlTools.ServiceLayer.DisasterRecovery
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void CloseConnection(object sender, TaskEventArgs<SqlTaskStatus> e)
|
||||||
|
{
|
||||||
|
SqlTask sqlTask = e.SqlTask;
|
||||||
|
if (sqlTask != null && sqlTask.IsCompleted)
|
||||||
|
{
|
||||||
|
connectionService.Disconnect(new DisconnectParams()
|
||||||
|
{
|
||||||
|
OwnerUri = sqlTask.TaskMetadata.OwnerUri
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private BackupOperation CreateBackupOperation(CDataContainer dataContainer, SqlConnection sqlConnection)
|
private BackupOperation CreateBackupOperation(CDataContainer dataContainer, SqlConnection sqlConnection)
|
||||||
{
|
{
|
||||||
BackupOperation backupOperation = new BackupOperation();
|
BackupOperation backupOperation = new BackupOperation();
|
||||||
|
|||||||
@@ -46,6 +46,11 @@ namespace Microsoft.SqlTools.ServiceLayer.TaskServices
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public ITaskOperation TaskOperation { get; set; }
|
public ITaskOperation TaskOperation { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Connection uri
|
||||||
|
/// </summary>
|
||||||
|
public string OwnerUri { get; set; }
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Creates task metadata given the request parameters
|
/// Creates task metadata given the request parameters
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -84,6 +89,8 @@ namespace Microsoft.SqlTools.ServiceLayer.TaskServices
|
|||||||
taskMetadata.TaskExecutionMode = scriptableRequestParams.TaskExecutionMode;
|
taskMetadata.TaskExecutionMode = scriptableRequestParams.TaskExecutionMode;
|
||||||
|
|
||||||
taskMetadata.TaskOperation = taskOperation;
|
taskMetadata.TaskOperation = taskOperation;
|
||||||
|
taskMetadata.OwnerUri = requestParam.OwnerUri;
|
||||||
|
|
||||||
return taskMetadata;
|
return taskMetadata;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user