PSXRSYU ;BIR/WPB,BAB-CMOP SYSTEM File Utility ;09 SEP 1998 6:48 AM
;;2.0;CMOP;**1,18,41**;11 Apr 97
BATCH ;sets up the variables and makes the entry to PSX(550.2
I $G(PSXRTRN)=1 G EN
;Q:'$D(^TMP($J,"PSX"))
EN D NOW^%DTC S (PSXTDT,DTTM)=% K %
K DD,DO
S PSXDUZ=DUZ
L L +^PSX(550.2,0):600 I '$T S PSXFILE="CMOP Transmission" D RALRT^PSXUTL Q
F S X=$O(^PSX(550.2,"B","A"),-1)+1 ; later use Julian number for batch name
S DIC="^PSX(550.2,",DIC(0)="Z"
S DIC("DR")="1////1;2////"_PSOSITE_";3////"_+PSXSYS_";4////"_PSXDUZ_";6////"_DTTM_";17////"_$S($G(PSXCS)=1:"C",1:"N")
D FILE^DICN G:$P($G(Y),U,3)'=1 F S PSXBAT=+Y
L -^PSX(550.2,0)
K DA,DIC,DUOUT,DTOUT,X,Y,DTTM
Q
BATCHNM() ;
;Make batch number as YYJDTHHMMSS where JDT is 3 digit julian date
;make julian date: get current year append 1st month 1st day compute diff from today.
N J1,J2,JDT,X1,X2
D NOW^%DTC
S X1=$E(%,1,3)_"0101",X2=DT+1,JDT=$$FMDIFF^XLFDT(X1,X2,1)
;change sign - to +
S JDT=(JDT*-1)
;pad with 0s
I $L(JDT)<3 F I=1:1:(3-$L(JDT)) S JDT="0"_JDT
S J1=$E(%,2,3),J2=$E(%,9,12),BATCH=J1_JDT_J2
K %
Q BATCH
AFTER L +^PSX(550.2,PSXBAT):600 Q:'$T
S DA=PSXBAT,DIE="^PSX(550.2,"
S DR="1////2" D ^DIE K DA,DIE,DR
L -^PSX(550.2,PSXBAT)
AFTER1 L +^PSX(550,+PSXSYS):600 Q:'$T
S DA=+PSXSYS,DIE="^PSX(550,",DR="6////"_PSXBAT D ^DIE K DIE,DA,DR
L -^PSX(550,+PSXSYS)
Q
PSXSTAT ;
L +^PSX(550,+PSXSYS,0):30 I '$T,$E(IOST)="C" W !!,"The CMOP System file is in use, try again later." S PSXLOCK=1 Q
N TSK K DIC,DA,DR,DIE
S TSK=$S($G(PSXSTAT)="H":"@",$G(PSXSTAT)="T":$G(PSXZTSK),1:"@")
S DA=+PSXSYS
S DIE=550,DR="2////^S X=PSXSTAT;9///^S X=TSK"
D ^DIE
L -^PSX(550,+PSXSYS,0)
K PSXSTAT
Q
;Called by Taskman to update file 550.2 for transmissions.
ACK S ZTREQ="@"
F YY="PSXBATNM^2","BMSG^4","EMSG^5","ADT^6","PSXSENDR^8","PSXMSGCT^9","PSXRXCT^10","PSXRTRN^11","PSXDIV^12","PSXREF^13" D PIECE^PSXUTL(XMRG,U,YY)
;
S PSXSER="S."_XQSOP,PSXXMZ=XQMSG,PSXSTART=BMSG,PSXEND=EMSG
S PSXBAT=$O(^PSX(550.2,"B",PSXBATNM,0))
;
;S PSXBAT=$P(XMRG,U,2),ADT=$P(XMRG,U,6),BMSG=$P(XMRG,U,4),EMSG=$P(XMRG,U,5),PSXSENDR=$P(XMRG,U,8),PSXMSGCT=$P(XMRG,U,9),PSXRXCT=$P(XMRG,U,10),PSXRTRN=$P(XMRG,U,11),PSXSER="S."_XQSOP,PSXXMZ=XQMSG
;S PSXDIV=$P(XMRG,U,12),PSXSTART=BMSG,PSXEND=EMSG,PSXREF=$P(XMRG,U,13)
D SET^PSXSYS S PSXSYST=+PSXSYS
S ZX=$$KSP^XUPARAM("INST"),DIC="4",DIC(0)="OMXZ",X=ZX D ^DIC S PSXSITE=$P(Y,"^",2) K DIC,X,Y
L +^PSX(550.2,PSXBAT):600 Q:'$T
K DA,DIE,DR
S DA=PSXBAT,DIE="^PSX(550.2,",DR="1////3;7////"_ADT D ^DIE K DA,DIE,DR
L -^PSX(550.2,PSXBAT)
S:$P($G(^PSX(550.2,PSXBAT,1)),U,3)'="" PSXRTRN=1
K XMZ
I $P(XMRG,U,1)="$$ACKN" S PSXFLAG=3 D EN^PSXNOTE S XMSER=PSXSER,XMZ=PSXXMZ D REMSBMSG^XMA1C K ADT G EX1
G:$P(XMRG,U,1)="$$VACK" ACKN^PSXRXQU
EX1 K PSXBAT,ADT,BMSG,EMSG,PSXSENDR,PSXMSGCT,PSXRXCT,PSXRTRN,PSXSER,PSXDIV,PSXSTART,PSXEND,PSXREF,PSXFLAG Q
ACT ;actives/inactivates the systems status in PSX(550
S SYSTEM=$P(XMRG,U,3),STAT=$P(XMRG,U,2),DTTM=$P(XMRG,U,4),NAME=$P(XMRG,U,5),OLDDTTM=$P(XMRG,U,6),XMSER="S."_XQSOP,TXMZ=XQMSG,OFF=$P(XMRG,U,7),ZTREQ="@"
I (STAT="A")!(STAT="I") D
.S RESP=$S(STAT="A":"A",STAT="I":"D",1:"")
.L +^PSX(550,SYSTEM):DTIME Q:'$T
.S DA=SYSTEM,DIE="^PSX(550,",DR="1////"_STAT D ^DIE K DIE,DA
.F RECD=0:0 S RECD=$O(^PSX(550,"AC",RECD)) Q:RECD'>0 S RC=RECD,TYPE=$P($G(^PSX(550,SYSTEM,1,RC,0)),U,1) I TYPE=OLDDTTM S DA(1)=SYSTEM,DA=RC,DIE="^PSX(550,"_SYSTEM_",1,",DR="2////"_DTTM_";3////"_RESP_";4////"_STAT D ^DIE K DIE,DA,DR,X
.L -^PSX(550,SYSTEM)
I STAT="D" D
.L +^PSX(550,SYSTEM):DTIME Q:'$T
.F RECD=0:0 S RECD=$O(^PSX(550,"AC",RECD)) Q:RECD'>0 S RC=RECD,TYPE=$P($G(^PSX(550,SYSTEM,1,RC,0)),U,1) Q:TYPE'=OLDDTTM S DA(1)=SYSTEM,DA=RC,DIE="^PSX(550,"_SYSTEM_",1,",DR="2////"_DTTM_";3////N" D ^DIE K DIE,DA,DR,X
.L -^PSX(550,SYSTEM)
K RECD,RC
S SYS=$P($G(^PSX(550,SYSTEM,0)),U,1)
D GRP^PSXNOTE
S XQAMSG=$S(STAT="A":"Permission to transmit to "_SYS_" has been received.",STAT="I":"Permission to transmit to "_SYS_" has been denied.",1:"") D GRP1^PSXNOTE,SETUP^XQALERT
S Y=DTTM X ^DD("DD") S DTTM=Y
S XMZ=$G(TXMZ),XMSER="S.PSXX CMOP SERVER" D:$G(XMZ)>0 REMSBMSG^XMA1C K XMZ,XMSER
Q:$G(STAT)="D"
MSG S XMSUB=($S(STAT="A":"CMOP Activation Approved",STAT="I":"CMOP Activation Disapproved",1:"")),LCNT=6,XMDUZ=.5
D XMZ^XMA2 G:XMZ<1 MSG
S ^XMB(3.9,XMZ,2,1,0)="Request to activate CMOP processing."
S ^XMB(3.9,XMZ,2,2,0)=""
S ^XMB(3.9,XMZ,2,3,0)="CMOP : "_SYS
S ^XMB(3.9,XMZ,2,4,0)="Approving Official: "_$P(NAME,",",2)_" "_$P(NAME,",",1)
S ^XMB(3.9,XMZ,2,5,0)="Action Date/Time : "_$P(DTTM,":",1,2)
S ^XMB(3.9,XMZ,2,6,0)="Action : "_$S(STAT="A":"Approved",STAT="I":"Disapproved",1:"")
S ^XMB(3.9,XMZ,2,0)="^3.92A^"_LCNT_U_LCNT_U_DT,XMDUN="CMOP MANAGER"
K XMY S XMDUZ=.5
D GRP^PSXNOTE,ENT1^XMD
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSXRSYU 4859 printed Oct 16, 2024@17:45:53 Page 2
PSXRSYU ;BIR/WPB,BAB-CMOP SYSTEM File Utility ;09 SEP 1998 6:48 AM
+1 ;;2.0;CMOP;**1,18,41**;11 Apr 97
BATCH ;sets up the variables and makes the entry to PSX(550.2
+1 IF $GET(PSXRTRN)=1
GOTO EN
+2 ;Q:'$D(^TMP($J,"PSX"))
EN DO NOW^%DTC
SET (PSXTDT,DTTM)=%
KILL %
+1 KILL DD,DO
+2 SET PSXDUZ=DUZ
L LOCK +^PSX(550.2,0):600
IF '$TEST
SET PSXFILE="CMOP Transmission"
DO RALRT^PSXUTL
QUIT
F ; later use Julian number for batch name
SET X=$ORDER(^PSX(550.2,"B","A"),-1)+1
+1 SET DIC="^PSX(550.2,"
SET DIC(0)="Z"
+2 SET DIC("DR")="1////1;2////"_PSOSITE_";3////"_+PSXSYS_";4////"_PSXDUZ_";6////"_DTTM_";17////"_$SELECT($GET(PSXCS)=1:"C",1:"N")
+3 DO FILE^DICN
if $PIECE($GET(Y),U,3)'=1
GOTO F
SET PSXBAT=+Y
+4 LOCK -^PSX(550.2,0)
+5 KILL DA,DIC,DUOUT,DTOUT,X,Y,DTTM
+6 QUIT
BATCHNM() ;
+1 ;Make batch number as YYJDTHHMMSS where JDT is 3 digit julian date
+2 ;make julian date: get current year append 1st month 1st day compute diff from today.
+3 NEW J1,J2,JDT,X1,X2
+4 DO NOW^%DTC
+5 SET X1=$EXTRACT(%,1,3)_"0101"
SET X2=DT+1
SET JDT=$$FMDIFF^XLFDT(X1,X2,1)
+6 ;change sign - to +
+7 SET JDT=(JDT*-1)
+8 ;pad with 0s
+9 IF $LENGTH(JDT)<3
FOR I=1:1:(3-$LENGTH(JDT))
SET JDT="0"_JDT
+10 SET J1=$EXTRACT(%,2,3)
SET J2=$EXTRACT(%,9,12)
SET BATCH=J1_JDT_J2
+11 KILL %
+12 QUIT BATCH
AFTER LOCK +^PSX(550.2,PSXBAT):600
if '$TEST
QUIT
+1 SET DA=PSXBAT
SET DIE="^PSX(550.2,"
+2 SET DR="1////2"
DO ^DIE
KILL DA,DIE,DR
+3 LOCK -^PSX(550.2,PSXBAT)
AFTER1 LOCK +^PSX(550,+PSXSYS):600
if '$TEST
QUIT
+1 SET DA=+PSXSYS
SET DIE="^PSX(550,"
SET DR="6////"_PSXBAT
DO ^DIE
KILL DIE,DA,DR
+2 LOCK -^PSX(550,+PSXSYS)
+3 QUIT
PSXSTAT ;
+1 LOCK +^PSX(550,+PSXSYS,0):30
IF '$TEST
IF $EXTRACT(IOST)="C"
WRITE !!,"The CMOP System file is in use, try again later."
SET PSXLOCK=1
QUIT
+2 NEW TSK
KILL DIC,DA,DR,DIE
+3 SET TSK=$SELECT($GET(PSXSTAT)="H":"@",$GET(PSXSTAT)="T":$GET(PSXZTSK),1:"@")
+4 SET DA=+PSXSYS
+5 SET DIE=550
SET DR="2////^S X=PSXSTAT;9///^S X=TSK"
+6 DO ^DIE
+7 LOCK -^PSX(550,+PSXSYS,0)
+8 KILL PSXSTAT
+9 QUIT
+10 ;Called by Taskman to update file 550.2 for transmissions.
ACK SET ZTREQ="@"
+1 FOR YY="PSXBATNM^2","BMSG^4","EMSG^5","ADT^6","PSXSENDR^8","PSXMSGCT^9","PSXRXCT^10","PSXRTRN^11","PSXDIV^12","PSXREF^13"
DO PIECE^PSXUTL(XMRG,U,YY)
+2 ;
+3 SET PSXSER="S."_XQSOP
SET PSXXMZ=XQMSG
SET PSXSTART=BMSG
SET PSXEND=EMSG
+4 SET PSXBAT=$ORDER(^PSX(550.2,"B",PSXBATNM,0))
+5 ;
+6 ;S PSXBAT=$P(XMRG,U,2),ADT=$P(XMRG,U,6),BMSG=$P(XMRG,U,4),EMSG=$P(XMRG,U,5),PSXSENDR=$P(XMRG,U,8),PSXMSGCT=$P(XMRG,U,9),PSXRXCT=$P(XMRG,U,10),PSXRTRN=$P(XMRG,U,11),PSXSER="S."_XQSOP,PSXXMZ=XQMSG
+7 ;S PSXDIV=$P(XMRG,U,12),PSXSTART=BMSG,PSXEND=EMSG,PSXREF=$P(XMRG,U,13)
+8 DO SET^PSXSYS
SET PSXSYST=+PSXSYS
+9 SET ZX=$$KSP^XUPARAM("INST")
SET DIC="4"
SET DIC(0)="OMXZ"
SET X=ZX
DO ^DIC
SET PSXSITE=$PIECE(Y,"^",2)
KILL DIC,X,Y
+10 LOCK +^PSX(550.2,PSXBAT):600
if '$TEST
QUIT
+11 KILL DA,DIE,DR
+12 SET DA=PSXBAT
SET DIE="^PSX(550.2,"
SET DR="1////3;7////"_ADT
DO ^DIE
KILL DA,DIE,DR
+13 LOCK -^PSX(550.2,PSXBAT)
+14 if $PIECE($GET(^PSX(550.2,PSXBAT,1)),U,3)'=""
SET PSXRTRN=1
+15 KILL XMZ
+16 IF $PIECE(XMRG,U,1)="$$ACKN"
SET PSXFLAG=3
DO EN^PSXNOTE
SET XMSER=PSXSER
SET XMZ=PSXXMZ
DO REMSBMSG^XMA1C
KILL ADT
GOTO EX1
+17 if $PIECE(XMRG,U,1)="$$VACK"
GOTO ACKN^PSXRXQU
EX1 KILL PSXBAT,ADT,BMSG,EMSG,PSXSENDR,PSXMSGCT,PSXRXCT,PSXRTRN,PSXSER,PSXDIV,PSXSTART,PSXEND,PSXREF,PSXFLAG
QUIT
ACT ;actives/inactivates the systems status in PSX(550
+1 SET SYSTEM=$PIECE(XMRG,U,3)
SET STAT=$PIECE(XMRG,U,2)
SET DTTM=$PIECE(XMRG,U,4)
SET NAME=$PIECE(XMRG,U,5)
SET OLDDTTM=$PIECE(XMRG,U,6)
SET XMSER="S."_XQSOP
SET TXMZ=XQMSG
SET OFF=$PIECE(XMRG,U,7)
SET ZTREQ="@"
+2 IF (STAT="A")!(STAT="I")
Begin DoDot:1
+3 SET RESP=$SELECT(STAT="A":"A",STAT="I":"D",1:"")
+4 LOCK +^PSX(550,SYSTEM):DTIME
if '$TEST
QUIT
+5 SET DA=SYSTEM
SET DIE="^PSX(550,"
SET DR="1////"_STAT
DO ^DIE
KILL DIE,DA
+6 FOR RECD=0:0
SET RECD=$ORDER(^PSX(550,"AC",RECD))
if RECD'>0
QUIT
SET RC=RECD
SET TYPE=$PIECE($GET(^PSX(550,SYSTEM,1,RC,0)),U,1)
IF TYPE=OLDDTTM
SET DA(1)=SYSTEM
SET DA=RC
SET DIE="^PSX(550,"_SYSTEM_",1,"
SET DR="2////"_DTTM_";3////"_RESP_";4////"_STAT
DO ^DIE
KILL DIE,DA,DR,X
+7 LOCK -^PSX(550,SYSTEM)
End DoDot:1
+8 IF STAT="D"
Begin DoDot:1
+9 LOCK +^PSX(550,SYSTEM):DTIME
if '$TEST
QUIT
+10 FOR RECD=0:0
SET RECD=$ORDER(^PSX(550,"AC",RECD))
if RECD'>0
QUIT
SET RC=RECD
SET TYPE=$PIECE($GET(^PSX(550,SYSTEM,1,RC,0)),U,1)
if TYPE'=OLDDTTM
QUIT
SET DA(1)=SYSTEM
SET DA=RC
SET DIE="^PSX(550,"_SYSTEM_",1,"
SET DR="2////"_DTTM_";3////N"
DO ^DIE
KILL DIE,DA,DR,X
+11 LOCK -^PSX(550,SYSTEM)
End DoDot:1
+12 KILL RECD,RC
+13 SET SYS=$PIECE($GET(^PSX(550,SYSTEM,0)),U,1)
+14 DO GRP^PSXNOTE
+15 SET XQAMSG=$SELECT(STAT="A":"Permission to transmit to "_SYS_" has been received.",STAT="I":"Permission to transmit to "_SYS_" has been denied.",1:"")
DO GRP1^PSXNOTE
DO SETUP^XQALERT
+16 SET Y=DTTM
XECUTE ^DD("DD")
SET DTTM=Y
+17 SET XMZ=$GET(TXMZ)
SET XMSER="S.PSXX CMOP SERVER"
if $GET(XMZ)>0
DO REMSBMSG^XMA1C
KILL XMZ,XMSER
+18 if $GET(STAT)="D"
QUIT
MSG SET XMSUB=($SELECT(STAT="A":"CMOP Activation Approved",STAT="I":"CMOP Activation Disapproved",1:""))
SET LCNT=6
SET XMDUZ=.5
+1 DO XMZ^XMA2
if XMZ<1
GOTO MSG
+2 SET ^XMB(3.9,XMZ,2,1,0)="Request to activate CMOP processing."
+3 SET ^XMB(3.9,XMZ,2,2,0)=""
+4 SET ^XMB(3.9,XMZ,2,3,0)="CMOP : "_SYS
+5 SET ^XMB(3.9,XMZ,2,4,0)="Approving Official: "_$PIECE(NAME,",",2)_" "_$PIECE(NAME,",",1)
+6 SET ^XMB(3.9,XMZ,2,5,0)="Action Date/Time : "_$PIECE(DTTM,":",1,2)
+7 SET ^XMB(3.9,XMZ,2,6,0)="Action : "_$SELECT(STAT="A":"Approved",STAT="I":"Disapproved",1:"")
+8 SET ^XMB(3.9,XMZ,2,0)="^3.92A^"_LCNT_U_LCNT_U_DT
SET XMDUN="CMOP MANAGER"
+9 KILL XMY
SET XMDUZ=.5
+10 DO GRP^PSXNOTE
DO ENT1^XMD
+11 QUIT