Function Service_Manager_Events(CtrlEntId, Event, Param1, Param2, Param3, Param4, Param5, Param6, Param7, Param8, Param9, Param10, Param11, Param12, Param13, Param14, Param15) /*********************************************************************************************************************** This program is proprietary and is not to be used by or disclosed to others, nor is it to be copied without written permission from Infineon. Name : Service_Manager_Events Description : This function acts as a commuter module for all events related to this window. Notes : Commuter Modules are automatically called from the Promoted_Events function which is called by the application-specific promoted event handler. This makes it possible to add QuickEvents that need to execute Basic+ logic without having use the Form Designer to make the association, although this is limited to the events which are currently promoted. If the form needs to call the commuter module directly then the QuickEvent parameters should be formatted like this: '@SELF','@EVENT',['@PARAM1','@PARAMx'] Parameters : CtrlEntId [in] -- The fully qualified name of the control calling the promoted event Event [in] -- The event being executed. See the Notes section regarding "PRE" events Param1-15 [in] -- Additional event parameter holders EventFlow [out] -- Set to 1 or 0 so the calling event knows whether or not to chain forward. See comments in EVENT_SETUP insert History : (Date, Initials, Notes) 07/26/17 dmb Created initial commuter module. 07/13/18 dmb Change protocol from calling service code directly to calling MCP. 05/27/20 djs Updated commuter module to read and write the last run datetime to the service record. ***********************************************************************************************************************/ #pragma precomp SRP_PreCompiler #Window SERVICE_MANAGER $insert APP_INSERTS $insert EVENT_SETUP $insert SERVICES_EQUATES $insert MSG_EQUATES Equate ActiveColor$ to 'Vertical(Gradient(Green L=70, Green L=30), Border(3DS))' Equate DeactiveColor$ to 'Vertical(Gradient(Red L=70, Red L=30), Border(3DS))' Common /ServiceManager/ TCPServerSettings@ Declare subroutine SRP_TcpClient, Yield, Database_Services Declare function SRP_TcpClient, Database_Services, Environment_Services, Service_Services SubclassInfo = Form_Services('FindSubclassControl') Subclass = SubclassInfo<1> // Update the arguments so that the OpenInsight OLE event will treate the ActiveX event as a native event handler. If Event EQ 'OLE' then Transfer Event to OIEvent Transfer Param1 to Event Transfer Param2 to Param1 Transfer Param3 to Param2 Transfer Param4 to Param3 Transfer Param5 to Param4 Transfer Param6 to Param5 Transfer Param7 to Param6 Transfer Param8 to Param7 end GoToEvent Event for CtrlEntID Return EventFlow else EVENT_CONTINUE$ //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// // Events //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// Event WINDOW.CREATE(CreateParam) Server = Environment_Services('GetServer') Text = Get_Property(@Window, 'TEXT') Text := ' - ' : Server Set_Property(@Window, 'TEXT', Text) GoSub Setup_OLE_Controls // Kick of the first TIMER event. Allow it to be self-triggering so TIMER events don't stack on top of each other. Set_Property(@Window, 'TIMER', 0 : @FM : 1000) SRP_Show_Window(@Window, '', 'R', 'B', 1, '', False$, False$) end event Event WINDOW.CLOSE(CancelFlag) // Turn off the TIMER event in case it is still triggered. Set_Property(@Window, 'TIMER', 0) Set_Property('SYSTEM','IDLEPROC','ADIOS') end event Event WINDOW.TIMER() ServiceList = Get_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.ColumnData[1]') If ServiceList NE '' then For Each Service in ServiceList using @VM setting vPos ServiceDetail = Service_Services('GetService', Service) Procedures = ServiceDetail Arguments = ServiceDetail For Each Procedure in Procedures using @VM setting procPos If Procedure[-9, 9] _EQC '_SERVICES' then Procedure[-9, 9] = '' Command = 'RUN MCP ' : Quote(Procedure) Arguments = Arguments<0, procPos> If Arguments NE '' then For Each Argument in Arguments using ',' Argument = Trim(Argument) If IndexC(Argument, '%Date%', 1) then // Using the Date token. Convert to current date and apply an date modifiers Modifier = Argument Convert @Upper_Case to @Lower_Case in Modifier Swap '%date%' with '' in Modifier Modifier = Trim(Modifier) If Index(Modifier, '-', 1) then Convert '- ' to '' in Modifier Modifier = Neg(Modifier) end else Convert '+ ' to '' in Modifier Modifier = Neg(Modifier) end If Not(Num(Modifier)) then Modifier = '' Argument = Date() + Modifier end Command := ', ' : Quote(Argument) Next Argument end Next Procedure // Check to see if this service is active. Use the color of the active button to verify. CellType = Get_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellType[7;' : vPos : ']') Active = CellType<3> EQ ActiveColor$ // If the service is active and this service has a command, check to see if it is time to call it. If (Active EQ True$) AND (Command NE '') then Cycle = Get_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[2;' : vPos : ']') LastRun = OConv(ServiceDetail, 'DT2/^HS') LastDate = Iconv(LastRun[1, ' '], 'D') LastTime = Iconv(LastRun[Col2() + 1, ' '], 'MT') LastSeconds = (LastDate * (24 * 60 * 60)) + LastTime CurrentSeconds = (Date() * (24 * 60 * 60)) + Time() Difference = CurrentSeconds - LastSeconds If Num(Cycle) then // Cycle contains the number of seconds this service runs in a loop. If Difference GE Cycle then // It has been long enough since the last time this service was called. Send the command to the SRP Engine Server. GoSub SendCommand DateTime = Oconv(Date(), 'D4/') : ' ' : Oconv(Time(), 'MTHS') FirstRun = Get_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[3;' : vPos : ']') If FirstRun EQ '' then Set_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[3;' : vPos : ']', DateTime) FirstRun = DateTime end Set_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[4;' : vPos : ']', DateTime) ServiceDetail = IConv(DateTime, 'DT') Database_Services('WriteDataRow', 'SERVICES', Service, ServiceDetail) LastDate = Iconv(DateTime[1, ' '], 'D') LastTime = Iconv(DateTime[Col2() + 1, ' '], 'MT') LastSeconds = (LastDate * (24 * 60 * 60)) + LastTime FirstDate = Iconv(FirstRun[1, ' '], 'D') FirstTime = Iconv(FirstRun[Col2() + 1, ' '], 'MT') FirstSeconds = (FirstDate * (24 * 60 * 60)) + FirstTime Uptime = ((LastSeconds - FirstSeconds) / (24 * 60 * 60)) Set_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[5;' : vPos : ']', Oconv(Iconv(Uptime, 'MD1'), 'MD1')) RunCount = Get_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[6;' : vPos : ']') RunCount += 1 Set_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[6;' : vPos : ']', RunCount) end end else // Cycle contains the trigger time that this service runs. TriggerTime = Iconv(Cycle, 'MT') // Make sure this service hasn't already been run on this date. If LastDate LT Date() then // Make sure the trigger time is close (within 30 seconds) to the actual time to avoid being // triggered if the service manager is restarted. If (TriggerTime GE Time()) AND (TriggerTime LE (Time() + 30)) then GoSub SendCommand DateTime = Oconv(Date(), 'D4/') : ' ' : Oconv(Time(), 'MTHS') FirstRun = Get_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[3;' : vPos : ']') If FirstRun EQ '' then Set_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[3;' : vPos : ']', DateTime) FirstRun = DateTime end Set_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[4;' : vPos : ']', DateTime) ServiceDetail = IConv(DateTime, 'DT') Database_Services('WriteDataRow', 'SERVICES', Service, ServiceDetail) LastDate = Iconv(DateTime[1, ' '], 'D') LastTime = Iconv(DateTime[Col2() + 1, ' '], 'MT') LastSeconds = (LastDate * (24 * 60 * 60)) + LastTime FirstDate = Iconv(FirstRun[1, ' '], 'D') FirstTime = Iconv(FirstRun[Col2() + 1, ' '], 'MT') FirstSeconds = (FirstDate * (24 * 60 * 60)) + FirstTime Uptime = ((LastSeconds - FirstSeconds) / (24 * 60 * 60)) Set_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[5;' : vPos : ']', Oconv(Iconv(Uptime, 'MD1'), 'MD1')) RunCount = Get_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[6;' : vPos : ']') RunCount += 1 Set_Property(@Window : '.OLE_EDT_SERVICES', 'OLE.CellText[6;' : vPos : ']', RunCount) end end end end If (Active EQ True$) AND (Command EQ '') then // Automatically turn off this service is there is no command. Send_Event(@Window : '.OLE_EDT_SERVICES', 'OLE', 'OnButtonClick', '7;' : vPos) end Next Service end // Call Yield() several times to allow for responsiveness with other events. Yield(); Yield(); Yield(); Yield(); Yield(); Yield(); Yield(); Yield(); Yield(); Yield(); Yield(); Yield(); Yield() // Trigger the next TIMER event 1 second from now. Set_Property(@Window, 'TIMER', 0 : @FM : 1000) end event Event OLE_EDT_SERVICES.OnButtonClick(Cell, Point, Button, Shift, Ctrl) Column = Cell[1, ';'] Row = Cell[Col2() + 1, ';'] CellType = Get_Property(CtrlEntId, 'OLE.CellType[' : Cell : ']') Color = CellType<3> If Color EQ ActiveColor$ then Color = DeactiveColor$ Text = 'Off' end else Color = ActiveColor$ Text = 'On' end CellType<3> = Color Set_Property(CtrlEntId, 'OLE.CellType[' : Cell : ']', CellType) Set_Property(CtrlEntId, 'OLE.CellText[' : Cell : ']', Text) If Text EQ 'On' then Set_Property(CtrlEntId, 'OLE.CellText[3;' : Row : ']', '') ; // Clear the first run date/time. Set_Property(CtrlEntId, 'OLE.CellText[5;' : Row : ']', 0) ; // Reset the uptime. Set_Property(CtrlEntId, 'OLE.CellText[6;' : Row : ']', 0) ; // Reset the run count. end end event //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// // Internal GoSubs //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// Setup_OLE_Controls: Ctrl = @Window : '.OLE_EDT_SERVICES' Set_Property(Ctrl, 'OLE.Dimension', 7 : @FM : 1) TitleList = 'Service Name' : @VM : 'Cycle (secs) or Run Time' : @VM : 'First Run' : @VM : 'Last Run' : @VM: 'Uptime (days)' : @VM : 'Run Count' : @VM : 'Active' Set_Property(Ctrl, 'OLE.TitleList', TitleList) Set_Property(Ctrl, 'OLE.HeaderColumn[1]', @FM : False$) Set_Property(Ctrl, 'OLE.HeaderFont[All; 1]', '' : @SVM : @SVM : '700') Set_Property(Ctrl, 'OLE.DataColumn[1]', 100 : @FM : True$ : @FM : False$ : @FM : True$) Set_Property(Ctrl, 'OLE.DataColumn[2]', 150 : @FM : True$ : @FM : False$ : @FM : False$) Set_Property(Ctrl, 'OLE.DataColumn[3]', 140 : @FM : True$ : @FM : False$ : @FM : False$) Set_Property(Ctrl, 'OLE.DataColumn[4]', 140 : @FM : True$ : @FM : False$ : @FM : False$) Set_Property(Ctrl, 'OLE.DataColumn[5]', 80 : @FM : True$ : @FM : False$ : @FM : False$) Set_Property(Ctrl, 'OLE.DataColumn[6]', 80 : @FM : True$ : @FM : False$ : @FM : False$) Set_Property(Ctrl, 'OLE.DataColumn[7]', 50 : @FM : True$ : @FM : False$ : @FM : False$) Set_Property(Ctrl, 'OLE.CellType[7; All]', 'Push Button' : @FM : @FM : ActiveColor$) Set_Property(Ctrl, 'OLE.CellAlignment[2; All]', '' : @FM : 'Center') Set_Property(Ctrl, 'OLE.CellAlignment[3; All]', '' : @FM : 'Center') Set_Property(Ctrl, 'OLE.CellAlignment[4; All]', '' : @FM : 'Center') Set_Property(Ctrl, 'OLE.CellAlignment[5; All]', '' : @FM : 'Right') Set_Property(Ctrl, 'OLE.CellAlignment[6; All]', '' : @FM : 'Right') Set_Property(Ctrl, 'OLE.CellAlignment[7; All]', '' : @FM : 'Center') Services = Service_Services('GetServices', Server) List = '' For Each Service in Services using @FM List := Service<0, 1> : @VM If Service<0, 2> NE '' then List := Service<0, 2> : @VM end else List := Oconv(Service<0, 3>, 'MTH') : @VM end List := @VM : @VM : 0 : @VM : 0 : @VM : 'On' : @FM Next Service List[-1, 1] = '' Set_Property(Ctrl, 'OLE.List', List) Qualify = '' Qualify<1> = 1 Qualify<4> = 0 Send_Message(Ctrl, 'QUALIFY_EVENT', 'OLE.OnButtonClick', 1) return SendCommand: // Call the SRPEngineService and pass it the command Server = Environment_Services('GetServer') TCPServerSettings@ = Environment_Services('GetApplicationRootIP') Convert '\\' to '' in TCPServerSettings@ // Get the port from the SRPEngineServer.ini file instead. FilePath = Drive():'\SRPEngineServer.ini' OSRead IniFile from FilePath then CharIndex = Index(IniFile, 'Port', 1) Line = IniFile[CharIndex, 'F':CRLF$] Port = Trim(Line[-1, 'B=']) TCPServerSettings@<2> = Port end TcpClientHandle = 0 If SRP_TcpClient(TcpClientHandle, 'CONNECT', TCPServerSettings@<1>, TCPServerSettings@<2>) then SRP_TcpClient(TcpClientHandle, 'SEND_SES', Command) SRP_TcpClient(TcpClientHandle, 'CLOSE_SES') end return