[613] | 1 | RCRCSRV ;ALB/CMS - RC SERVER DRIVER ; 16-JUN-00
|
---|
| 2 | V ;;4.5;Accounts Receivable;**61,87,63,147,159**;Mar 20, 1995
|
---|
| 3 | ;;Per VHA Directive 10-93-142, this routine should not be modified.
|
---|
| 4 | SERVER ;RC RC SERV SERVER OPTION MAIN ENTRY POINT
|
---|
| 5 | ;INPUT : Mailman variables
|
---|
| 6 | ;OUTPUT : Sets the XTMP global for certain types of message
|
---|
| 7 | ; : Sets the task job in the background if appropriate
|
---|
| 8 | ; : Adds Confirmation or Error to AR Transmission File
|
---|
| 9 | ;
|
---|
| 10 | Q:$G(XMZ)="" Q:'$D(^XMB(3.9,XMZ))
|
---|
| 11 | S XMXX="S.RC RC SERV",XMCHAN=1
|
---|
| 12 | D SETSB^XMA1C ;Save message in postmaster server basket
|
---|
| 13 | N RCBDT,RCCMSG,RCDOM,RCEDT,RCJOB,RCSCE,RCSTA,RCTYP,RCVAR,RCSITE,RCXMY,RCXMZ,RCXTYP
|
---|
| 14 | S RCXMZ=XMZ,RCJOB=$J
|
---|
| 15 | D READ
|
---|
| 16 | D SEND
|
---|
| 17 | D TASK
|
---|
| 18 | S XMZ=RCXMZ,XMSER="S.RC RC SERV" D REMSBMSG^XMA1C
|
---|
| 19 | K XMCHAN,XMDUZ,XMDUN,XMFROM,XMREC,XMSER,XMXX,XMY,XMZ
|
---|
| 20 | Q Q
|
---|
| 21 | ;
|
---|
| 22 | READ ;READ TRANSMISSION CHK FIRST LINE PUT MESSAGE IN XTMP
|
---|
| 23 | N II,RCEND,RCNT,XMRG,XMER,X2
|
---|
| 24 | S RCNT=0,RCCMSG="",RCSITE=$$SITE^RCMSITE,RCDOM=$G(XMFROM)
|
---|
| 25 | F II=0:0 D Q:$G(RCCMSG)]""
|
---|
| 26 | .X XMREC S RCNT=RCNT+1
|
---|
| 27 | .I $G(XMER)<0 D Q
|
---|
| 28 | ..I $G(RCEND)="" S RCCMSG="E;Incomplete message from Regional Counsel"
|
---|
| 29 | ..E S RCCMSG="C;AR accepted "_RCNT_" lines successfully."
|
---|
| 30 | ..S RCBDT=$P($G(RCEND),"$",4),RCEDT=$P($G(RCEND),"$",5)
|
---|
| 31 | ..; I +$P(RCVAR,U,5),$D(^XTMP(RCXTYP,RCJOB,0)) S $P(^XTMP(RCXTYP,RCJOB,0),"^",5)=RCNT
|
---|
| 32 | .I RCNT=1 D CHK1 I $G(RCCMSG)]"" Q
|
---|
| 33 | .I ($P(XMRG,"$",2)="END")!($P(XMRG,"$",3)="END") S RCEND=XMRG S RCNT=RCNT-1 Q
|
---|
| 34 | .I '$L(XMRG) S RCNT=RCNT-1 Q
|
---|
| 35 | .I +$P(RCVAR,U,5) S ^XTMP(RCXTYP,RCXMZ,RCNT)=XMRG
|
---|
| 36 | Q
|
---|
| 37 | ;
|
---|
| 38 | SEND ;CONFIRMATION, ERROR, ORIGINAL MESSAGE TRANSPORT
|
---|
| 39 | ;I message is the original send confirmation or error to RC
|
---|
| 40 | ;INPUT: RCCMSG from Read module always set
|
---|
| 41 | ; RCVAR if exists
|
---|
| 42 | ;I message is a Confirmation or Error from RC to site quit
|
---|
| 43 | I $P(RCCMSG,";",1)="Q" G SENDQ
|
---|
| 44 | S RETRY=0
|
---|
| 45 | ;
|
---|
| 46 | XMB N LN,RCCOM,RCSUB,RCWHO,RETRY,XMDUZ,XMSUB,XMTEXT,XMY,X,Y
|
---|
| 47 | ;Line below may not be needed
|
---|
| 48 | ;I confirmation don't send to anyone.
|
---|
| 49 | I $G(RCDOM)="" S RCDOM=$$RCDOM^RCRCUTL
|
---|
| 50 | S:$G(XMFROM)]"" XMY(XMFROM)=""
|
---|
| 51 | ;S RCWHO="S.RC RC SERV@"_RCDOM,XMY(RCWHO)=""
|
---|
| 52 | S RCWHO=RCDOM,XMY(RCWHO)=""
|
---|
| 53 | S Y=DT D D^DIQ
|
---|
| 54 | S LN(1)="$$RC$"_$G(RCTYP,"UNK")_"$"_$E(RCCMSG,1)_"$"_$G(RCSITE,"UNK")_"$"
|
---|
| 55 | S LN(2)="Status: Mail Message #("_XMZ_") received at the VAMC "_$G(RCSITE,"UNK")_" system on "_Y
|
---|
| 56 | S LN(3)=$S($E(RCCMSG,1)="E":"Error ",1:"")_"Message: "_$P(RCCMSG,";",2)
|
---|
| 57 | S LN(4)="Desc.: "_$P($G(RCVAR),U,4)
|
---|
| 58 | S (RCSUB,XMSUB)="AR/RC - "_$G(RCSITE,"UNK")_" "_$S($E(RCCMSG,1)="C":"CONFIRMATION ("_$G(RCTYP,"UNK")_")",1:"TRANSMISSION ("_$G(RCTYP,"UNK")_") ERROR")_" MESSAGE"
|
---|
| 59 | S XMTEXT="LN(",XMDUZ="ACCOUNTS RECEIVABLE RC SERVER"
|
---|
| 60 | D ^XMD I XMZ<1 S RETRY=RETRY+1 I RETRY<100 G XMB
|
---|
| 61 | S RCCOM=LN(3)
|
---|
| 62 | D ENT^RCRCXMS(XMZ,RCSUB,RCWHO,RCCOM)
|
---|
| 63 | SENDQ Q
|
---|
| 64 | ;
|
---|
| 65 | CHK1 ;CHECK FIRST LINE OF TRANSMISSION
|
---|
| 66 | ;First Line Syntax:
|
---|
| 67 | ;$$RC$S1$$sta#prefix$RC Address
|
---|
| 68 | ; o first four characters must be $$RC$
|
---|
| 69 | ; o $ piece 4 required must be a server code in routine RCRCVAR
|
---|
| 70 | ; o $ piece 5 will be "C" for a confirmation message or
|
---|
| 71 | ; "E" for error receiving the message
|
---|
| 72 | ; "" for the original transmission of a message
|
---|
| 73 | ; o $ piece 6 station number
|
---|
| 74 | ; o $ piece 7 is the RC address to send back to at RCDOM
|
---|
| 75 | ;Last Line Syntax: $END$#oflines$
|
---|
| 76 | ; $END$#oflines$Beg.Ref.DT$End.Ref.DT (Rec Rept. 4 of 4)
|
---|
| 77 | ; - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
---|
| 78 | ;INPUT: XMRG - First line of mail message
|
---|
| 79 | ;OUTPUT: RCVAR - Server Code^(C,E,O)^Recipient^desc.^0or1^taskroutine
|
---|
| 80 | ; or Killed
|
---|
| 81 | ; RCCMSG - Error message
|
---|
| 82 | ; RCSTA - Station Number
|
---|
| 83 | ; RCXMY - send message to
|
---|
| 84 | ; RCJOB - $J
|
---|
| 85 | ;
|
---|
| 86 | I $E(XMRG,1,5)'="$$RC$" S RCCMSG="E;RC Server at site is unable to interpret the first line of this message." G CHK1Q
|
---|
| 87 | S RCSCE=$P(XMRG,"$",5) S RCSCE=$S(RCSCE="C":RCSCE,RCSCE="E":RCSCE,RCSCE="":"O",1:"UNK")
|
---|
| 88 | S RCTYP=$P(XMRG,"$",4),RCVAR=$$CHK^RCRCVAR(RCTYP,RCSCE)
|
---|
| 89 | I $P(RCVAR,";",1)="E" S RCCMSG=RCVAR K RCVAR G CHK1Q
|
---|
| 90 | S RCSTA=$P(XMRG,"$",6)
|
---|
| 91 | S RCXMY=$P(XMRG,"$",7)
|
---|
| 92 | S RCDOM=$G(XMFROM)
|
---|
| 93 | ; If original message needs an XTMP global initialize it
|
---|
| 94 | I +$P(RCVAR,U,5) D XTMP(RCTYP,$P(RCVAR,U,4))
|
---|
| 95 | D FILE
|
---|
| 96 | I "CE"[RCSCE S RCCMSG="Q;"
|
---|
| 97 | CHK1Q Q
|
---|
| 98 | ;
|
---|
| 99 | TASK ;If message is original fire off the background job
|
---|
| 100 | ;fire off the background task now. (The time the server is run.)
|
---|
| 101 | I $G(RCSCE)="O",$E($G(RCCMSG),1)'="E" D TASK^RCRCRR
|
---|
| 102 | TASKQ Q
|
---|
| 103 | ;
|
---|
| 104 | FILE ;Update AR Transmission File
|
---|
| 105 | N DA,DIE,DR,RCCOM,RCX,X,Y
|
---|
| 106 | I RCSCE="O" D G FILEQ
|
---|
| 107 | . S RCSUB=$$SUBGET^XMGAPI0(RCXMZ)
|
---|
| 108 | . S RCCOM="RC sent Request Action ("_RCTYP_")."
|
---|
| 109 | . D ENT^RCRCXMS(RCXMZ,$G(RCSUB),"RC SERVER AT "_RCSTA,RCCOM)
|
---|
| 110 | ;If Message is a Confirm or Error from RC
|
---|
| 111 | X XMREC S RCNT=RCNT+1 I XMRG'["STATUS:" G FILEQ
|
---|
| 112 | S RCX=+$P(XMRG,"Message ",2)
|
---|
| 113 | S DA=$O(^RCT(349.3,"B",RCX,0))
|
---|
| 114 | I DA S DIE="^RCT(349.3,",DR=$S(RCSCE="E":6,1:5)_"////^S X="_RCXMZ D ^DIE
|
---|
| 115 | I 'DA,RCSCE="E" D
|
---|
| 116 | . S RCSUB=$$SUBGET^XMGAPI0(RCXMZ)
|
---|
| 117 | . S RCCOM="RC sent Error message ("_RCTYP_")."
|
---|
| 118 | . D ENT^RCRCXMS(RCXMZ,$G(RCSUB),"RC SERVER AT "_RCSTA,RCCOM)
|
---|
| 119 | FILEQ Q
|
---|
| 120 | ;
|
---|
| 121 | XTMP(RCTYP,RCDSC) ;INITIALIZE TOP XTMP Global for Server Type
|
---|
| 122 | ;INPUT : Type of server message must be passed
|
---|
| 123 | ;OUTPUT: XTMP global gets created for this server type
|
---|
| 124 | ; : RCXTYP gets set to PRCA_rctype(MR1,RR1,TR,CL...)
|
---|
| 125 | ; : RCJOB Job Number
|
---|
| 126 | ;XTMP purge data will be 30 days past the create date
|
---|
| 127 | N RCDT,X,X1,X2,Y,%,%H,%I
|
---|
| 128 | D NOW^%DTC S (X1,RCDT)=X,X2=30 D C^%DTC
|
---|
| 129 | S RCXTYP="PRCA"_RCTYP K ^XTMP(RCXTYP,RCXMZ)
|
---|
| 130 | S ^XTMP(RCXTYP,RCXMZ,0)=X_"^"_RCDT_"^"_RCDSC_U_RCXMZ
|
---|
| 131 | Q
|
---|
| 132 | ;RCRCSRV
|
---|