public static DossierLog CreateLog(Dossier dossier, DossierFolder dossierFolder, DossierLogType logType, string logDescription, string registrationUser) { DossierLog dossierLog = new DossierLog() { LogType = logType, LogDescription = logDescription, SystemComputer = Environment.MachineName, RegistrationDate = DateTimeOffset.UtcNow, RegistrationUser = registrationUser, Entity = dossier, DossierFolder = dossierFolder }; dossierLog.Hash = HashGenerator.GenerateHash($"{dossierLog.RegistrationUser}|{dossierLog.LogType}|{dossierLog.LogDescription}|{dossierLog.UniqueId}|{dossier.UniqueId}|{dossierLog.RegistrationDate:yyyyMMddHHmmss}"); return(dossierLog); }
private void CreateOrUpdateFolderHystoryLog(DossierFolder entityTransformed) { DossierLog logDossier = _unitOfWork.Repository <DossierLog>().GetFolderHystoryLog(entityTransformed.UniqueId).SingleOrDefault(); DossierFolder toStore = new DossierFolder() { Name = entityTransformed.Name }; string serializedEntity = JsonConvert.SerializeObject(toStore, DefaultJsonSerializer); if (logDossier == null) { _unitOfWork.Repository <DossierLog>().Insert(BaseDossierService <DossierLog> .CreateLog(entityTransformed.Dossier, entityTransformed, DossierLogType.FolderHystory, serializedEntity, CurrentDomainUser.Account)); return; } logDossier.LogDescription = serializedEntity; _unitOfWork.Repository <DossierLog>().Update(logDossier); }
protected override DossierFolder BeforeUpdate(DossierFolder entity, DossierFolder entityTransformed) { if (CurrentUpdateActionType.HasValue && CurrentUpdateActionType == Common.Infrastructures.UpdateActionType.CloneProcessDetails) { _unitOfWork.Repository <DossierFolder>().ExecuteProcedure(CommonDefinition.SQL_SP_DossierFolder_UpdateHierarchy, new QueryParameter(CommonDefinition.SQL_Param_DossierFolder_IdDossier, entity.Dossier.UniqueId)); entityTransformed.JsonMetadata = null; entityTransformed.Name = entity.Name.Substring(2, entity.Name.Length - 2); return(base.BeforeUpdate(entity, entityTransformed)); } bool hasFascicle = entityTransformed.Fascicle != null; entityTransformed.Status = DossierFolderStatus.InProgress; if (_unitOfWork.Repository <DossierFolder>().CountChildren(entity.UniqueId) > 0) { entityTransformed.Status = DossierFolderStatus.Folder; } Guid?actualIdFascicle = entityTransformed.Fascicle == null ? null : new Guid?(entityTransformed.Fascicle.UniqueId); entityTransformed.Fascicle = null; if (entity.Dossier != null) { entityTransformed.Dossier = _unitOfWork.Repository <Dossier>().Find(entity.Dossier.UniqueId); } if (entity.Category != null) { entityTransformed.Category = _unitOfWork.Repository <Category>().Find(entity.Category.EntityShortId); } if (entity.Fascicle != null) { entityTransformed.Fascicle = _unitOfWork.Repository <Fascicle>().Find(entity.Fascicle.UniqueId); entityTransformed.Status = DossierFolderStatus.Fascicle; CreateOrUpdateFolderHystoryLog(entityTransformed); entityTransformed.Name = string.Concat(entityTransformed.Fascicle.Title, "-", entityTransformed.Fascicle.FascicleObject); _unitOfWork.Repository <DossierLog>().Insert(BaseDossierService <DossierLog> .CreateLog(entityTransformed.Dossier, entityTransformed, DossierLogType.FolderModify, string.Concat("Aggiornata la cartella '", entityTransformed.Name, "' con fascicolo associato '", entityTransformed.Fascicle.Title, "-", entityTransformed.Fascicle.FascicleObject, "'"), CurrentDomainUser.Account)); } if (CurrentUpdateActionType.HasValue && CurrentUpdateActionType == Common.Infrastructures.UpdateActionType.DossierFolderAuthorizationsPropagation) { _unitOfWork.Repository <DossierFolder>().ExecuteProcedure(CommonDefinition.SQL_SP_DossierFolder_PropagateAtuthorizationToDescendants, new QueryParameter(CommonDefinition.SQL_Param_DossierFolder_IdParent, entity.UniqueId), new QueryParameter(CommonDefinition.SQL_Param_DossierFolder_IdDossier, entity.Dossier.UniqueId), new QueryParameter(CommonDefinition.SQL_Param_DossierFolder_AuthorizationType, AuthorizationRoleType.Accounted), new QueryParameter(CommonDefinition.SQL_Param_DossierFolder_AuthorizationTypeDescription, AuthorizationRoleType.Accounted.ToString()), new QueryParameter(CommonDefinition.SQL_Param_DossierFolder_RegistrationUser, CurrentDomainUser.Account), new QueryParameter(CommonDefinition.SQL_Param_DossierFolder_System, Environment.MachineName)); UpdateHashLog(entityTransformed); } if (entityTransformed.Fascicle == null && hasFascicle) { foreach (DossierFolderRole item in entityTransformed.DossierFolderRoles.ToList()) { DeleteFascicleRole(item, actualIdFascicle); } DossierLog logDossier = _unitOfWork.Repository <DossierLog>().GetFolderHystoryLog(entityTransformed.UniqueId).SingleOrDefault(); DossierFolder oldEntity = logDossier == null ? null : JsonConvert.DeserializeObject <DossierFolder>(logDossier.LogDescription, DefaultJsonSerializer); string previousFascileName = string.Copy(entityTransformed.Name); if (oldEntity != null) { entityTransformed.Name = string.IsNullOrEmpty(oldEntity.Name) ? "Cartella vuota" : oldEntity.Name; } _unitOfWork.Repository <DossierLog>().Insert(BaseDossierService <DossierLog> .CreateLog(entityTransformed.Dossier, entityTransformed, DossierLogType.FolderFascicleRemove, string.Concat("Aggiornata la cartella '", entityTransformed.Name, "' con rimozione del fascicolo '", previousFascileName, "'"), CurrentDomainUser.Account)); } if (entity.DossierFolderRoles != null) { foreach (DossierFolderRole item in entityTransformed.DossierFolderRoles.Where(f => !entity.DossierFolderRoles.Any(c => c.UniqueId == f.UniqueId)).ToList()) { _unitOfWork.Repository <DossierLog>().Insert(BaseDossierService <DossierLog> .CreateLog(entityTransformed.Dossier, entityTransformed, DossierLogType.FolderAuthorize, string.Concat("Rimossa autorizzazione '", item.AuthorizationRoleType.ToString(), "' al settore '", item.Role.Name, "' (", item.Role.EntityShortId, ") alla cartella '", entity.Name, "'"), CurrentDomainUser.Account)); DeleteFascicleRole(item, actualIdFascicle); _unitOfWork.Repository <DossierFolderRole>().Delete(item); } DossierFolderRole newDossierFolderRole = null; foreach (DossierFolderRole item in entity.DossierFolderRoles.Where(f => !entityTransformed.DossierFolderRoles.Any(c => c.UniqueId == f.UniqueId))) { newDossierFolderRole = CreateDossierFolderRole(item, entityTransformed, _unitOfWork.Repository <Role>().Find(item.Role.EntityShortId)); if (newDossierFolderRole != null) { _unitOfWork.Repository <DossierFolderRole>().Insert(newDossierFolderRole); } } Role role; foreach (DossierFolderRole item in entity.DossierFolderRoles.Where(f => entityTransformed.DossierFolderRoles.Any(c => c.UniqueId == f.UniqueId))) { if (entityTransformed.Fascicle != null && !_unitOfWork.Repository <FascicleRole>().ExistFascicleRolesAccounted(entityTransformed.Fascicle.UniqueId, item.Role.EntityShortId)) { role = _unitOfWork.Repository <Role>().Find(item.Role.EntityShortId); CreateFascicleRole(entityTransformed, AuthorizationRoleType.Accounted, role); } } } _unitOfWork.Repository <DossierLog>().Insert(BaseDossierService <DossierLog> .CreateLog(entityTransformed.Dossier, entityTransformed, DossierLogType.FolderModify, string.Concat("Aggiornata la cartella '", entityTransformed.Name, "'"), CurrentDomainUser.Account)); return(base.BeforeUpdate(entity, entityTransformed)); }