public string GetAdminByName(string codAmm) { try { // prende la system_id dell'amm.ne DocsPaDB.Query_DocsPAWS.AmministrazioneXml amm = new DocsPaDB.Query_DocsPAWS.AmministrazioneXml(); return(amm.GetAdminByName(codAmm)); } catch (Exception ex) { logger.Debug(ex.Message.ToString(), ex); return(string.Empty); } }
/// <summary> /// conta quanti record di log ci sono sul db /// </summary> /// <param name="result"></param> /// <param name="codAmm"></param> public void ContaArchivioLog(out string result, string codAmm, string type) { result = ""; try { // prende la system_id dell'amm.ne DocsPaDB.Query_DocsPAWS.AmministrazioneXml amm = new DocsPaDB.Query_DocsPAWS.AmministrazioneXml(); string idAmm = amm.GetAdminByName(codAmm); DocsPaDB.Query_DocsPAWS.AmministrazioneXml log = new DocsPaDB.Query_DocsPAWS.AmministrazioneXml(); result = log.ContaArchivioLog(idAmm, type); } catch (Exception exception) { logger.Debug("Errore nel metodo ContaArchivioLog: ", exception); } }
/// <summary> /// /// </summary> /// <param name="classificazione"></param> /// <param name="fascicolo"></param> /// <param name="infoUtente"></param> /// <param name="ruolo"></param> /// <param name="enableUffRef"></param> /// <param name="folder"></param> /// <param name="codiceFasc"></param> /// <param name="dbProvider"></param> /// <returns></returns> private bool CreazioneFascicoloConTransazione(DocsPaVO.fascicolazione.Classificazione classificazione, DocsPaVO.fascicolazione.Fascicolo fascicolo, DocsPaVO.utente.InfoUtente infoUtente, DocsPaVO.utente.Ruolo ruolo, bool enableUffRef, DocsPaVO.fascicolazione.Folder folder, string codiceFasc, DocsPaDB.DBProvider dbProvider, out Ruolo[] ruoliSuperiori) { logger.Info("BEGIN"); bool result = true; ruoliSuperiori = null; DocsPaDB.Query_DocsPAWS.AmministrazioneXml objAX = new DocsPaDB.Query_DocsPAWS.AmministrazioneXml(); DocsPaDB.Query_DocsPAWS.Fascicoli fascicoli = new DocsPaDB.Query_DocsPAWS.Fascicoli(); string msgError = "errore nel metodo: creazioneFascicoloConTransazione - errore durante la creazione del fascicolo"; try { // 3 - Si calcola il formato del codice del fascicolo fascicolo.codice = codiceFasc; string chiaveFascicolo = this.CalcolaChiaveFascicolo(fascicolo.idClassificazione, DateTime.Today.Year.ToString(), fascicolo.codUltimo, fascicolo.idRegistro); if (string.IsNullOrEmpty(chiaveFascicolo)) { logger.Debug("errore nella calcolo del VAR_CHIAVE_FASCICOLO - DATI MANCANTI "); throw new Exception(); } // 5 - Si aggiorna il record relativo al fascicolo con i nuovi dati fascicolo = this.NewFascicolo(infoUtente.idAmministrazione, classificazione.registro, fascicolo, enableUffRef, chiaveFascicolo); if (fascicolo != null) { //6 - Si crea la folder associata al fascicolo folder.descrizione = fascicolo.codice; folder.idFascicolo = fascicolo.systemID; folder.idParent = fascicolo.systemID; string idPeopleDelegato = string.Empty; if (infoUtente.delegato != null && infoUtente.delegato.idPeople != null) { idPeopleDelegato = infoUtente.delegato.idPeople; } folder.systemID = this.CreateProject(folder.descrizione, idPeopleDelegato); if (!string.IsNullOrEmpty(folder.systemID)) { //7 - La creazione è andata a buon fine, quindi si aggiorna il record relativo alla folder con i dati del fascicolo if (fascicoli.NewFolder(infoUtente.idAmministrazione, folder, dbProvider)) { //8 - Imposto ID_TITOLARIO, cioe' il titolario di appartenenza sia per il fascicolo che per il folder DocsPaDB.Query_DocsPAWS.Amministrazione amm = new DocsPaDB.Query_DocsPAWS.Amministrazione(); DocsPaVO.amministrazione.OrgNodoTitolario nodoTit = amm.getNodoTitolario(fascicolo.idClassificazione); if (!string.IsNullOrEmpty(nodoTit.ID_Titolario)) { if (!fascicoli.updateIdTitolario(nodoTit.ID_Titolario, fascicolo.systemID, folder.systemID, dbProvider)) { msgError = "errore nel metodo: creazioneFascicoloConTransazione - errore durante l'aggiornamento dell'ID_TITOLARIO per il Fascicolo e il Folder"; throw new Exception(); } } } else { msgError = "errore nel metodo: creazioneFascicoloConTransazione - errore durante l'aggiornamento della Root Folder"; throw new Exception(); } //creazione dei sottofascicoli relativi alla tipologia con gara e senza gara fascicolo.folderSelezionato = folder; CreateFolderHermes(fascicolo, ruolo); } else { msgError = "errore nel metodo: creazioneFascicoloConTransazione - errore durante la creazione della Root Folder"; throw new Exception(); } } else { //Se il fascicolo è NULL viene lanciata una eccezione e viene eseguita la Rollback dell'operazione msgError = "errore nel metodo: creazioneFascicoloConTransazione - errore durante l'Update sulla Project"; throw new Exception(); } bool isPrivato = true; if (fascicolo.privato.Equals("0")) { isPrivato = false; } if (ruolo != null) { System.Collections.ArrayList listRuoliSuperiori; // 9 - Si estende la visibilità sul fascicolo creato if (fascicoli.SetProjectTrustees(infoUtente.idPeople, fascicolo.systemID, ruolo, fascicolo.idClassificazione, fascicolo.idRegistro, isPrivato, out listRuoliSuperiori, infoUtente.delegato)) { // 10 - Si estende la visibilità sulla folder creata bool isSottofascicolo = (folder.idParent != folder.idFascicolo); System.Collections.ArrayList tmp; // Variabile temporanea: i ruoli superiori sono già stati reperiti //10.1 - sottofascicoli: si da la visibilità ad essi a tutti coloro che vedono il fascicolo a cui essi appartengono //10.2 caso di rootFolder, segue la visibilità del fascicolo a cui fa riferimento (calcolata in fase di creazione del fascicolo) if (!fascicoli.SetProjectTrustees(infoUtente.idPeople, folder.systemID, ruolo, folder.idFascicolo, isSottofascicolo, fascicolo.idRegistro, isPrivato, out tmp, infoUtente.delegato)) { msgError = "errore durante estensione della visibilità della Folder"; throw new Exception(); } } else { msgError = "errore durante estenzione della visibilità sul Fascicolo"; throw new Exception(); } ruoliSuperiori = (Ruolo[])listRuoliSuperiori.ToArray(typeof(Ruolo)); } } catch { logger.Debug("*** ESEGUITA ROLLBACK DELLA TRANSAZIONE CREAZIONE FASCICOLO: " + msgError + "***"); result = false; } logger.Info("END"); return(result); }
/// <summary> /// /// </summary> /// <param name="classifica"></param> /// <param name="fascicolo"></param> /// <param name="ruolo"></param> /// <param name="enableUfficioReferente"></param> /// <param name="result"></param> /// <param name="ruoliSuperiori"></param> /// <returns></returns> public bool CreateProject(Classificazione classifica, Fascicolo fascicolo, Ruolo ruolo, bool enableUfficioReferente, out ResultCreazioneFascicolo result, out DocsPaVO.utente.Ruolo[] ruoliSuperiori) { logger.Info("BEGIN"); bool retValue = false; ruoliSuperiori = null; using (DocsPaDB.DBProvider dbProvider = new DocsPaDB.DBProvider()) { using (System.Data.IDataReader reader = dbProvider.ExecuteReader("select a.CHA_STATO from project a where a.SYSTEM_ID in (select b.ID_TITOLARIO from project b where b.SYSTEM_ID =" + classifica.systemID + ")")) { if (reader.FieldCount > 0) { while (reader.Read()) { string valorechiave = DocsPaUtils.Configuration.InitConfigurationKeys.GetValue("0", "BE_FASC_TUTTI_TIT"); if (string.IsNullOrEmpty(valorechiave) || !valorechiave.Equals("1")) { if (reader.GetString(reader.GetOrdinal("CHA_STATO")).ToUpper().Equals("C")) { logger.Debug("sottofascilo chiuso"); throw new Exception("sottofascilo chiuso"); } } } } } logger.Debug(" *** INIZIO TRANSAZIONE CREAZIONE FASCICOLO ***"); dbProvider.BeginTransaction(); fascicolo.idClassificazione = classifica.systemID; result = DocsPaVO.fascicolazione.ResultCreazioneFascicolo.OK; DocsPaVO.fascicolazione.Folder folder = new DocsPaVO.fascicolazione.Folder(); DocsPaDB.Query_DocsPAWS.AmministrazioneXml objAX = new DocsPaDB.Query_DocsPAWS.AmministrazioneXml(); DocsPaDB.Query_DocsPAWS.Fascicoli fascicoli = new DocsPaDB.Query_DocsPAWS.Fascicoli(); try { fascicolo.stato = "A"; fascicolo.tipo = "P"; // 6 - Si aggiorna il codUltimo relativo al fascicolo (solo per ora perchè andrà tolta questa gestione) if (!fascicoli.aggiornaDpaRegFasc(ref fascicolo.codUltimo, fascicolo.idClassificazione, fascicolo.idRegistro, dbProvider)) { throw new Exception("Errore nell'aggiornamento della tabella dpa_reg_fasc"); } //prova per verifica codice univoco string format = DocsPaDB.Utils.Personalization.getInstance(this.UserInfo.idAmministrazione).FormatoFascicolatura; if (format == null || format.Equals("")) { //in alcuni casi, l'oggetto Personalization non è not null, ma il formato segnatura è null!! //per evitare il blocco della protocollazione a meno di un iisreset inserisco questo codice. logger.Debug("Ricalcolo Personalization"); DocsPaDB.Utils.Personalization.Reset(); format = DocsPaDB.Utils.Personalization.getInstance(this.UserInfo.idAmministrazione).FormatoFascicolatura; if (format == null || format.Equals("")) { throw new FormatoFascicolaturaException(); } } //string codiceFasc = this.CalcolaCodiceFascicolo(this.UserInfo.idAmministrazione, classifica.codice, fascicolo.apertura, classifica.systemID, ref fascicolo.codUltimo, true, dbProvider); string codiceFasc = this.CalcolaCodiceFascicolo(this.UserInfo.idAmministrazione, classifica, fascicolo.apertura, ref fascicolo.codUltimo, true, dbProvider); string idReg = fascicolo.idRegistro; if (idReg != null && idReg == "") { idReg = classifica.registro.systemId; } // 4 - Si verifica che il codice sia univoco if (!objAX.CheckUniqueCode("PROJECT", "VAR_CODICE", codiceFasc, "AND ((ID_REGISTRO IS NULL OR ID_REGISTRO=" + idReg + " ) ) AND ID_AMM =" + this.UserInfo.idAmministrazione + " AND ID_PARENT = " + classifica.systemID + "", dbProvider)) { // 4 - Si verifica se il codice è già presente vienelanciata una eccezione //codiceFascNew = calcolaCodiceFascicolo(infoUtente.idAmministrazione,classificazione.codice, fascicolo.apertura, classificazione.systemID, ref fascicolo.codUltimo, false, dbProvider); throw new FascicoloPresenteException(); } // Creazione fascicolo string idPeopleDelegato = string.Empty; if (fascicolo.creatoreFascicolo != null && fascicolo.creatoreFascicolo.idPeopleDelegato != null) { idPeopleDelegato = fascicolo.creatoreFascicolo.idPeopleDelegato; } string systemIdFasc = this.CreateProject(fascicolo.descrizione, idPeopleDelegato); if (systemIdFasc != null && systemIdFasc != "") { fascicolo.systemID = systemIdFasc; /* 2 - VIENE INVOCATO IL METODO PER LA CREAZIONE DEL FASCICOLO * e della ROOT FOLDER */ bool resultNewFasc = this.CreazioneFascicoloConTransazione(classifica, fascicolo, this.UserInfo, ruolo, enableUfficioReferente, folder, codiceFasc, dbProvider, out ruoliSuperiori); //3 - SE LA CREAZIONE DEL FASCICOLO è ANDATA A BUON FINE SI EFFETTUA IL COMMIT //DELLA TRANSAZIONE if (resultNewFasc) { result = DocsPaVO.fascicolazione.ResultCreazioneFascicolo.OK; } else { throw new Exception("Errore nella gestione dei fascicoli (newFascicolo)"); } } else { throw new Exception("Errore nella gestione dei fascicoli (newFascicolo)"); } //Profilazione dinamica fascicoli if (fascicolo.template != null) { DocsPaDB.Query_DocsPAWS.ModelFasc modelFasc = new DocsPaDB.Query_DocsPAWS.ModelFasc(); modelFasc.salvaInserimentoUtenteProfDimFasc(fascicolo.template, fascicolo.systemID); } //Fine profilazione dinamica fascicoli logger.Debug("Fascicolo creato: idFascicolo = " + fascicolo.systemID); logger.Debug("Folder creata: = " + folder.systemID); if (result == ResultCreazioneFascicolo.OK) { retValue = true; } } catch (FascicoloPresenteException e) { retValue = false; fascicolo = null; result = DocsPaVO.fascicolazione.ResultCreazioneFascicolo.FASCICOLO_GIA_PRESENTE; logger.Debug(e.Message); } catch (FormatoFascicolaturaException e) { retValue = false; fascicolo = null; result = DocsPaVO.fascicolazione.ResultCreazioneFascicolo.FORMATO_FASCICOLATURA_NON_PRESENTE; logger.Debug(e.Message); } catch (Exception e) { //SE LA CREAZIONE DEL FASCICOLO GENERA ERRORE, //SI RILASCIANO RISORSE ALLOCATE E SI EFFETTUA IL ROLLBACK DELLA TRANSAZIONE retValue = false; fascicolo = null; result = DocsPaVO.fascicolazione.ResultCreazioneFascicolo.GENERIC_ERROR; logger.Debug(e.Message); } if (retValue) { dbProvider.CommitTransaction(); } else { dbProvider.RollbackTransaction(); } } logger.Info("END"); return(retValue); }
/// <summary> /// Scrive (aggiorna) il file di log nella gestione dell'abilitazione dei log di amm. /// </summary> /// <param name="streamXml">file stream xml</param> /// <param name="codAmm">codice amm.ne</param> /// <returns>bool: true=successo, false=insuccesso</returns> public bool WriteWSLogAmm(string streamXml, string codAmm) { bool result = true; try { // prende la system_id dell'amm.ne DocsPaDB.Query_DocsPAWS.AmministrazioneXml amm = new DocsPaDB.Query_DocsPAWS.AmministrazioneXml(); string idAmm = amm.GetAdminByName(codAmm); #region gestione con file xml (DISATTIVATO) // string codice; // string attivo; // bool passato = false; // // xml già presente sul WS // XmlDocument xmlDoc = new XmlDocument(); // string xmldocpath = AppDomain.CurrentDomain.BaseDirectory + @"xml\WSLog.xml"; // xmlDoc.Load(xmldocpath); // // string path = ".//AMMINISTRAZIONE[@ID='" + idAmm + "']"; // XmlNode nodoAmm = xmlDoc.SelectSingleNode(path); // // // xml passato in stream // XmlDocument xmlDocStream = new XmlDocument(); // xmlDocStream.LoadXml(streamXml); // // if(nodoAmm != null && nodoAmm.ChildNodes.Count > 0) // { // // ChildNodes dell'xml presente sul WS // foreach (XmlNode azione in nodoAmm.ChildNodes) // { // codice = azione.ChildNodes[0].InnerText; // attivo = azione.ChildNodes[4].InnerText; // // // prende il nodo ATTIVO dello stream passato // XmlNode azioneStream = xmlDocStream.SelectSingleNode(".//AZIONI/CODICE[text()='"+ codice +"']"); // if(azioneStream != null) // { // XmlNode NodeAttivoStream = azioneStream.ParentNode.SelectSingleNode("ATTIVO"); // // // modifica il nodo ATTIVO dell'xml presente sul WS con quello passato in stream // if(attivo != NodeAttivoStream.InnerText) // { // azione.ChildNodes[4].InnerText = NodeAttivoStream.InnerText; // passato = true; // } // } // else // { // return false; // } // } // // if(passato) // { // xmlDoc.Save(xmldocpath); // } // // } // else // { // return false; // } #endregion #region gestione con lettura sul db string codice; // Contesto transazionale using (DocsPaDB.TransactionContext transactionContext = new DocsPaDB.TransactionContext()) { // elimina tutti i record di questa amm.ne DocsPaDB.Query_DocsPAWS.Log log = new DocsPaDB.Query_DocsPAWS.Log(); if (log.DelLogAttiviAmm(idAmm)) { // xml passato in stream XmlDocument xmlDocStream = new XmlDocument(); xmlDocStream.LoadXml(streamXml); XmlNode listaAzioni = xmlDocStream.SelectSingleNode("NEWDATASET"); if (listaAzioni.ChildNodes.Count > 0) { XmlNodeList listaAttivi = listaAzioni.SelectNodes(".//ATTIVO[text()='1']"); if (listaAttivi.Count > 0) { foreach (XmlNode nodoAttivo in listaAttivi) { // prende il codice codice = nodoAttivo.ParentNode.SelectSingleNode("CODICE").InnerText; // esegue la insert su db log.AddLogAttivi(codice, idAmm); } } } } else { return(false); } transactionContext.Complete(); } #endregion } catch (Exception ex) { logger.Debug(ex.Message.ToString(), ex); return(false); } return(result); }
/// <summary> /// Legge il file di log per la gestione dell'abilitazione dei log /// </summary> /// <returns>string XmlStream</returns> public string ReadWSLogAmm(string codAmm) { string result = null; try { // prende la system_id dell'amm.ne DocsPaDB.Query_DocsPAWS.AmministrazioneXml amm = new DocsPaDB.Query_DocsPAWS.AmministrazioneXml(); string idAmm = amm.GetAdminByName(codAmm); #region gestione con file xml (DISATTIVATO) // XmlDocument xmlDoc = new XmlDocument(); // string xmldocpath = AppDomain.CurrentDomain.BaseDirectory + @"xml\WSLog.xml"; // xmlDoc.Load(xmldocpath); // // string path = ".//AMMINISTRAZIONE[@ID='" + idAmm + "']"; // XmlNode nodoAmm = xmlDoc.SelectSingleNode(path); // // result = nodoAmm.OuterXml; #endregion #region gestione con lettura sul db System.Data.DataSet ds; System.Data.DataSet ds2; DataRow row; DocsPaDB.Query_DocsPAWS.Log log = new DocsPaDB.Query_DocsPAWS.Log(); ds = log.GetLogAttiviAmm(idAmm); if (ds != null && ds.Tables["AZIONIAMM"].Rows.Count > 0) { // ha trovato record di log attivi ds2 = log.GetLogDisattiviAmm(idAmm); // prende quelli disattivi if (ds2 != null && ds2.Tables["AZIONI_DISATTIVE"].Rows.Count > 0) { // unisce i due dataset foreach (DataRow rowDis in ds2.Tables["AZIONI_DISATTIVE"].Rows) { row = ds.Tables["AZIONIAMM"].NewRow(); row["codice"] = rowDis["codice"]; row["descrizione"] = rowDis["descrizione"]; row["oggetto"] = rowDis["oggetto"]; row["metodo"] = rowDis["metodo"]; row["attivo"] = "0"; ds.Tables["AZIONIAMM"].Rows.Add(row); } } result = ds.GetXml(); } else { // non ha trovato record di log attivi, prende quindi tutti quelli dell'anagrafica ds = log.GetLogDisattiviAmm(); if (ds != null && ds.Tables["AZIONIAMM"].Rows.Count > 0) { result = ds.GetXml(); } } #endregion } catch { result = null; } return(result); }
/// <summary> /// /// </summary> /// <param name="classificazione"></param> /// <param name="fascicolo"></param> /// <param name="infoUtente"></param> /// <param name="ruolo"></param> /// <param name="enableUffRef"></param> /// <param name="folder"></param> /// <param name="codiceFasc"></param> /// <param name="dbProvider"></param> /// <returns></returns> private bool CreazioneFascicoloConTransazione(DocsPaVO.fascicolazione.Classificazione classificazione, DocsPaVO.fascicolazione.Fascicolo fascicolo, DocsPaVO.utente.InfoUtente infoUtente, DocsPaVO.utente.Ruolo ruolo, bool enableUffRef, DocsPaVO.fascicolazione.Folder folder, string codiceFasc, DocsPaDB.DBProvider dbProvider, out Ruolo[] ruoliSuperiori) { logger.Info("BEGIN"); bool result = true; ruoliSuperiori = null; DocsPaDB.Query_DocsPAWS.AmministrazioneXml objAX = new DocsPaDB.Query_DocsPAWS.AmministrazioneXml(); DocsPaDB.Query_DocsPAWS.Fascicoli fascicoli = new DocsPaDB.Query_DocsPAWS.Fascicoli(); string systemIdRoot; try { // 3 - Si calcola il formato del codice del fascicolo fascicolo.codice = codiceFasc; string chiaveFascicolo = CalcolaChiaveFascicolo(fascicolo.idClassificazione, DateTime.Today.Year.ToString(), fascicolo.codUltimo, fascicolo.idRegistro); if (string.IsNullOrEmpty(chiaveFascicolo)) { throw new Exception("errore nel calcolo del VAR_CHIAVE_FASCICOLO - DATI MANCANTI"); } // 5 - Si aggiorna il record relativo al fascicolo con i nuovi dati fascicolo = NewFascicolo(infoUtente.idAmministrazione, classificazione.registro, fascicolo, enableUffRef, chiaveFascicolo); if (fascicoli == null) { throw new Exception("errore durante l'Update sulla Project"); } // 6 - Si crea la folder associata al fascicolo folder.descrizione = fascicolo.codice; folder.idFascicolo = fascicolo.systemID; folder.idParent = fascicolo.systemID; string idPeopleDelegato = string.Empty; if (infoUtente.delegato != null && infoUtente.delegato.idPeople != null) { idPeopleDelegato = infoUtente.delegato.idPeople; } systemIdRoot = CreateProject(folder.descrizione, idPeopleDelegato); if (string.IsNullOrEmpty(systemIdRoot)) { throw new Exception("errore durante la creazione della Root Folder"); } // 7 - La creazione è andata a buon fine, quindi si aggiorna il record relativo alla folder con i dati del fascicolo folder.systemID = systemIdRoot; if (!fascicoli.NewFolder(infoUtente.idAmministrazione, folder, dbProvider)) { throw new Exception("errore durante l'aggiornamento della Root Folder"); } // 8 - Imposto ID_TITOLARIO, cioe' il titolario di appartenenza sia per il fascicolo che per il folder DocsPaDB.Query_DocsPAWS.Amministrazione amm = new DocsPaDB.Query_DocsPAWS.Amministrazione(); DocsPaVO.amministrazione.OrgNodoTitolario nodoTit = amm.getNodoTitolario(fascicolo.idClassificazione); if (nodoTit.ID_Titolario != null && nodoTit.ID_Titolario != "") { if (!fascicoli.updateIdTitolario(nodoTit.ID_Titolario, fascicolo.systemID, folder.systemID, dbProvider)) { throw new Exception("errore durante l'aggiornamento dell'ID_TITOLARIO per il Fascicolo e il Folder"); } } bool isPrivato = fascicolo.privato != "0"; if (ruolo != null) { System.Collections.ArrayList listRuoliSuperiori; // 9 - Si estende la visibilità sul fascicolo creato if (!fascicoli.SetProjectTrustees(infoUtente.idPeople, fascicolo.systemID, ruolo, fascicolo.idClassificazione, fascicolo.idRegistro, isPrivato, out listRuoliSuperiori, infoUtente.delegato, fascicolo.pubblico)) { throw new Exception("errore durante estensione della visibilità sul Fascicolo"); } // 10 - Si estende la visibilità sulla folder creata bool isSottofascicolo = (folder.idParent != folder.idFascicolo); System.Collections.ArrayList tmp; // Variabile temporanea: i ruoli superiori sono già stati reperiti //10.1 - sottofascicoli: si da la visibilità ad essi a tutti coloro che vedono il fascicolo a cui essi appartengono //10.2 caso di rootFolder, segue la visibilità del fascicolo a cui fa riferimento (calcolata in fase di creazione del fascicolo) if (!fascicoli.SetProjectTrustees(infoUtente.idPeople, folder.systemID, ruolo, folder.idFascicolo, isSottofascicolo, fascicolo.idRegistro, isPrivato, out tmp, infoUtente.delegato, fascicolo.pubblico)) { throw new Exception("errore durante estensione della visibilità della Folder"); } ruoliSuperiori = (Ruolo[])listRuoliSuperiori.ToArray(typeof(Ruolo)); } string key_beprojectlevel = DocsPaUtils.Configuration.InitConfigurationKeys.GetValue("0", "BE_PROJECT_LEVEL"); if (!string.IsNullOrEmpty(key_beprojectlevel) && key_beprojectlevel.Equals("1")) { folder.codicelivello = string.Format("{0:0000}", Convert.ToInt32(fascicolo.codUltimo)); UpdateFolderCodLivello(folder, infoUtente); } string key_beprojectstructure = DocsPaUtils.Configuration.InitConfigurationKeys.GetValue("0", "BE_PROJECT_STRUCTURE"); if (!string.IsNullOrEmpty(key_beprojectstructure) && key_beprojectstructure.Equals("1")) { CreateStrutturaFascicolo(fascicolo, infoUtente, ruolo); } } catch (Exception ex) { logger.Debug("*** ESEGUITA ROLLBACK DELLA TRANSAZIONE CREAZIONE FASCICOLO: ***"); logger.DebugFormat("errore nel metodo: creazioneFascicoloConTransazione - {0}", ex.Message); logger.DebugFormat("StackTrace : {0}", ex.StackTrace); result = false; } logger.Info("END"); return(result); }