HLCSLNCH ;ALB/MTC/JC - START AND STOP THE LLP ;12/31/2003 17:37
;;1.6;HEALTH LEVEL SEVEN;**6,19,43,49,57,75,84,109**;Oct 13, 1995
;
;This program is callable from a menu
;It allows the user to Start and Stop the Lower Layer
;Protocol in the Background or in the foreground
;
;Required or Optional INPUT PARAMETERS
; None
;
;
;Output variables
; HLDP=IEN of Logical Link in file #870
;(optional)HLTRACE=if SET it launches the LLP in the Foreground
;(optional) ZTSK=if defined LLP was launched in the
;background
;
;
START ; Start up the lower level protocol
N DIC,DIRUT,DTOUT,DUOUT,HLDP,HLDAPP,HLJ,HLQUIT,HLTRACE
N HLPARM0,HLPARM4,HLTYPTR,HLBGR,X,Y,ZTCPU,ZTSK,ZTRTN,ZTDESC
W !!,"This option is used to launch the lower level protocol for the"
W !,"appropriate device. Please select the node with which you want"
W !,"to communicate",!
S DIC="^HLCS(870,",DIC(0)="QEAMZ" D ^DIC G:Y<0 STARTQ
S HLDP=+Y,HLDAPP=Y(0,0),HLTYPTR=+$P(Y(0),U,3),HLPARM0=Y(0)
;-- check if parameter have been setup
;-- check for LLP type
I 'HLTYPTR W !,$C(7),"A Lower Layer Protocol must be selected before start-up can occur." G STARTQ
;-- get TCP information
S HLPARM4=$G(^HLCS(870,HLDP,400))
;-- get routine (background job for LLP)
S HLBGR=$G(^HLCS(869.1,HLTYPTR,100))
;-- get environment check routine (HLQUIT should be defined in fails)
S HLENV=$G(^HLCS(869.1,HLTYPTR,200))
;
I HLBGR="" W !,$C(7),"No routine has been specified for this LLP." G STARTQ
;
;-- execute environment check routine if HLQUIT is defined then terminate
I HLENV'="" X HLENV G:$D(HLQUIT) STARTQ
;Multi-Servers, only enable the link if not OpenM
I $P(HLPARM4,U,3)="M",$S(^%ZOSF("OS")'["OpenM":1,1:$$OS^%ZOSV["VMS") D G STARTQ
. W !,$C(7),"This LLP is a multi-threaded server. It is controlled by external service, i.e. TCPIP/UCX. You must use the external service to start this LLP."
. Q
;
I $P(HLPARM0,U,10) W !,$C(7),"The LLP was last started on ",$$DAT2^HLUTIL1($P(HLPARM0,U,10)),"." G STP1:$P(HLPARM0,U,5)'="Error"
I $P(HLPARM0,U,11) W !,"The LLP was last shutdown on ",$$DAT2^HLUTIL1($P(HLPARM0,U,11)),"."
I $P(HLPARM0,U,5)'="Error",'($P(HLPARM4,U,3)="C"&("N"[$P(HLPARM4,U,4))),$P(HLPARM0,U,10)]""&($P(HLPARM0,U,11)=""),$P(HLPARM0,U,12) W !,"The LLP appears to be online already !"
I $$TASK^HLUTIL1($P(HLPARM0,U,12)) D G STARTQ
. W !,$C(7),"NOTE: The lower level protocol for this application is already running."
I $P(HLPARM4,U,3)="C"&("N"[$P(HLPARM4,U,4)) D G STARTQ
.;4=status 9=Time Started, 10=Time Stopped, 11=Task Number
.;14=Shutdown LLP, 3=Device Type, 18=Gross Errors
.N HLJ,X
.I $P(HLPARM0,U,15)=0 W !,"This LLP is already enabled!" Q
.L +^HLCS(870,HLDP,0):2
.E W !,$C(7),"Unable to enable this LLP !" Q
.S X="HLJ(870,"""_HLDP_","")"
.S @X@(4)="Enabled",@X@(9)=$$NOW^XLFDT,@X@(14)=0
.D FILE^HLDIE("","HLJ","","START","HLCSLNCH") ;HL*1.6*109
.L -^HLCS(870,HLDP,0)
.W !,"This LLP has been enabled!"
.Q
I $P(HLPARM4,U,6),$D(^%ZIS(14.7,+$P(HLPARM4,U,6),0)) S ZTCPU=$P(^(0),U) W !,"This LLP will start on node ",ZTCPU," if it is run in the Background.",!
;
W ! S DIR(0)="SM^F:FOREGROUND;B:BACKGROUND;Q:QUIT"
S DIR("A")="Method for running the receiver"
S DIR("B")="B"
S DIR("?",1)="Enter F for Foreground (and trace)"
S DIR("?",2)=" B for Background (normal) or"
S DIR("?")=" Q to quit without starting the receiver"
D ^DIR K DIR
Q:(Y=U)!(Y="Q")
;
S HLX=$G(^HLCS(870,HLDP,0))
;-- foreground
I Y="F" S HLTRACE=1 D G STARTQ
. X HLBGR
;-- background
I Y="B" D G STARTQ
. S ZTRTN=$P(HLBGR," ",2),HLTRACE="",ZTIO="",ZTDTH=$H
. S ZTDESC=HLDAPP_" Low Level Protocol",ZTSAVE("HLDP")=""
. D ^%ZTLOAD
. W !,$S($D(ZTSK):"Job was queued as "_ZTSK_".",1:"Unable to queue job.")
;
Q
;
;
STARTQ ;
I $G(POP) W !,?5,"-Unable to Open the Device !",!,!,?6,"Check that Port is Logged Out, and that the",!,?6,"Lower Level Protocol is not Already Running."
Q
;
STOP ; Shut down a lower level protocol..
N DIC,DIRUT,DTOUT,DUOUT,HLDP,HLDAPP,HLJ,HLPARM0,HLPARM4,X,Y
W !!,"This option is used to shut down the lower level protocol for the"
W !,"appropriate device. Please select the link which you would"
W !,"like to shutdown.",!
S DIC="^HLCS(870,",DIC(0)="QEAMZ" D ^DIC K DIC Q:Y<0
S HLDP=+Y,HLDAPP=Y(0,0),HLPARM0=Y(0),HLPARM4=$G(^HLCS(870,HLDP,400))
I $P(HLPARM4,U,3)="M",$S(^%ZOSF("OS")'["OpenM":1,1:$$OS^%ZOSV["VMS") D Q
. W !,$C(7),"This LLP is a multi-threaded server. It is controlled by external service, i.e. UCX. You must use the external service to disable this LLP."
. Q
;
I $P(HLPARM0,U,15) W !,$C(7),"The lower level protocol is already ",$P(HLPARM0,U,5),"." Q
I $P(HLPARM0,U,10) W !,$C(7),"The lower level protocol was started on ",$$DAT2^HLUTIL1($P(HLPARM0,U,10)),"."
STP1 ;
W ! S DIR(0)="Y",DIR("A")="Okay to shut down this job" D ^DIR K DIR
I 'Y!($D(DIRUT))!($D(DUOUT)) W !!,"The job will not be shut down." Q
S ;
F L +^HLCS(870,HLDP,0):2 Q:$T
;4=status,10=Time Stopped,9=Time Started,11=Task Number,3=Device Type,14=shutdown
S X="HLJ(870,"""_HLDP_","")",@X@(4)="Halting",@X@(10)=$$NOW^XLFDT,(@X@(11),@X@(9))="@",@X@(14)=1
I $P(HLPARM4,U,3)="C"&("N"[$P(HLPARM4,U,4)),'$P(HLPARM0,U,12) S @X@(4)="Shutdown"
D FILE^HLDIE("","HLJ","","STOP","HLCSLNCH") ; HL*1.6*109
I ^%ZOSF("OS")["OpenM",(($P(HLPARM4,U,3)="M"&($$OS^%ZOSV'["VMS"))!($P(HLPARM4,U,3)="S")) D
. ;pass task number to stop listener
. S:$P(HLPARM0,U,12) X=$$ASKSTOP^%ZTLOAD(+$P(HLPARM0,U,12))
. D CALL^%ZISTCP($P(HLPARM4,U),$P(HLPARM4,U,2),10)
. I POP D HOME^%ZIS U IO W !,"Unable to shutdown logical link!!!",$C(7),$C(7) Q
. U IO W "**STOP**"
. W !
. D CLOSE^%ZISTCP
L -^HLCS(870,HLDP,0)
W !,"The job for the "_HLDAPP_" Lower Level Protocol will be shut down."
Q
;
STOPQ Q
HLCSLNCH ;ALB/MTC/JC - START AND STOP THE LLP ;12/31/2003 17:37
+1 ;;1.6;HEALTH LEVEL SEVEN;**6,19,43,49,57,75,84,109**;Oct 13, 1995
+2 ;
+3 ;This program is callable from a menu
+4 ;It allows the user to Start and Stop the Lower Layer
+5 ;Protocol in the Background or in the foreground
+6 ;
+7 ;Required or Optional INPUT PARAMETERS
+8 ; None
+9 ;
+10 ;
+11 ;Output variables
+12 ; HLDP=IEN of Logical Link in file #870
+13 ;(optional)HLTRACE=if SET it launches the LLP in the Foreground
+14 ;(optional) ZTSK=if defined LLP was launched in the
+15 ;background
+16 ;
+17 ;
START ; Start up the lower level protocol
+1 NEW DIC,DIRUT,DTOUT,DUOUT,HLDP,HLDAPP,HLJ,HLQUIT,HLTRACE
+2 NEW HLPARM0,HLPARM4,HLTYPTR,HLBGR,X,Y,ZTCPU,ZTSK,ZTRTN,ZTDESC
+3 WRITE !!,"This option is used to launch the lower level protocol for the"
+4 WRITE !,"appropriate device. Please select the node with which you want"
+5 WRITE !,"to communicate",!
+6 SET DIC="^HLCS(870,"
SET DIC(0)="QEAMZ"
DO ^DIC
IF Y<0
GOTO STARTQ
+7 SET HLDP=+Y
SET HLDAPP=Y(0,0)
SET HLTYPTR=+$PIECE(Y(0),U,3)
SET HLPARM0=Y(0)
+8 ;-- check if parameter have been setup
+9 ;-- check for LLP type
+10 IF 'HLTYPTR
WRITE !,$CHAR(7),"A Lower Layer Protocol must be selected before start-up can occur."
GOTO STARTQ
+11 ;-- get TCP information
+12 SET HLPARM4=$GET(^HLCS(870,HLDP,400))
+13 ;-- get routine (background job for LLP)
+14 SET HLBGR=$GET(^HLCS(869.1,HLTYPTR,100))
+15 ;-- get environment check routine (HLQUIT should be defined in fails)
+16 SET HLENV=$GET(^HLCS(869.1,HLTYPTR,200))
+17 ;
+18 IF HLBGR=""
WRITE !,$CHAR(7),"No routine has been specified for this LLP."
GOTO STARTQ
+19 ;
+20 ;-- execute environment check routine if HLQUIT is defined then terminate
+21 IF HLENV'=""
XECUTE HLENV
IF $DATA(HLQUIT)
GOTO STARTQ
+22 ;Multi-Servers, only enable the link if not OpenM
+23 IF $PIECE(HLPARM4,U,3)="M"
IF $SELECT(^%ZOSF("OS")'["OpenM":1,1:$$OS^%ZOSV["VMS")
Begin DoDot:1
+24 WRITE !,$CHAR(7),"This LLP is a multi-threaded server. It is controlled by external service, i.e. TCPIP/UCX. You must use the external service to start this LLP."
+25 QUIT
End DoDot:1
GOTO STARTQ
+26 ;
+27 IF $PIECE(HLPARM0,U,10)
WRITE !,$CHAR(7),"The LLP was last started on ",$$DAT2^HLUTIL1($PIECE(HLPARM0,U,10)),"."
IF $PIECE(HLPARM0,U,5)'="Error"
GOTO STP1
+28 IF $PIECE(HLPARM0,U,11)
WRITE !,"The LLP was last shutdown on ",$$DAT2^HLUTIL1($PIECE(HLPARM0,U,11)),"."
+29 IF $PIECE(HLPARM0,U,5)'="Error"
IF '($PIECE(HLPARM4,U,3)="C"&("N"[$PIECE(HLPARM4,U,4)))
IF $PIECE(HLPARM0,U,10)]""&($PIECE(HLPARM0,U,11)="")
IF $PIECE(HLPARM0,U,12)
WRITE !,"The LLP appears to be online already !"
+30 IF $$TASK^HLUTIL1($PIECE(HLPARM0,U,12))
Begin DoDot:1
+31 WRITE !,$CHAR(7),"NOTE: The lower level protocol for this application is already running."
End DoDot:1
GOTO STARTQ
+32 IF $PIECE(HLPARM4,U,3)="C"&("N"[$PIECE(HLPARM4,U,4))
Begin DoDot:1
+33 ;4=status 9=Time Started, 10=Time Stopped, 11=Task Number
+34 ;14=Shutdown LLP, 3=Device Type, 18=Gross Errors
+35 NEW HLJ,X
+36 IF $PIECE(HLPARM0,U,15)=0
WRITE !,"This LLP is already enabled!"
QUIT
+37 LOCK +^HLCS(870,HLDP,0):2
+38 IF '$TEST
WRITE !,$CHAR(7),"Unable to enable this LLP !"
QUIT
+39 SET X="HLJ(870,"""_HLDP_","")"
+40 SET @X@(4)="Enabled"
SET @X@(9)=$$NOW^XLFDT
SET @X@(14)=0
+41 ;HL*1.6*109
DO FILE^HLDIE("","HLJ","","START","HLCSLNCH")
+42 LOCK -^HLCS(870,HLDP,0)
+43 WRITE !,"This LLP has been enabled!"
+44 QUIT
End DoDot:1
GOTO STARTQ
+45 IF $PIECE(HLPARM4,U,6)
IF $DATA(^%ZIS(14.7,+$PIECE(HLPARM4,U,6),0))
SET ZTCPU=$PIECE(^(0),U)
WRITE !,"This LLP will start on node ",ZTCPU," if it is run in the Background.",!
+46 ;
+47 WRITE !
SET DIR(0)="SM^F:FOREGROUND;B:BACKGROUND;Q:QUIT"
+48 SET DIR("A")="Method for running the receiver"
+49 SET DIR("B")="B"
+50 SET DIR("?",1)="Enter F for Foreground (and trace)"
+51 SET DIR("?",2)=" B for Background (normal) or"
+52 SET DIR("?")=" Q to quit without starting the receiver"
+53 DO ^DIR
KILL DIR
+54 IF (Y=U)!(Y="Q")
QUIT
+55 ;
+56 SET HLX=$GET(^HLCS(870,HLDP,0))
+57 ;-- foreground
+58 IF Y="F"
SET HLTRACE=1
Begin DoDot:1
+59 XECUTE HLBGR
End DoDot:1
GOTO STARTQ
+60 ;-- background
+61 IF Y="B"
Begin DoDot:1
+62 SET ZTRTN=$PIECE(HLBGR," ",2)
SET HLTRACE=""
SET ZTIO=""
SET ZTDTH=$HOROLOG
+63 SET ZTDESC=HLDAPP_" Low Level Protocol"
SET ZTSAVE("HLDP")=""
+64 DO ^%ZTLOAD
+65 WRITE !,$SELECT($DATA(ZTSK):"Job was queued as "_ZTSK_".",1:"Unable to queue job.")
End DoDot:1
GOTO STARTQ
+66 ;
+67 QUIT
+68 ;
+69 ;
STARTQ ;
+1 IF $GET(POP)
WRITE !,?5,"-Unable to Open the Device !",!,!,?6,"Check that Port is Logged Out, and that the",!,?6,"Lower Level Protocol is not Already Running."
+2 QUIT
+3 ;
STOP ; Shut down a lower level protocol..
+1 NEW DIC,DIRUT,DTOUT,DUOUT,HLDP,HLDAPP,HLJ,HLPARM0,HLPARM4,X,Y
+2 WRITE !!,"This option is used to shut down the lower level protocol for the"
+3 WRITE !,"appropriate device. Please select the link which you would"
+4 WRITE !,"like to shutdown.",!
+5 SET DIC="^HLCS(870,"
SET DIC(0)="QEAMZ"
DO ^DIC
KILL DIC
IF Y<0
QUIT
+6 SET HLDP=+Y
SET HLDAPP=Y(0,0)
SET HLPARM0=Y(0)
SET HLPARM4=$GET(^HLCS(870,HLDP,400))
+7 IF $PIECE(HLPARM4,U,3)="M"
IF $SELECT(^%ZOSF("OS")'["OpenM":1,1:$$OS^%ZOSV["VMS")
Begin DoDot:1
+8 WRITE !,$CHAR(7),"This LLP is a multi-threaded server. It is controlled by external service, i.e. UCX. You must use the external service to disable this LLP."
+9 QUIT
End DoDot:1
QUIT
+10 ;
+11 IF $PIECE(HLPARM0,U,15)
WRITE !,$CHAR(7),"The lower level protocol is already ",$PIECE(HLPARM0,U,5),"."
QUIT
+12 IF $PIECE(HLPARM0,U,10)
WRITE !,$CHAR(7),"The lower level protocol was started on ",$$DAT2^HLUTIL1($PIECE(HLPARM0,U,10)),"."
STP1 ;
+1 WRITE !
SET DIR(0)="Y"
SET DIR("A")="Okay to shut down this job"
DO ^DIR
KILL DIR
+2 IF 'Y!($DATA(DIRUT))!($DATA(DUOUT))
WRITE !!,"The job will not be shut down."
QUIT
S ;
+1 FOR
LOCK +^HLCS(870,HLDP,0):2
IF $TEST
QUIT
+2 ;4=status,10=Time Stopped,9=Time Started,11=Task Number,3=Device Type,14=shutdown
+3 SET X="HLJ(870,"""_HLDP_","")"
SET @X@(4)="Halting"
SET @X@(10)=$$NOW^XLFDT
SET (@X@(11),@X@(9))="@"
SET @X@(14)=1
+4 IF $PIECE(HLPARM4,U,3)="C"&("N"[$PIECE(HLPARM4,U,4))
IF '$PIECE(HLPARM0,U,12)
SET @X@(4)="Shutdown"
+5 ; HL*1.6*109
DO FILE^HLDIE("","HLJ","","STOP","HLCSLNCH")
+6 IF ^%ZOSF("OS")["OpenM"
IF (($PIECE(HLPARM4,U,3)="M"&($$OS^%ZOSV'["VMS"))!($PIECE(HLPARM4,U,3)="S"))
Begin DoDot:1
+7 ;pass task number to stop listener
+8 IF $PIECE(HLPARM0,U,12)
SET X=$$ASKSTOP^%ZTLOAD(+$PIECE(HLPARM0,U,12))
+9 DO CALL^%ZISTCP($PIECE(HLPARM4,U),$PIECE(HLPARM4,U,2),10)
+10 IF POP
DO HOME^%ZIS
USE IO
WRITE !,"Unable to shutdown logical link!!!",$CHAR(7),$CHAR(7)
QUIT
+11 USE IO
WRITE "**STOP**"
+12 WRITE !
+13 DO CLOSE^%ZISTCP
End DoDot:1
+14 LOCK -^HLCS(870,HLDP,0)
+15 WRITE !,"The job for the "_HLDAPP_" Lower Level Protocol will be shut down."
+16 QUIT
+17 ;
STOPQ QUIT