[613] | 1 | HLTP31 ;SFIRMFO/RSD - Cont. Transaction Processor for TCP ;01/26/2006 15:50
|
---|
| 2 | ;;1.6;HEALTH LEVEL SEVEN;**57,58,66,109,120**;Oct 13, 1995;Build 12
|
---|
| 3 | ;
|
---|
| 4 | Q
|
---|
| 5 | RSP(X,HLN) ;process response msg. X=ien in 773^msg. ien in 772
|
---|
| 6 | ;HLN=HL array for original message
|
---|
| 7 | ;HLMTIEN=ien in 772, HLMTIENS=ien in 773
|
---|
| 8 | ;returns - 0=resend msg, 1=commit ack, 3=app ack success, 4=error
|
---|
| 9 | ;set error trap
|
---|
| 10 | N $ETRAP,$ESTACK S $ETRAP="D ERROR^HLTP3"
|
---|
| 11 | N HLERR,HLHDR,HLMSA,HLMTIEN,HLMTIENS,HLQUIT,HLNODE,HLNEXT,HLRESLTA
|
---|
| 12 | D INIT^HLTP3A ;patch HL*1.6*109: hltp3 routine split
|
---|
| 13 | ;Quit processing if error with header
|
---|
| 14 | I $G(HLRESLT) D EXIT Q 0
|
---|
| 15 | ;must have MSA segment
|
---|
| 16 | I '$L(HLMSA) D RSPER(4,108,"Missing MSA segment") Q 0
|
---|
| 17 | ;msg. id in MSA must match original msg. id, if not reject
|
---|
| 18 | I $P(HLMSA,HL("FS"),2)'=HLN("MID") D RSPER(4,108,"Incorrect msg. Id") Q 0
|
---|
| 19 | ;rec. app. must match sending app. of original message.
|
---|
| 20 | I HL("RAN")'=HLN("SAN") D RSPER(4,108,"Incorrect sending app.") Q 0
|
---|
| 21 | ;get ack code
|
---|
| 22 | S HL("ACKCD")=$P(HLMSA,HL("FS"))
|
---|
| 23 | ;update LL, rec. 1 msg
|
---|
| 24 | D LLCNT^HLCSTCP(HLDP,1)
|
---|
| 25 | ;commit ack
|
---|
| 26 | I $E(HL("ACKCD"))="C" D Q X
|
---|
| 27 | . ;update LL, processed 1 msg
|
---|
| 28 | . D LLCNT^HLCSTCP(HLDP,2)
|
---|
| 29 | . ;received an error ack, return NAK
|
---|
| 30 | . S:$E(HL("ACKCD"),2)'="A" HLRESLT=102_U_$P(HLMSA,HL("FS"),3)
|
---|
| 31 | . D RSPER(3) S X=$S($E(HL("ACKCD"),2)="A":1,1:4)
|
---|
| 32 | ;app. ack, received an error ack, NAK
|
---|
| 33 | S:$E(HL("ACKCD"),2)'="A" HLRESLT=102_U_$P(HLMSA,HL("FS"),3)
|
---|
| 34 | ;Set special HL variables
|
---|
| 35 | S HLQUIT=0,HLNODE="",HLNEXT="D HLNEXT^HLCSUTL"
|
---|
| 36 | ;HLORNOD=subscriber protocol for Fileman auditing, ien;global ref
|
---|
| 37 | N HLORNODD S HLORNOD=HL("EIDS")_";ORD(101,"
|
---|
| 38 | ;process ack
|
---|
| 39 | D
|
---|
| 40 | . N HLTCP ;Newed variable to update status in 772.
|
---|
| 41 | . D PROCACK^HLTP2(HLMTIEN,HL("EID"),.HLRESLT,.HL)
|
---|
| 42 | ;update LL, processed 1 msg
|
---|
| 43 | D LLCNT^HLCSTCP(HLDP,2)
|
---|
| 44 | ;process ack successfully
|
---|
| 45 | D RSPER(3)
|
---|
| 46 | ;HLRESELT is defined for errors
|
---|
| 47 | Q $S($G(HLRESLT):4,1:3)
|
---|
| 48 | ;
|
---|
| 49 | RSPER(HLST,HLER,HLERM) ;HLST=status, HLER=error type, HLERM=error msg.
|
---|
| 50 | D STATUS^HLTF0(HLMTIENS,HLST,$G(HLER),$G(HLERM),1)
|
---|
| 51 | S:$G(HLER) HLRESLT=HLER_U_HLERM
|
---|
| 52 | D EXIT
|
---|
| 53 | Q
|
---|
| 54 | EXIT ;unlock
|
---|
| 55 | ;**109**
|
---|
| 56 | ;I $G(HLMTIENS) L -^HLMA(HLMTIENS)
|
---|
| 57 | Q
|
---|
| 58 | ;
|
---|
| 59 | SETINQUE ;
|
---|
| 60 | ;**HL*1.6*109***
|
---|
| 61 | ;Called from HLTP3 for message that utilize enhanced mode - NOT original mode
|
---|
| 62 | ;Sets the incoming message on the in queue.
|
---|
| 63 | ;Does not use the listener, instead, arranges multiple in-queues
|
---|
| 64 | ;by using the sending link.
|
---|
| 65 | ;
|
---|
| 66 | N HLI,HLINST,HLDOMAIN,HLLINK
|
---|
| 67 | ;
|
---|
| 68 | ;Override value of logical link based on sending facility to create
|
---|
| 69 | ;a queue (^HLMA("AC","I",llnk ien,msg ien)) different than that of the
|
---|
| 70 | ;listener
|
---|
| 71 | S HLINST=$P(HL("SFN"),$E(HL("ECH")))
|
---|
| 72 | S HLDOMAIN=$P(HL("SFN"),$E(HL("ECH")),2)
|
---|
| 73 | ;
|
---|
| 74 | ; patch HL*1.6*120 start
|
---|
| 75 | ; assume the format is <domain>:<port #>
|
---|
| 76 | I HLDOMAIN[":" S HL("PORT")=$P(HLDOMAIN,":",2)
|
---|
| 77 | S HLDOMAIN=$P(HLDOMAIN,":")
|
---|
| 78 | S HL("DOMAIN")=HLDOMAIN
|
---|
| 79 | ; change from lower case to upper case
|
---|
| 80 | S HLDOMAIN=$$UP^XLFSTR(HLDOMAIN)
|
---|
| 81 | ; if first piece of domain is "HL7." or "MPI.", remove it
|
---|
| 82 | I ($E(HLDOMAIN,1,4)="HL7.")!($E(HLDOMAIN,1,4)="MPI.") D
|
---|
| 83 | . S HLDOMAIN=$P(HLDOMAIN,".",2,99)
|
---|
| 84 | ; patch HL*1.6*120 end
|
---|
| 85 | ;
|
---|
| 86 | I HLDOMAIN]"" D ;logical link lookup by domain
|
---|
| 87 | . D LINK^HLUTIL3(HLDOMAIN,.HLI,"D")
|
---|
| 88 | . S HLLINK=$O(HLI(0)) ;client link for sending facility
|
---|
| 89 | ;logical link lookup by station number
|
---|
| 90 | I $G(HLLINK)']"",HLINST]"" D
|
---|
| 91 | . D LINK^HLUTIL3(HLINST,.HLI,"I")
|
---|
| 92 | . S HLLINK=$O(HLI(0)) ;client link for sending facility
|
---|
| 93 | ;
|
---|
| 94 | ; patch HL*1.6*120 start
|
---|
| 95 | ;logical link lookup by DNS domain
|
---|
| 96 | I $G(HLLINK)']"",HL("DOMAIN")]"" D
|
---|
| 97 | . I $D(^HLCS(870,"DNS",HL("DOMAIN"))) D Q
|
---|
| 98 | .. S HLLINK=+$O(^HLCS(870,"DNS",HL("DOMAIN"),0))
|
---|
| 99 | . I $D(^HLCS(870,"DNS",$$UP^XLFSTR(HL("DOMAIN")))) D Q
|
---|
| 100 | .. S HLLINK=+$O(^HLCS(870,"DNS",$$UP^XLFSTR(HL("DOMAIN")),0))
|
---|
| 101 | . I $D(^HLCS(870,"DNS",$$LOW^XLFSTR(HL("DOMAIN")))) D
|
---|
| 102 | .. S HLLINK=+$O(^HLCS(870,"DNS",$$LOW^XLFSTR(HL("DOMAIN")),0))
|
---|
| 103 | ;
|
---|
| 104 | ;logical link lookup by ip address
|
---|
| 105 | I $G(HLLINK)']"",HL("DOMAIN") D
|
---|
| 106 | . S HLLINK=$O(^HLCS(870,"IP",HL("DOMAIN"),0))
|
---|
| 107 | ; patch HL*1.6*120 end
|
---|
| 108 | ;
|
---|
| 109 | ; find the logical link of the subscriber protocol
|
---|
| 110 | ; then set the link field of this message to the link
|
---|
| 111 | I $G(HL("EIDS")),$P(^ORD(101,HL("EIDS"),770),"^",7) S HLLINK=$P(^ORD(101,HL("EIDS"),770),"^",7)
|
---|
| 112 | ;
|
---|
| 113 | I $L($G(HLLINK)) D
|
---|
| 114 | .D ENQUE^HLCSREP(HLLINK,"I",HLMTIENS)
|
---|
| 115 | E D
|
---|
| 116 | .D ENQUE^HLCSREP(HLDP,"I",HLMTIENS)
|
---|
| 117 | Q
|
---|