void PerformSaveResult(out ResourceCatalogResult saveResult, Guid workspaceID, IResource resource, StringBuilder contents, bool overwriteExisting, string savedPath, string reason = "") { var fileManager = new TxFileManager(); using (TransactionScope tx = new TransactionScope(TransactionScopeOption.RequiresNew)) { try { var resources = _resourceCatalog.GetResources(workspaceID); var conflicting = resources.FirstOrDefault(r => resource.ResourceID != r.ResourceID && r.GetResourcePath(workspaceID) != null && r.GetResourcePath(workspaceID).Equals(savedPath + "\\" + resource.ResourceName, StringComparison.InvariantCultureIgnoreCase) && r.ResourceName.Equals(resource.ResourceName, StringComparison.InvariantCultureIgnoreCase)); if (conflicting != null && !conflicting.IsNewResource || conflicting != null && !overwriteExisting) { saveResult = ResourceCatalogResultBuilder.CreateDuplicateMatchResult(string.Format(ErrorResource.TypeConflict, conflicting.ResourceType)); return; } contents = GetExistingResource(resource, contents, reason, resources); var directoryName = SetResourceFilePath(workspaceID, resource, ref savedPath); var xml = SaveToDisk(resource, contents, directoryName, fileManager); var updated = AddToCatalog(resource, resources, fileManager, xml); _resourceCatalog.AddToActivityCache(resource); Dev2Logger.Debug($"Removing Execution Plan for {resource.ResourceID} for workspace {workspaceID}", GlobalConstants.WarewolfDebug); _resourceCatalog.RemoveFromResourceActivityCache(workspaceID, resource); Dev2Logger.Debug($"Removed Execution Plan for {resource.ResourceID} for workspace {workspaceID}", GlobalConstants.WarewolfDebug); Dev2Logger.Debug($"Adding Execution Plan for {resource.ResourceID} for workspace {workspaceID}", GlobalConstants.WarewolfDebug); _resourceCatalog.Parse(workspaceID, resource); Dev2Logger.Debug($"Added Execution Plan for {resource.ResourceID} for workspace {workspaceID}", GlobalConstants.WarewolfDebug); tx.Complete(); saveResult = ResourceCatalogResultBuilder.CreateSuccessResult($"{(updated ? "Updated" : "Added")} {resource.ResourceType} '{resource.ResourceName}'"); } catch (Exception e) { Dev2Logger.Warn($"Error saving {resource.ResourceName}. " + e.Message, GlobalConstants.WarewolfWarn); Transaction.Current.Rollback(); //the process should not be terminated because of just one failure saveResult = ResourceCatalogResultBuilder.CreateFailResult(string.Format(ErrorResource.ErrorDuringSaveCallback, resource.ResourceID) + "' message " + e.Message); } } }
ResourceCatalogResult DeleteFromWorkspace(Guid workspaceID, Guid resourceID, string type, bool deleteVersions) { var @lock = Common.GetWorkspaceLock(workspaceID); lock (@lock) { if (resourceID == Guid.Empty || string.IsNullOrEmpty(type)) { throw new InvalidDataContractException(ErrorResource.ResourceNameAndTypeMissing); } var workspaceResources = _resourceCatalog.GetResources(workspaceID); var resources = workspaceResources.FindAll(r => Equals(r.ResourceID, resourceID)); var commands = GetDeleteCommands(workspaceID, resourceID, type, deleteVersions, resources, workspaceResources); if (commands.ContainsKey(resources.Count)) { var resourceCatalogResult = commands[resources.Count]; return(resourceCatalogResult); } return(ResourceCatalogResultBuilder.CreateDuplicateMatchResult($"<Result>Multiple matches found for {type} '{resourceID}'.</Result>")); } }
public ResourceCatalogResult DeleteResource(Guid workspaceID, string resourceName, string type, bool deleteVersions) { var @lock = Common.GetWorkspaceLock(workspaceID); lock (@lock) { if (resourceName == "*") { var noWildcardsAllowedhResult = ResourceCatalogResultBuilder.CreateNoWildcardsAllowedhResult("<Result>Delete resources does not accept wildcards.</Result>."); return(noWildcardsAllowedhResult); } if (string.IsNullOrEmpty(resourceName) || string.IsNullOrEmpty(type)) { throw new InvalidDataContractException(ErrorResource.ResourceNameAndTypeMissing); } var workspaceResources = _resourceCatalog.GetResources(workspaceID); var resources = _resourceCatalog.GetResourcesBasedOnType(type, workspaceResources, r => string.Equals(r.ResourceName, resourceName, StringComparison.InvariantCultureIgnoreCase)); var commands = new Dictionary <int, ResourceCatalogResult>() { { 0, ResourceCatalogResultBuilder.CreateNoMatchResult($"<Result>{type} '{resourceName}' was not found.</Result>") }, { 1, DeleteImpl(workspaceID, resources, workspaceResources, deleteVersions) }, }; if (commands.ContainsKey(resources.Count)) { var resourceCatalogResult = commands[resources.Count]; return(resourceCatalogResult); } return(ResourceCatalogResultBuilder.CreateDuplicateMatchResult($"<Result>Multiple matches found for {type} '{resourceName}'.</Result>")); } }
private void PerformSaveResult(out ResourceCatalogResult saveResult, Guid workspaceID, IResource resource, StringBuilder contents, bool overwriteExisting, string savedPath) { var fileManager = new TxFileManager(); using (TransactionScope tx = new TransactionScope()) { try { var resources = _resourceCatalog.GetResources(workspaceID); var conflicting = resources.FirstOrDefault(r => resource.ResourceID != r.ResourceID && r.GetResourcePath(workspaceID) != null && r.GetResourcePath(workspaceID).Equals(savedPath + "\\" + resource.ResourceName, StringComparison.InvariantCultureIgnoreCase) && r.ResourceName.Equals(resource.ResourceName, StringComparison.InvariantCultureIgnoreCase)); if (conflicting != null && !conflicting.IsNewResource || conflicting != null && !overwriteExisting) { saveResult = ResourceCatalogResultBuilder.CreateDuplicateMatchResult(string.Format(ErrorResource.TypeConflict, conflicting.ResourceType)); return; } var res = resources.FirstOrDefault(p => p.ResourceID == resource.ResourceID); if (res != null) //Found Existing resource { if (res.ResourceName != resource.ResourceName) // Renamed while open { var resourceXml = contents.ToXElement(); resourceXml.SetAttributeValue("Name", res.ResourceName); resourceXml.SetElementValue("DisplayName", res.ResourceName); var actionElement = resourceXml.Element("Action"); var xamlElement = actionElement?.Element("XamlDefinition"); if (xamlElement != null) { var xamlContent = xamlElement.Value; xamlElement.Value = xamlContent. Replace("x:Class=\"" + resource.ResourceName + "\"", "x:Class=\"" + res.ResourceName + "\"") .Replace("Flowchart DisplayName=\"" + resource.ResourceName + "\"", "Flowchart DisplayName=\"" + res.ResourceName + "\""); } resource.ResourceName = res.ResourceName; contents = resourceXml.ToStringBuilder(); } } var directoryName = SetResourceFilePath(workspaceID, resource, ref savedPath); #region Save to disk var xml = SaveToDisk(resource, contents, directoryName, fileManager); #endregion #region Add to catalog var updated = AddToCatalog(resource, resources, fileManager, xml); #endregion Dev2Logger.Debug($"Removing Execution Plan for {resource.ResourceID} for workspace {workspaceID}"); ((ResourceCatalog)_resourceCatalog).RemoveFromResourceActivityCache(workspaceID, resource); Dev2Logger.Debug($"Removed Execution Plan for {resource.ResourceID} for workspace {workspaceID}"); Dev2Logger.Debug($"Adding Execution Plan for {resource.ResourceID} for workspace {workspaceID}"); ((ResourceCatalog)_resourceCatalog).Parse(workspaceID, resource.ResourceID); Dev2Logger.Debug($"Added Execution Plan for {resource.ResourceID} for workspace {workspaceID}"); tx.Complete(); saveResult = ResourceCatalogResultBuilder.CreateSuccessResult($"{(updated ? "Updated" : "Added")} {resource.ResourceType} '{resource.ResourceName}'"); } catch (Exception) { Transaction.Current.Rollback(); throw; } } }