import java.util.*; public class spadministration_tablesBL extends spadministration_tablesWV 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_tables"; 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_cpttbls; public String m_cServer_cpttbls; public CPPhTableWrInfo m_oWrInfo_cpttbls; // Variabile che contiene il nome virtuale della tabella public String m_cVirtName_cpttbls; public String m_cPhName_cptsrvr; public String m_cServer_cptsrvr; public CPPhTableWrInfo m_oWrInfo_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 = {"cpttbls"}; // 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 = "{'FileName':FileName,'ServerName':ServerName"+FoundlingChildrenList("spadministration_tables",true)+"}"; public static final String i_CompleteStateStructure = "{'FileName':FileName,'PhName':PhName,'ServerName':ServerName,'DateMod':DateMod,'descserver':descserver"+FoundlingChildrenList("spadministration_tables",true)+"}"; public static final String i_ItemSequence = "FileName,ServerName"+FoundlingChildrenList("spadministration_tables",false)+""; public static final com.zucchetti.sitepainter.EntityItem[] i_EditableEntityItems = com.zucchetti.sitepainter.EntityItem.buildEditableItemsForEntity(GetLinkDef(),FoundlingChildrenList("spadministration_tables"),new String[][]{new String[]{"FileName","FileName","C","30","0","campo","key1","false","false"},new String[]{"ServerName","ServerName","C","10","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_tablesBL (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_cpttbls = p_ContextObject.GetPhName("cpttbls",p_ContextObject.GetCompany(),false); m_cServer_cpttbls = p_ContextObject.GetServer("cpttbls"); m_oWrInfo_cpttbls = CPPhTableWrInfo.GetCPPhTableWrInfo(p_ContextObject,"cpttbls",p_ContextObject.GetCompany()); m_cVirtName_cpttbls = CPSql.ManipulateTablePhName("cpttbls",m_cServer_cpttbls); // Assegnazione della variabile di collegamento con il database m_Sql = p_ContextObject.GetSql(); m_Ctx = p_ContextObject; m_cPhName_cptsrvr = p_ContextObject.GetPhName("cptsrvr"); m_cServer_cptsrvr = p_ContextObject.GetServer("cptsrvr"); m_oWrInfo_cptsrvr = CPPhTableWrInfo.GetCPPhTableWrInfo(p_ContextObject,"cptsrvr",p_ContextObject.GetCompany()); // Istanziazione dei business object dei figli m_MNTs = CPLib.MNTChilds("spadministration_tables",p_ContextObject); } public void Blank() { BlankStatusVariables(); // * --- Area Manuale = BO - Blank Record Init // * --- Fine Area Manuale w_FileName = ""; w_PhName = ""; w_ServerName = ""; w_DateMod = ""; w_descserver = ""; Link_OJERXEZSWH(); 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() { } public void NotifyEvent(String p_cEvent) { CPLib.NotifyEvent(p_cEvent,this,m_Ctx,specificEventsHandlers,allEventsHandlers); } // Funzioni di link legate alle variabili ed ai campi. protected boolean Link_OJERXEZSWH() { return Link_OJERXEZSWH("Full"); } protected boolean Link_OJERXEZSWH(String p_cType) { // Viene eseguita una query per chiave totale. boolean l_bResult; boolean l_bLoaded; String l_cWhere = ""; String l_cCurrentKey; l_bResult = false; // Dichiarazione del cursore locale del link CPResultSet l_rsLink=null; if ( ! (CPLib.Empty(w_ServerName))) { String l_OldValue = w_ServerName; // Costruzione della where per la chiave corrente e per le chiavi fisse l_cCurrentKey = "="+CPSql.SQLValueAdapter(CPLib.ToSQL(w_ServerName,"C",10,0),m_cServer_cptsrvr,w_ServerName); if (m_Ctx.IsSharedTemp("cptsrvr")) { l_cWhere = l_cWhere+" and context_id='"+m_Ctx.GetTempID()+"'"; } if (l_rsLink!=null) l_rsLink.Close(); l_rsLink = m_Sql.Query(m_cServer_cptsrvr,"select ServerName,ServerDesc from "+m_cPhName_cptsrvr+((m_cPhName_cptsrvr).endsWith(CPSecurity.FILTER_QUERY_POSTFIX)?CPLib.NewCPCCCHK():"")+" where "+"ServerName"+l_cCurrentKey+l_cWhere); try { l_bLoaded = ! (l_rsLink.Eof()); if (l_bLoaded) { /* E' stato trovato almeno un record: i valori del cursore vengono riportati nei relativi campi e/o variabili. */ w_ServerName = l_rsLink.GetString("ServerName"); w_descserver = l_rsLink.GetString("ServerDesc"); l_rsLink.Next(); /* Se è stato trovato un record il link con chiave piena ha avuto successo. */ l_bResult = l_rsLink.Eof(); /* Segna che l'interfaccia potrebbe fare un link con chiave parziale */ } else { Link_OJERXEZSWH_blank(); if (CPLib.eq(p_cType,"Load")) { w_ServerName = l_OldValue; } } if ( ! (l_bResult)) { m_nLastError = 3; m_cLastMsgError = ""; if (CPLib.eq(m_cLastMsgError,"")) { m_cLastMsgError = m_Ctx.Translate("MSG_LINK_FAILED","ServerName"); } m_cLastWorkVarError = "ServerName"; } } finally { l_rsLink.Close(); } } else { // Se la variabile è vuota deve essere considerato un valore valido ('NULL') l_bResult = true; Link_OJERXEZSWH_blank(); } return l_bResult; } void Link_OJERXEZSWH_blank() { w_ServerName = ""; w_descserver = ""; } /* 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_FileName(String p_workVariableValue) { 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_FileName = p_workVariableValue; // Esecuzione dei calcoli Calculate(); SaveDependsOn(); return l_bResult; } public boolean Set_ServerName(String p_workVariableValue) { 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; l_bResult = Link_OJERXEZSWH(); // La variabile che indica il tipo di errore viene eventualmente impostata // dalla funzione di link: infatti il suo valore di ritorno non e' // sufficiente per determinare il tipo di errore che puo' essere di valore // non trovato nella tabella collegata o di check non valido. if ( ! (l_bResult)) { // Impostazione a blank della variabile di work w_ServerName = ""; } // 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 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; // * --- 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; } 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 = {"FileName"}; public static String QueryFilter(CPContext m_Ctx) { String l_cFilter; l_cFilter = CPLib.ApplicationQueryFilter("spadministration_tables","cpttbls",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_FileName = ""; w_PhName = ""; w_ServerName = ""; w_DateMod = ""; w_descserver = ""; 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_FileName = CPLib.GetProperty(p,"FileName",w_FileName,0); w_PhName = CPLib.GetProperty(p,"PhName",w_PhName,0); w_ServerName = CPLib.GetProperty(p,"ServerName",w_ServerName,0); w_DateMod = CPLib.GetProperty(p,"DateMod",w_DateMod,0); w_descserver = CPLib.GetProperty(p,"descserver",w_descserver,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; map = new HashMap(); items = tables.get("cptsrvr"); if (CPLib.IsNull(items)) { items = new ArrayList>(); tables.put("cptsrvr",items); } items.add(map); map.put("rd_kvar",new String[]{}); map.put("rd_kfield",new String[]{}); map.put("rd_field",new String[]{"ServerName","ServerDesc"}); map.put("rd_var",new String[]{"w_ServerName","w_descserver"}); map.put("wr_var",new String[]{}); map.put("wr_field",new String[]{}); map.put("wr_op",new String[]{}); map.put("rd_var.obj_type",zeroSplit.split("C\u0000C",-1)); map.put("rd_kvar.obj_type",new String[]{}); map.put("rd_var.len",zeroSplit.split("10\u000030",-1)); map.put("rd_kvar.len",new String[]{}); map.put("rd_var.dec",zeroSplit.split("0\u00000",-1)); map.put("rd_kvar.dec",new String[]{}); map.put("rd_var.comment",zeroSplit.split("ServerName\u0000ADMIN_DESCRIPTION",-1)); map.put("rd_kvar.comment",new String[]{}); map.put("rd_var.key_num",zeroSplit.split("nokey\u0000nokey",-1)); map.put("rd_kvar.key_num",new String[]{}); map.put("rd_var.repeated",zeroSplit.split("FALSE\u0000FALSE",-1)); map.put("rd_kvar.repeated",new String[]{}); map.put("rd_var.frm_obbl",zeroSplit.split("\u0000",-1)); map.put("rd_kvar.frm_obbl",new String[]{}); map.put("rd_var.obj",zeroSplit.split("campo\u0000variabile",-1)); map.put("rd_kvar.obj",new String[]{}); map.put("property.value",zeroSplit.split("cptsrvr\u0000false\u0000false\u00001\u00000\u0000spadministration_servers\u0000false\u0000false\u0000\u0000\u0000\u0000false",-1)); map.put("property.name",zeroSplit.split("arch\u0000fillemptykey\u0000looselylinked\u0000src_key\u0000hst_link_mode\u0000prg_zoom\u0000looselylinked\u0000sendkeystozoomonzoom\u0000zoom_title\u0000prg_link_search\u0000prg_link_defaults\u0000",-1)); } 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_tables",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_tables",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_tables",m_Ctx); m_cPreviousState = GetCurrentState(); } public boolean Check() { boolean l_bResult; l_bResult = true; ResetErrorMessage(); // * --- Area Manuale = BO - Check Form // * --- Fine Area Manuale 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_tables"}; } if (CPLib.eq(l_Keys.length,0)) { l_Keys = new String[]{"spadministration_tables\\"+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 = 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 // 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,"FileName",w_FileName,0); CPLib.PutProperty(p,"PhName",w_PhName,0); CPLib.PutProperty(p,"ServerName",w_ServerName,0); CPLib.PutProperty(p,"DateMod",w_DateMod,0); CPLib.PutProperty(p,"descserver",w_descserver,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 "cpttbls"+"\\"+CPLib.ToCPStr(p_Caller.GetString("FileName","C",30,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 }