PSXSTRT ;BIR/BAB-Start Interface ;[ 03/10/99 11:08 AM ]
;;2.0;CMOP;**17**;11 Apr 97
START ;Start here when queued
S:'$D(^PSX(553,1,"X",0)) ^PSX(553,1,"X",0)="^553.01DA^^"
S TERM=13,SOH=1,STX=2,ETB=23,ETX=3,EOT=4,ENQ=5,NAK=21,ACK=16
S PSXABORT=0,ZCNT=1 D NOW^%DTC S XCNT=% K %
D SETPAR,PURG G STRT^PSXJOB
SETPAR ;Set parameters (TIMERS,LINE BID,RETRIES)
S PSXPAR0=$G(^PSX(553,1,0)),PSXPART=$G(^PSX(553,1,"T"))
S PSXDLTA=$P(PSXPART,"^"),PSXDLTB=$P(PSXPART,"^",2)
S PSXDLTD=$P(PSXPART,"^",3),PSXDLTE=$P(PSXPART,"^",4)
S PSXTRYM=$P(PSXPAR0,"^",6),PSXTRYL=$P(PSXPAR0,"^",5)
S PSXVNDR=$S(^PSX(553,1,0)["MURF":1,^PSX(553,1,0)["HIN":2,^PSX(553,1,0)["CHAR":2,1:0)
Q
PURG ;Purge CMOP log file
S PSXPURG=0 F PSXCNT=1:1 S PSXPURG=$O(^PSX(553,1,"X",PSXPURG)) Q:'PSXPURG I PSXCNT>1000 S DA=PSXPURG,DA(1)=1,DIK="^PSX(553,"_DA(1)_",""X""," D ^DIK
K PSXCNT,PSXPURG,DA,DIK
Q
QUE ;Entry point to queue interface background job
I $P($G(^PSX(553,1,0)),"^")["LEAVENWORTH" G QUE^PSXYSTRT
K PSXONE
I $G(^PSX(553,1,"P"))="R" W !!,"INTERFACE CANNOT BE STARTED WHILE LABELS ARE PRINTING!......TRY LATER." Q
L +^PSX(553,1,"S"):30 I '$T W !!,"The CMOP Interface file is in use, try later." Q
I $P(^PSX(553,1,"S"),"^",1)="R" W !!,"INTERFACE is already RUNNING, or PURGE is in progress!" Q
;G ALL
ASK S DIR(0)="SM^A:All Transmissions Queued;S:Single Transmission;P:Prioritize Queue;Q:Query Request",DIR("??")="^D HELP^PSXSTRT",DIR("B")="A" D ^DIR K DIR G:$G(DTOUT)!($G(DUOUT)) EXIT G:"Aa"[X ALL G:"Pp"[X ^PSXQUE G:"Qq"[X QUERY
ONE K DIRUT,DUOUT,DTOUT,DIROUT,Y,X
S DIC(0)="AEOX",DIC("A")="Enter Transmission Number: ",DIC="^PSX(552.1,",DIC("S")="I $P(^PSX(552.1,+Y,0),U,4)>0&($P(^PSX(552.1,+Y,0),U,2)=""2""),($D(^PSX(552.1,""AQ"",$P(^PSX(552.1,+Y,0),U,4),X,+Y)))"
D ^DIC K DIC S TRAN=+Y,PSXONE=$G(X) I Y'>0!($D(DTOUT))!($D(DUOUT)) K PSXIN G EXIT
K DUOUT,DTOUT,Y
S DIR(0)="Y",DIR("A")="Download Transmission "_$G(X),DIR("B")="YES" D ^DIR K DIR I Y'>0!($G(DTOUT))!($D(DUOUT))!($D(DIROUT))!($D(DIRUT)) K PSXIN G EXIT
S ZTSAVE("PSXONE")=""
K DIR,DIRUT,DUOUT,DTOUT,DIROUT,Y,X,TRAN
ALL S ^PSX(553,1,"S")="R",PSXIN=1
L -^PSX(553,1,"S")
U IO(0) W !!,?10,"*** Interface STARTED ***"
S ZTIO="CMOP",ZTRTN="START^PSXSTRT",ZTDTH=$H,ZTREQ="@"
S ZTDESC="CMOP Interface"
D ^%ZTLOAD
EXIT K ACK,ENQ,EOT,ETB,ETX,NAK,PSXABORT,PSXDLTA,PSXDLTB,PSXDLTD,PSXDLTE,LOG,PSXTME,PSXTMOUT,PSXTRASH,TRAN,PSXONE,DIR,DIRUT,DUOUT,DTOUT,DIROUT,X,Y,WAIT,INT,XZ,%,LQRYTM,NEXT,WAIT
G:$G(PSXIN)>0 ^PSXHSYS
Q
QUERY D NOW^%DTC S XZ=$P(^PSX(553.1,0),"^",3),INT=$P(^PSX(553,1,0),"^",9) S:$G(INT)'>0 INT=1
I $G(XZ) S LQRYTM=$P(^PSX(553.1,XZ,0),"^",2) S NEXT=$$FMADD^XLFDT(LQRYTM,0,$G(INT),0,0) I %'>NEXT S WAIT=$$FMDIFF^XLFDT(NEXT,%,2) W !!,"Another query can not be initiated for ",($G(WAIT)\60)," minutes." G EXIT
S PSXQRY=1,ZTSAVE("PSXQRY")="",PSXQRYA=1,ZTSAVE("PSXQRYA")="" G ALL
Q
HELP W !,"A - All Transmissions Queued. Sends all transmissions in the queue to the",!,"vendor. The interface will NOT stop after all transmissions have been sent to",!,"the vendor system."
W !!,"S - Single Transmission. Only sends the transmission selected to the vendor.",!,"The interface will stop when the transmission download has completed."
W !!,"P - Prioritize Queue. Allows the user to establish a priority for sending",!,"transmissions to the vendor. The interface will NOT stop after all transmissions",!,"have been sent to the vendor."
W !!,"Q - Query Request. Allows the user to initiate a query request. Once the query",!,"request is complete the interface stops."
Q
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HPSXSTRT 3583 printed Dec 13, 2024@01:45:18 Page 2
PSXSTRT ;BIR/BAB-Start Interface ;[ 03/10/99 11:08 AM ]
+1 ;;2.0;CMOP;**17**;11 Apr 97
START ;Start here when queued
+1 if '$DATA(^PSX(553,1,"X",0))
SET ^PSX(553,1,"X",0)="^553.01DA^^"
+2 SET TERM=13
SET SOH=1
SET STX=2
SET ETB=23
SET ETX=3
SET EOT=4
SET ENQ=5
SET NAK=21
SET ACK=16
+3 SET PSXABORT=0
SET ZCNT=1
DO NOW^%DTC
SET XCNT=%
KILL %
+4 DO SETPAR
DO PURG
GOTO STRT^PSXJOB
SETPAR ;Set parameters (TIMERS,LINE BID,RETRIES)
+1 SET PSXPAR0=$GET(^PSX(553,1,0))
SET PSXPART=$GET(^PSX(553,1,"T"))
+2 SET PSXDLTA=$PIECE(PSXPART,"^")
SET PSXDLTB=$PIECE(PSXPART,"^",2)
+3 SET PSXDLTD=$PIECE(PSXPART,"^",3)
SET PSXDLTE=$PIECE(PSXPART,"^",4)
+4 SET PSXTRYM=$PIECE(PSXPAR0,"^",6)
SET PSXTRYL=$PIECE(PSXPAR0,"^",5)
+5 SET PSXVNDR=$SELECT(^PSX(553,1,0)["MURF":1,^PSX(553,1,0)["HIN":2,^PSX(553,1,0)["CHAR":2,1:0)
+6 QUIT
PURG ;Purge CMOP log file
+1 SET PSXPURG=0
FOR PSXCNT=1:1
SET PSXPURG=$ORDER(^PSX(553,1,"X",PSXPURG))
if 'PSXPURG
QUIT
IF PSXCNT>1000
SET DA=PSXPURG
SET DA(1)=1
SET DIK="^PSX(553,"_DA(1)_",""X"","
DO ^DIK
+2 KILL PSXCNT,PSXPURG,DA,DIK
+3 QUIT
QUE ;Entry point to queue interface background job
+1 IF $PIECE($GET(^PSX(553,1,0)),"^")["LEAVENWORTH"
GOTO QUE^PSXYSTRT
+2 KILL PSXONE
+3 IF $GET(^PSX(553,1,"P"))="R"
WRITE !!,"INTERFACE CANNOT BE STARTED WHILE LABELS ARE PRINTING!......TRY LATER."
QUIT
+4 LOCK +^PSX(553,1,"S"):30
IF '$TEST
WRITE !!,"The CMOP Interface file is in use, try later."
QUIT
+5 IF $PIECE(^PSX(553,1,"S"),"^",1)="R"
WRITE !!,"INTERFACE is already RUNNING, or PURGE is in progress!"
QUIT
+6 ;G ALL
ASK SET DIR(0)="SM^A:All Transmissions Queued;S:Single Transmission;P:Prioritize Queue;Q:Query Request"
SET DIR("??")="^D HELP^PSXSTRT"
SET DIR("B")="A"
DO ^DIR
KILL DIR
if $GET(DTOUT)!($GET(DUOUT))
GOTO EXIT
if "Aa"[X
GOTO ALL
if "Pp"[X
GOTO ^PSXQUE
if "Qq"[X
GOTO QUERY
ONE KILL DIRUT,DUOUT,DTOUT,DIROUT,Y,X
+1 SET DIC(0)="AEOX"
SET DIC("A")="Enter Transmission Number: "
SET DIC="^PSX(552.1,"
SET DIC("S")="I $P(^PSX(552.1,+Y,0),U,4)>0&($P(^PSX(552.1,+Y,0),U,2)=""2""),($D(^PSX(552.1,""AQ"",$P(^PSX(552.1,+Y,0),U,4),X,+Y)))"
+2 DO ^DIC
KILL DIC
SET TRAN=+Y
SET PSXONE=$GET(X)
IF Y'>0!($DATA(DTOUT))!($DATA(DUOUT))
KILL PSXIN
GOTO EXIT
+3 KILL DUOUT,DTOUT,Y
+4 SET DIR(0)="Y"
SET DIR("A")="Download Transmission "_$GET(X)
SET DIR("B")="YES"
DO ^DIR
KILL DIR
IF Y'>0!($GET(DTOUT))!($DATA(DUOUT))!($DATA(DIROUT))!($DATA(DIRUT))
KILL PSXIN
GOTO EXIT
+5 SET ZTSAVE("PSXONE")=""
+6 KILL DIR,DIRUT,DUOUT,DTOUT,DIROUT,Y,X,TRAN
ALL SET ^PSX(553,1,"S")="R"
SET PSXIN=1
+1 LOCK -^PSX(553,1,"S")
+2 USE IO(0)
WRITE !!,?10,"*** Interface STARTED ***"
+3 SET ZTIO="CMOP"
SET ZTRTN="START^PSXSTRT"
SET ZTDTH=$HOROLOG
SET ZTREQ="@"
+4 SET ZTDESC="CMOP Interface"
+5 DO ^%ZTLOAD
EXIT KILL ACK,ENQ,EOT,ETB,ETX,NAK,PSXABORT,PSXDLTA,PSXDLTB,PSXDLTD,PSXDLTE,LOG,PSXTME,PSXTMOUT,PSXTRASH,TRAN,PSXONE,DIR,DIRUT,DUOUT,DTOUT,DIROUT,X,Y,WAIT,INT,XZ,%,LQRYTM,NEXT,WAIT
+1 if $GET(PSXIN)>0
GOTO ^PSXHSYS
+2 QUIT
QUERY DO NOW^%DTC
SET XZ=$PIECE(^PSX(553.1,0),"^",3)
SET INT=$PIECE(^PSX(553,1,0),"^",9)
if $GET(INT)'>0
SET INT=1
+1 IF $GET(XZ)
SET LQRYTM=$PIECE(^PSX(553.1,XZ,0),"^",2)
SET NEXT=$$FMADD^XLFDT(LQRYTM,0,$GET(INT),0,0)
IF %'>NEXT
SET WAIT=$$FMDIFF^XLFDT(NEXT,%,2)
WRITE !!,"Another query can not be initiated for ",($GET(WAIT)\60)," minutes."
GOTO EXIT
+2 SET PSXQRY=1
SET ZTSAVE("PSXQRY")=""
SET PSXQRYA=1
SET ZTSAVE("PSXQRYA")=""
GOTO ALL
+3 QUIT
HELP WRITE !,"A - All Transmissions Queued. Sends all transmissions in the queue to the",!,"vendor. The interface will NOT stop after all transmissions have been sent to",!,"the vendor system."
+1 WRITE !!,"S - Single Transmission. Only sends the transmission selected to the vendor.",!,"The interface will stop when the transmission download has completed."
+2 WRITE !!,"P - Prioritize Queue. Allows the user to establish a priority for sending",!,"transmissions to the vendor. The interface will NOT stop after all transmissions",!,"have been sent to the vendor."
+3 WRITE !!,"Q - Query Request. Allows the user to initiate a query request. Once the query",!,"request is complete the interface stops."
+4 QUIT