import java.util.*; public class spadministration_serversBL extends spadministration_serversWV implements CPLib.QueryFilterFromApplication { // Variabile che indica se il record è stato caricato public boolean m_bLoaded; // Variabile che indica se il record è stato variato public boolean m_bUpdated; // Variabile che memorizza lo stato subito dopo una Load o una Save public String m_cPreviousState; // Variabile che mantiene il vecchio timestamp public String m_cOldCPCCCHK; public java.util.List m_oParameters; protected String m_cPassword; protected String m_cOTP; // Variabile che indica il tipo dell'ultimo // errore, o messaggio da comunicare all'interfaccia, // che si è verificato impostando una variabile di work. // I valori ammessi sono: // - 1 : errore di campo obbligatorio // - 2 : errore di check // - 3 : valore non ammesso nel link // - 4 : richiesta password // - 5 : richiesto otp public int m_nLastError; public String m_cLastMsgError; public String m_cLastWorkVarError; // m_bCalculating==true la Calculate e' in esecuzione public boolean m_bCalculating = false; public static final String i_EntityName = "spadministration_servers"; public static final String i_EntityType = "master"; public static final boolean i_IsSon = false; public boolean m_bSkipCheckOTPSecurity = true; // Variabile di collegamento con il database: passata nel costruttore public CPSql m_Sql; // Variabile di contesto (variabili globali): passata nel costruttore public CPContext m_Ctx; // Variabili che contengono il nome fisico e la connessione per la tabella collegata public String m_cPhName_cptsrvr; public String m_cServer_cptsrvr; public CPPhTableWrInfo m_oWrInfo_cptsrvr; // Variabile che contiene il nome virtuale della tabella public String m_cVirtName_cptsrvr; // gestori eventi esterni al business object sono collegati inserendoli nella coppia di strutture dati seguenti // gestori associati a particolari eventi ('Blank') public static volatile HashMap specificEventsHandlers; // gestori associati a tutti gli eventi public static volatile ArrayList allEventsHandlers; // metadati resi disponibili ai gestori di eventi public static String[] m_EntityTables = {"cptsrvr"}; // codice secondo sintassi delle business rules per produrre i dati da usare in un ideale documento che li rappresenti public static final String i_StateStructure = "{'ServerName':ServerName,'ServerDesc':ServerDesc,'ODBCDataSource':ODBCDataSource,'DatabaseType_Other':DatabaseType_Other,'DatabaseType_Var':DatabaseType_Var,'PostIt':PostIt"+FoundlingChildrenList("spadministration_servers",true)+"}"; public static final String i_CompleteStateStructure = "{'ServerName':ServerName,'ServerDesc':ServerDesc,'ODBCDataSource':ODBCDataSource,'DatabaseType':DatabaseType,'DatabaseType_SupportedDatabases':DatabaseType_SupportedDatabases,'DatabaseType_Other':DatabaseType_Other,'DatabaseType_Var':DatabaseType_Var,'PostIt':PostIt"+FoundlingChildrenList("spadministration_servers",true)+"}"; public static final String i_ItemSequence = "ServerName,ServerDesc,ODBCDataSource,DatabaseType_Other,DatabaseType_Var,PostIt"+FoundlingChildrenList("spadministration_servers",false)+""; public static final com.zucchetti.sitepainter.EntityItem[] i_EditableEntityItems = com.zucchetti.sitepainter.EntityItem.buildEditableItemsForEntity(GetLinkDef(),FoundlingChildrenList("spadministration_servers"),new String[][]{new String[]{"ServerName","ADMIN_SERVER_NAME","C","10","0","campo","key1","false","true"},new String[]{"ServerDesc","ADMIN_SERVER_DESCRIPTION","C","30","0","campo","nokey","false","false"},new String[]{"ODBCDataSource","ADMIN_URL_DATA_SOURCE","C","500","0","campo","nokey","false","false"},new String[]{"DatabaseType_Other","ADMIN_DATABASE_DRIVER","C","60","0","variabile","nokey","false","false"},new String[]{"DatabaseType_Var","","C","60","0","variabile","nokey","false","false"},new String[]{"PostIt","PostIt","C","1","0","campo","nokey","false","false"}}); // dati usati internamente dai metodi BRxxx di BRCallerImpl private static boolean _involved=true; protected void _setInvolvedInBR(boolean involved) { _involved=involved; } protected boolean _involvedInBR() { return _involved; } public spadministration_serversBL (CPContext p_ContextObject) { /* Impostazione dell'ambiente globale: il businness object si collega all'oggetto globale (unico per più istanze di una stessa applicazione) per recuperare informazioni sul: 1) nome fisico della tabella di gestione; 2) nome fisico delle tabelle collegate nei link; 3) stringa di connessione. L'azienda è contenuta nel global object. */ // Assegnazione delle variabili che contengono il nome fisico, il nome virtuale, e la connessione per la tabella collegata m_cPhName_cptsrvr = p_ContextObject.GetPhName("cptsrvr",p_ContextObject.GetCompany(),false); m_cServer_cptsrvr = p_ContextObject.GetServer("cptsrvr"); m_oWrInfo_cptsrvr = CPPhTableWrInfo.GetCPPhTableWrInfo(p_ContextObject,"cptsrvr",p_ContextObject.GetCompany()); m_cVirtName_cptsrvr = CPSql.ManipulateTablePhName("cptsrvr",m_cServer_cptsrvr); // Assegnazione della variabile di collegamento con il database m_Sql = p_ContextObject.GetSql(); m_Ctx = p_ContextObject; // Istanziazione dei business object dei figli m_MNTs = CPLib.MNTChilds("spadministration_servers",p_ContextObject); } public void Blank() { BlankStatusVariables(); // * --- Area Manuale = BO - Blank Record Init // * --- Fine Area Manuale w_ServerName = ""; w_ServerDesc = ""; w_ODBCDataSource = ""; w_DatabaseType = "ODBC Bridge"; w_DatabaseType_SupportedDatabases = ",ODBC Bridge,SQL Server 2000,Oracle,DB2,DB2/390,PostgreSQL,SAPDB,MySQL,Informix,SPINSTANCE,"; w_DatabaseType_Other = ""; w_DatabaseType_Other = (CPLib.eq(EntityStatus(),"N") || CPLib.gt(CPLib.At(","+w_DatabaseType+",",w_DatabaseType_SupportedDatabases),0)?"":w_DatabaseType); w_DatabaseType_Var = ""; w_DatabaseType_Var = (CPLib.eq(EntityStatus(),"N") || CPLib.gt(CPLib.At(","+w_DatabaseType+",",w_DatabaseType_SupportedDatabases),0)?w_DatabaseType:""); w_PostIt = (CPLib.Empty(w_PostIt)?"S":w_PostIt); CPExtenderLib.BlankExtendedFields(extendedFields); SaveDependsOn(); NotifyEvent("Blank"); // * --- Area Manuale = BO - Blank Record End // * --- Fine Area Manuale } public boolean IsUpdated() { boolean l_bResult; l_bResult = m_bUpdated; return l_bResult; } public boolean IsLoaded() { return m_bLoaded; } public boolean IsNew() { return IsUpdated() && ! (IsLoaded()); } public void SaveDependsOn() { o_DatabaseType = w_DatabaseType; o_DatabaseType_Other = w_DatabaseType_Other; o_DatabaseType_Var = w_DatabaseType_Var; } public void NotifyEvent(String p_cEvent) { CPLib.NotifyEvent(p_cEvent,this,m_Ctx,specificEventsHandlers,allEventsHandlers); } // Funzioni di link legate alle variabili ed ai campi. /* Gestione dei metodi per l'impostazione delle variabili di work. I seguenti metodi sono pubblici perchè vengono chiamati dalla UI che ha creato il business object o da batch. */ public boolean Set_ServerName(String p_workVariableValue) { m_nLastError = 0; m_cLastMsgError = ""; boolean l_bResult; l_bResult = true; // Variabile temporanea che conterrà il risultato della funzione di link se l'item corrente è parte di una chiave composta boolean l_bTmpRes; SetUpdated(); w_ServerName = p_workVariableValue; // Se il campo è vuoto, demando la segnalazione dell'obbligatorietà alla Check() del business object if ( ! (l_bResult)) { // Impostazione a blank della variabile di work w_ServerName = ""; } // Esecuzione dei calcoli Calculate(); SaveDependsOn(); return l_bResult; } public boolean Set_ServerDesc(String p_workVariableValue) { m_nLastError = 0; m_cLastMsgError = ""; boolean l_bResult; l_bResult = true; // Variabile temporanea che conterrà il risultato della funzione di link se l'item corrente è parte di una chiave composta boolean l_bTmpRes; SetUpdated(); w_ServerDesc = p_workVariableValue; // Esecuzione dei calcoli Calculate(); SaveDependsOn(); return l_bResult; } public boolean Set_ODBCDataSource(String p_workVariableValue) { m_nLastError = 0; m_cLastMsgError = ""; boolean l_bResult; l_bResult = true; // Variabile temporanea che conterrà il risultato della funzione di link se l'item corrente è parte di una chiave composta boolean l_bTmpRes; SetUpdated(); w_ODBCDataSource = p_workVariableValue; // Esecuzione dei calcoli Calculate(); SaveDependsOn(); return l_bResult; } public boolean Set_DatabaseType_Other(String p_workVariableValue) { m_nLastError = 0; m_cLastMsgError = ""; boolean l_bResult; l_bResult = true; // Variabile temporanea che conterrà il risultato della funzione di link se l'item corrente è parte di una chiave composta boolean l_bTmpRes; SetUpdated(); w_DatabaseType_Other = p_workVariableValue; // Esecuzione dei calcoli Calculate(); SaveDependsOn(); return l_bResult; } public boolean Set_DatabaseType_Var(String p_workVariableValue) { m_nLastError = 0; m_cLastMsgError = ""; boolean l_bResult; l_bResult = true; // Variabile temporanea che conterrà il risultato della funzione di link se l'item corrente è parte di una chiave composta boolean l_bTmpRes; SetUpdated(); w_DatabaseType_Var = p_workVariableValue; // Esecuzione dei calcoli Calculate(); SaveDependsOn(); return l_bResult; } public boolean Set_PostIt(String p_workVariableValue) { m_nLastError = 0; m_cLastMsgError = ""; boolean l_bResult; l_bResult = true; // Variabile temporanea che conterrà il risultato della funzione di link se l'item corrente è parte di una chiave composta boolean l_bTmpRes; SetUpdated(); w_PostIt = p_workVariableValue; // Esecuzione dei calcoli Calculate(); SaveDependsOn(); return l_bResult; } /* Gestione delle funzioni che rispondono lo stato delle variabili di work. Vengono chiamate dalla UI per valutare la condizione di visibilità e di abilitazione di un control. */ public boolean getVisible_DatabaseType_Other() { return ! (CPLib.Empty(w_DatabaseType_Var)); } public boolean Set_Password(String p_pwd) { m_cPassword = p_pwd; return true; } public boolean Set_OTP(String p_otp) { m_cOTP = p_otp; return true; } public boolean Calculate() { boolean l_bTmpRes; l_bTmpRes = true; boolean l_bResult; l_bResult = true; m_bCalculating = true; if (CPLib.ne(o_DatabaseType,w_DatabaseType)) { w_DatabaseType_Other = (CPLib.eq(EntityStatus(),"N") || CPLib.gt(CPLib.At(","+w_DatabaseType+",",w_DatabaseType_SupportedDatabases),0)?"":w_DatabaseType); } if (CPLib.ne(o_DatabaseType,w_DatabaseType)) { w_DatabaseType_Var = (CPLib.eq(EntityStatus(),"N") || CPLib.gt(CPLib.At(","+w_DatabaseType+",",w_DatabaseType_SupportedDatabases),0)?w_DatabaseType:""); } if (CPLib.ne(o_DatabaseType_Var,w_DatabaseType_Var) || CPLib.ne(o_DatabaseType_Other,w_DatabaseType_Other)) { Calculation_OANHAMSHFO(); } // * --- Area Manuale = BO - Calculate // * --- Fine Area Manuale for (int l_i = 0; CPLib.lt(l_i,m_MNTs.length); l_i = l_i + (1)) { m_MNTs[l_i].m_child.FoundlingCopyWorkVar(this,true); } m_bCalculating = false; return l_bResult; } void Calculation_OANHAMSHFO() { w_DatabaseType = (CPLib.Empty(w_DatabaseType_Var)?w_DatabaseType_Other:w_DatabaseType_Var); } protected void BlankStatusVariables() { m_bLoaded = false; m_bUpdated = false; m_cPreviousState = CPSecurity.UNKNOWN_STATE; } public void CalledBatchEnd() { if ( ! (m_bCalculating)) { // Esecuzione dei calcoli Calculate(); } } public final static String[] m_KeyColumns = {"ServerName"}; public static String QueryFilter(CPContext m_Ctx) { String l_cFilter; l_cFilter = CPLib.ApplicationQueryFilter("spadministration_servers","cptsrvr",m_KeyColumns,m_Ctx); return l_cFilter; } public void SetFromContext(String s) { SetFromContext(s,null); } public void SetFromContext(java.util.Properties p) { SetFromContext("_dummy_",p); } public void SetFromContext(String s,java.util.Properties p) { BlankStatusVariables(); w_ServerName = ""; w_ServerDesc = ""; w_ODBCDataSource = ""; w_DatabaseType = ""; w_DatabaseType_SupportedDatabases = ""; w_DatabaseType_Other = ""; w_DatabaseType_Var = ""; w_PostIt = ""; CPExtenderLib.BlankExtendedFields(extendedFields); SaveDependsOn(); if ( ! (CPLib.Empty(s))) { if (CPLib.IsNull(p)) { p = CPLib.GetProperties(s); } boolean l_bFromHyperlink = CPLib.ne("_not_found_",CPLib.GetProperty(p,"m_cParameterSequence","_not_found_")); w_ServerName = CPLib.GetProperty(p,"ServerName",w_ServerName,0); w_ServerDesc = CPLib.GetProperty(p,"ServerDesc",w_ServerDesc,0); w_ODBCDataSource = CPLib.GetProperty(p,"ODBCDataSource",w_ODBCDataSource,0); w_DatabaseType = CPLib.GetProperty(p,"DatabaseType",w_DatabaseType,0); w_PostIt = CPLib.GetProperty(p,"PostIt",w_PostIt,0); w_DatabaseType_SupportedDatabases = CPLib.GetProperty(p,"DatabaseType_SupportedDatabases",w_DatabaseType_SupportedDatabases,0); w_DatabaseType_Other = CPLib.GetProperty(p,"DatabaseType_Other",w_DatabaseType_Other,0); w_DatabaseType_Var = CPLib.GetProperty(p,"DatabaseType_Var",w_DatabaseType_Var,0); CPLib.SetFromContextMNTs(p,m_MNTs); SPExtenderLib.SetExtendedFromContext(p,extendedFields); m_bLoaded = CPLib.GetProperty(p,"m_bLoaded",false,0); m_bUpdated = CPLib.GetProperty(p,"m_bUpdated",false,0); m_cOldCPCCCHK = CPLib.GetProperty(p,"m_cOldCPCCCHK","",0); m_cPreviousState = CPLib.GetProperty(p,"m_cPrvsStt","",0); m_cPassword = CPLib.GetProperty(p,"m_cPwd","",0); m_cOTP = CPLib.GetProperty(p,"m_cOTP","",0); m_lCtxLoaded = true; if ( ! (l_bFromHyperlink)) { SaveDependsOn(); } } } public void SetUpdated() { m_bUpdated = true; } public String EntityStatus() { return (m_bLoaded?"E":"N"); } public String LastErrorMessage() { return m_cLastMsgError; } static void GetLinkDef0(Map>> tables) { java.util.regex.Pattern zeroSplit; zeroSplit = java.util.regex.Pattern.compile("\\x00"); Map map; List> items; } public static Map>> GetLinkDef() { java.util.regex.Pattern zeroSplit; zeroSplit = java.util.regex.Pattern.compile("\\x00"); Map>> tables; tables = new HashMap>>(); Map map; List> items; GetLinkDef0(tables); for(String child : CPLib.LoadableMNTs("spadministration_servers",false)) { map = new HashMap(); items = tables.get(com.zucchetti.sitepainter.Library.getEntityTables(child)[0]); if (CPLib.IsNull(items)) { items = new ArrayList>(); tables.put(com.zucchetti.sitepainter.Library.getEntityTables(child)[0],items); } map.put("link_PC",new String[]{}); map.put("rd_kvar",new String[]{}); map.put("rd_kfield",new String[]{}); map.put("rd_field",new String[]{}); map.put("rd_var",new String[]{}); String[][] definitions = CPMNTChild.GetM_Fkd("spadministration_servers",child); // Informazione usata per risolvere la sintassi BO->tabella nelle VQR map.put("rd_var",definitions[0]); map.put("rd_field",definitions[1]); // Definizione delle coppie padre/figlio map.put("wr_var",definitions[0]); map.put("wr_field",definitions[1]); map.put("wr_op",new String[]{}); map.put("rd_var.obj_type",new String[]{}); map.put("rd_var.len",new String[]{}); map.put("rd_var.dec",new String[]{}); map.put("rd_var.comment",new String[]{}); map.put("property.name",new String[]{"arch","foundling","","","","prg_zoom"}); map.put("property.value",new String[]{com.zucchetti.sitepainter.Library.getEntityTables(child)[0],"true","","","",child}); items.add(map); } return tables; } public void Initialize() { // Inizializzazione delle variabili di work Blank(); // Inizializzazione delle variabili di progressivo e legate alle operazioni a saldo BlankAutonumberAndTransactionVars(); m_MNTs = CPLib.MNTChilds("spadministration_servers",m_Ctx); m_cPreviousState = GetCurrentState(); } public boolean Check() { boolean l_bResult; l_bResult = true; boolean l_bNoObligatory; l_bNoObligatory = true; ResetErrorMessage(); if (CPLib.Empty(w_ServerName)) { l_bNoObligatory = ! (CPLib.Empty(w_ServerName)); String obblMsgError = m_Ctx.Translate("ADMIN_SERVER_NAME")+" : "; m_cLastMsgError = obblMsgError+m_Ctx.Translate("MSG_OBBLI_FIELD"); l_bResult = false; w_ServerName = ""; if (CPLib.eq(m_cLastWorkVarError,"")) { m_cLastWorkVarError = "ServerName"; } } // * --- Area Manuale = BO - Check Form // * --- Fine Area Manuale if ( ! (l_bNoObligatory)) { m_nLastError = 1; } return l_bResult; } void ResetErrorMessage() { m_nLastError = 0; m_cLastMsgError = ""; m_cLastWorkVarError = ""; } public String GetCurrentState() { String l_bResult; l_bResult = CPSecurity.UNKNOWN_STATE; return l_bResult; } /** @deprecated Will be removed in a future version **/ @Deprecated public String GetStateSecurityKey(String p_cState) { return GetStateSecurityKeyRoles(p_cState)[0]; } public String[] GetStateSecurityKeyRoles(String p_cState) { String[] l_Keys = {}; if (CPLib.eq(p_cState,CPSecurity.UNKNOWN_STATE)) { l_Keys = new String[]{"spadministration_servers"}; } if (CPLib.eq(l_Keys.length,0)) { l_Keys = new String[]{"spadministration_servers\\"+p_cState}; } return l_Keys; } public boolean CanView() { boolean l_bResult; l_bResult = true; ResetErrorMessage(); l_bResult = l_bResult && BRCanView(); if ( ! (l_bResult)) { String o_cLastMsgError = m_cLastMsgError; Blank(); // Evita che un errore segnalato alla Blank, ad esempio link fallito, sovrascriva l'errore di accesso bloccato m_cLastMsgError = o_cLastMsgError; } return l_bResult; } public boolean CanEdit() { return CanEdit(GetCurrentState()); } public boolean CanEdit(String p_cState) { boolean l_bResult = true; ResetErrorMessage(); l_bResult = l_bResult && BRCanEdit(); return l_bResult; } public boolean CanDelete() { boolean l_bResult; l_bResult = true; ResetErrorMessage(); l_bResult = ! (spadministration_check_server_usageR.Make(m_Ctx,this).Run(w_ServerName)); if ( ! (l_bResult)) { m_cLastMsgError = "MSG_SERVER_IN_USE"; } l_bResult = l_bResult && BRCanDelete(); return l_bResult; } public boolean CanAdd() { return CanAdd(GetCurrentState()); } public boolean CanAdd(String p_cState) { boolean l_bResult = true; ResetErrorMessage(); l_bResult = l_bResult && BRCanAdd(); return l_bResult; } void BlankAutonumberAndTransactionVars() { // Inizializzazione dei progressivi // Inizializzazione delle variabili per DependsOn o_DatabaseType = ""; o_DatabaseType_Other = ""; o_DatabaseType_Var = ""; // Inizializzazione delle variabili per la gestione dello storno delle operazioni di saldo } public String GetContext() { return GetContext(true); } public String GetContext(boolean p_bGetChildren) { Properties p; p = new Properties(); GetContext(p_bGetChildren,p); return CPLib.ToProperties(p); } public void GetContext(java.util.Properties p_oProperties) { GetContext(true,p_oProperties); } public void GetContext(boolean p_bGetChildren,java.util.Properties p) { CPLib.PutProperty(p,"ServerName",w_ServerName,0); CPLib.PutProperty(p,"ServerDesc",w_ServerDesc,0); CPLib.PutProperty(p,"ODBCDataSource",w_ODBCDataSource,0); CPLib.PutProperty(p,"DatabaseType",w_DatabaseType,0); CPLib.PutProperty(p,"PostIt",w_PostIt,0); CPLib.PutProperty(p,"DatabaseType_SupportedDatabases",w_DatabaseType_SupportedDatabases,0); CPLib.PutProperty(p,"DatabaseType_Other",w_DatabaseType_Other,0); CPLib.PutProperty(p,"DatabaseType_Var",w_DatabaseType_Var,0); if (p_bGetChildren) { CPLib.PutProperty(p,m_MNTs); } SPExtenderLib.PutExtendedProperies(p,extendedFields); CPLib.PutProperty(p,"m_bLoaded",m_bLoaded); CPLib.PutProperty(p,"m_bUpdated",m_bUpdated); CPLib.PutProperty(p,"m_cOldCPCCCHK",m_cOldCPCCCHK); CPLib.PutProperty(p,"m_cPrvsStt",m_cPreviousState); } public String i_PrimaryKey() { return PrimaryKey(this); } public static String PrimaryKey(Caller p_Caller) { return "cptsrvr"+"\\"+CPLib.ToCPStr(p_Caller.GetString("ServerName","C",10,0)); } public List> AutonumDefinition() { return StaticAutonumDefinition(); } public static List> StaticAutonumDefinition() { List> autonums; autonums = new ArrayList>(); List oneAutoNum; return autonums; } CallerBRImpl GetChild(String p_cName) { return GetMNTChild(false,m_MNTs,p_cName); } // * --- Area Manuale = BL - Methods // * --- Fine Area Manuale }