Home   Package List   Routine Alphabetical List   Global Alphabetical List   FileMan Files List   FileMan Sub-Files List   Package Component Lists   Package-Namespace Mapping  
Routine: HLOSRVR2

HLOSRVR2.m

Go to the documentation of this file.
  1. HLOSRVR2 ;ALB/CJM-HL7 - Sends an application ack over an open connection, for original mode ;02/04/2004
  1. ;;1.6;HEALTH LEVEL SEVEN;**131**;Oct 13, 1995;Build 10
  1. ;
  1. NEWMSG(HLCSTATE,HLMSTATE,HDR) ;
  1. ;initialize the HLMSTATE array after reading the header
  1. ;Inputs:
  1. ; HLCSTATE (pass by reference)
  1. ; HDR (pass by reference) parsed header
  1. ;Output:
  1. ; HLMSTATE (pass by reference)
  1. ;
  1. K HLMSTATE
  1. S HLMSTATE("IEN")=""
  1. S HLMSTATE("BODY")=""
  1. S HLMSTATE("DIRECTION")="IN"
  1. S HLMSTATE("CURRENT SEGMENT")=0 ;no segments in cache
  1. S HLMSTATE("UNSTORED LINES")=1 ;just the header in cache so far
  1. S HLMSTATE("LINE COUNT")=0 ;no lines within message stored to disk
  1. I HDR("SEGMENT TYPE")="BHS" D
  1. .S HLMSTATE("BATCH")=1
  1. .S HLMSTATE("ID")=HDR("BATCH CONTROL ID")
  1. .S HLMSTATE("BATCH","CURRENT MESSAGE")=0 ;no messages in batch
  1. .S HLMSTATE("UNSTORED MSH")=0
  1. E D
  1. .S HLMSTATE("BATCH")=0
  1. .S HLMSTATE("ID")=HDR("MESSAGE CONTROL ID")
  1. M HLMSTATE("HDR")=HDR
  1. M HLMSTATE("SYSTEM")=HLCSTATE("SYSTEM")
  1. S HLMSTATE("STATUS")=""
  1. S HLMSTATE("STATUS","QUEUE")=""
  1. S HLMSTATE("STATUS","ACTION")=""
  1. S HLMSTATE("STATUS","LINK NAME")=HLCSTATE("LINK","NAME")
  1. S HLMSTATE("STATUS","PORT")=$P(HDR("SENDING FACILITY",2),":",2)
  1. ;
  1. ;if this is a batch, and it references another batch, assume it is a b.
  1. I HLMSTATE("BATCH"),HLMSTATE("ID")]"" D
  1. .N IEN
  1. .S HLMSTATE("ACK TO")=HLMSTATE("ID")
  1. .S HLMSTATE("ACK TO","STATUS")="SU"
  1. .S IEN=$O(^HLB("B",HLMSTATE("ID"),0))
  1. .I IEN S HLMSTATE("ACK TO","IEN")=IEN_"^"
  1. E S HLMSTATE("ACK TO")=""
  1. I 'HLMSTATE("BATCH"),HDR("ACCEPT ACK TYPE")="",HDR("APP ACK TYPE")="" D
  1. .S HLMSTATE("ORIGINAL MODE")=1
  1. E D
  1. .S HLMSTATE("ORIGINAL MODE")=0
  1. N I F I=1,3 S HLMSTATE("MSA",I)=""
  1. S HLMSTATE("MSA",2)=HLMSTATE("ID")
  1. Q
  1. ;
  1. ACKNOW(MSG,ERROR) ;
  1. ;Sends the messge immediately if there is an open connection, otherwise
  1. ;will return an error.
  1. ;
  1. N $ETRAP,$ESTACK S $ETRAP="G ERROR^HLOSRVR2"
  1. N SENT
  1. S SENT=0,ERROR=""
  1. I '$G(HLCSTATE("CONNECTED")) D
  1. .S ERROR="NOT CONNECTED"
  1. .S MSG("STATUS")="TF"
  1. E S MSG("STATUS")="SU"
  1. S:'$G(MSG("DT/TM CREATED")) MSG("DT/TM CREATED")=$$NOW^XLFDT
  1. S MSG("STATUS","PURGE")=$$FMADD^XLFDT(MSG("DT/TM CREATED"),$S($G(HLCSTATE("ERROR PURGE")):HLCSTATE("ERROR PURGE"),1:7))
  1. D
  1. .I $G(MSG("UNSTORED LINES")),'$$SAVEMSG^HLOF777(.MSG) S ERROR="$$SAVE^HLOF777 FAILED!" Q
  1. .I '$$SAVEMSG^HLOF778(.MSG) S ERROR="$$SAVE^HLOF778 FAILED!" Q
  1. .Q:MSG("STATUS")'="SU"
  1. .I '$$WRITEMSG^HLOCLNT1(.HLCSTATE,.MSG) S ERROR="TRANSMISSION FAILURE" Q
  1. .S SENT=1
  1. .D COUNT^HLOSTAT(.HLCSTATE,ACK("HDR","RECEIVING APPLICATION"),ACK("HDR","SENDING APPLICATION"),ACK("HDR","MESSAGE TYPE")_"~"_ACK("HDR","EVENT"))
  1. ;
  1. END ;
  1. I 'SENT,MSG("STATUS")="SU",$G(MSG("IEN")) D
  1. .Q:'$D(^HLB(MSG("IEN"),0))
  1. .S MSG("STATUS")="TF"
  1. .S MSG("STATUS","ERROR TEXT")=ERROR
  1. .S $P(^HLB(MSG("IEN"),0),"^",20)=MSG("STATUS")
  1. .S $P(^HLB(MSG("IEN"),0),"^",21)=MSG("STATUS","ERROR TEXT")
  1. .S ^HLB("ERRORS","TF",$S($L($G(MSG("HDR","RECEIVING APPLICATION"))):MSG("HDR","RECEIVING APPLICATION"),1:"UNKNOWN"),MSG("DT/TM CREATED"),IEN)=""
  1. ;
  1. Q SENT
  1. ;
  1. ERROR ;error trap for ACKNOW
  1. S SENT=0,ERROR="TRANSMISSION FAILURE:"_$P($ECODE,",",1,2)
  1. S $ETRAP="D UNWIND^%ZTER"
  1. ;
  1. ;don't log some common errors
  1. I ($ECODE["READ")!($ECODE["NOTOPEN")!($ECODE["DEVNOTOPN")!($ECODE["WRITE")!($ECODE["OPENERR") D
  1. .;nothing!
  1. E D
  1. .D ^%ZTER
  1. G END^HLOSRVR2
  1. Q