/// <summary> /// Bekrefte at endringslogg er lastet ned /// </summary> /// <returns></returns> public bool AcknowledgeChangelogDownloaded(int datasetId, string changelogId) { try { var dataset = SubscriberDatasetManager.GetDataset(datasetId); var client = buildClient(dataset); var id = new ChangelogIdentificationType { changelogId = changelogId }; client.AcknowlegeChangelogDownloaded(id); return(true); } catch (WebException webEx) { if (webEx.Status == WebExceptionStatus.Success) { return(false); } Logger.Error(webEx, "AcknowledgeChangelogDownloaded WebException:"); throw; } catch (Exception ex) { Logger.Error(ex, "AcknowledgeChangelogDownloaded failed:"); throw; } }
/// <summary> /// Get and download changelog /// </summary> /// <param name="datasetId"></param> /// <param name="changelogId"></param> /// <param name="downloadController"></param> /// <returns></returns> public bool GetChangelog(int datasetId, string changelogId, out DownloadController downloadController) { try { var dataset = SubscriberDatasetManager.GetDataset(datasetId); var client = buildClient(dataset); var id = new ChangelogIdentificationType { changelogId = changelogId }; var resp = client.GetChangelog(id); var downloaduri = resp.downloadUri; // 20151215-Leg: Norkart downloaduri may contain .zip Logger.Info("GetChangelog downloaduri: " + downloaduri); var changelogDir = string.IsNullOrEmpty(dataset.ChangelogDirectory) ? Environment.GetEnvironmentVariable("TEMP") : dataset.ChangelogDirectory; #if (NOT_FTP) string fileName = changelogDir + @"\" + changelogid + "_Changelog.xml"; #else CreateFolderIfMissing(changelogDir); const string ftpPath = "abonnent"; CreateFolderIfMissing(changelogDir + @"\" + ftpPath); // Create the abonnent folder if missing var fileName = changelogDir + @"\" + ftpPath + @"\" + Path.GetFileName(downloaduri); #endif downloadController = new DownloadController { ChangelogFilename = fileName }; downloadController.DownloadChangelog(downloaduri, dataset); } catch (WebException webEx) { Logger.Error("GetChangelog failed:", webEx); throw; } catch (Exception ex) { Logger.Error(ex, "GetChangelog failed:"); throw; } return(true); }
/// <summary> /// Get ChangelogStatus Response /// </summary> /// <param name="datasetId"></param> /// <param name="changelogId"></param> /// <returns></returns> public ChangelogStatusType GetChangelogStatusResponse(int datasetId, string changelogId) { try { var dataset = SubscriberDatasetManager.GetDataset(datasetId); var client = buildClient(dataset); var id = new ChangelogIdentificationType { changelogId = changelogId }; var resp = client.GetChangelogStatus(id); return(resp); } catch (Exception ex) { Logger.Error(ex, "GetChangelogStatusResponse failed:"); throw; } }