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

HLCSMM.m

Go to the documentation of this file.
HLCSMM ;ISC/MTC-Create Mail Message and Entry in the HL7 Transmission File ;11/03/2000  08:53
 ;;1.6;HEALTH LEVEL SEVEN;**17,35,57,66,68**;Oct 13, 1995
 Q
 ;
EN(HLD0,HLD1) ; This routine will send a Message from the Out Queue to the
 ; MailGroup Specified in the Logical Link file (#870). It is called
 ; from HLCSMM1 routine that monitors the queue for a link. The MM LLP
 ; uses <CR> stuffing to indicate the end of segments. The message
 ; will use the following format within the XMB global.
 ;  ^XMB(3.9,..1)=Segment 1
 ;  ^XMB(3.9,..2)=""  - End of segment 1
 ;  ^XMB(3.9,..3)=Segment 2
 ;  ^XMB(3.9,..4)=Continuation of segment 2
 ;  ^XMB(3.9,..5)=""  - End of segment 2
 ; "             "
 ; This processing will enable segment greater than 245.
 ;
 ; INPUT :  HLD0 - IEN of Logical Link file (#870)
 ;       :  HLD1 - IEN of OutQueue Mutiple (Message)
 ;
 ; OUTPUT:  NONE
 ;
 N HLI,HLI0,HLSERV,HLFAC,HLERR,HLOGLINK,HLMSTXT,HLPARENT,HLPTXT,HLPARM
 ;
 S HLOGLINK=$G(^HLCS(870,HLD0,0))
 ;-- get MailMan LLP parameters
 S HLPARM=$G(^HLCS(870,HLD0,100))
 ;-- facility
 S HLFAC=$P($$SITE^VASITE,"^",2)
 I HLFAC="" S HLFAC="Unknown"
 ;-- date
 D NOW^%DTC S Y=% X ^DD("DD") S HLDT=Y
 ;-- logical link name
 S HLDAN=$P(HLOGLINK,U)
 ;
 ;-- Build MailMan variables
 ;
NEWMM ;Patch 66-introduce new Mailman API's
 N XMSUB,XMTO,XMINSTR
 I '$G(DUZ) N DUZ D DUZ^XUP(.5)
 S XMSUB="HL7 Msg "_HLDT_" from "_HLFAC,XMSUB=$E(XMSUB,1,65)
 S XMTO="G."_$P(^XMB(3.8,$P(HLPARM,U),0),U)
 S XMINSTR("FROM")=.5
 S XMINSTR("ADDR FLAGS")="R" ; Ignore any restrictions (domain closed or protected by security key)
 D SENDMSG^XMXAPI(DUZ,XMSUB,"^HLCS(870,HLD0,2,HLD1,1)",XMTO,.XMINSTR)
 ;-- Set message status to 'done'
 S $P(^HLCS(870,HLD0,2,HLD1,0),"^",2)="D"
 I $G(XMERR) D ERROR
 Q 
ERROR ;-- send Mail Message indicating error
 Q:'$G(XMERR)
 Q:'$D(^TMP("XMERR",$J))
 N HLX,HLY,HLZ,HLPARAM,XMSUB,XMTO,XMINSTR
 N DUZ D DUZ^XUP(.5) ; Want to make sure this message is sent.  It won't be if DUZ is not a valid user.
 K ^TMP($J,"HLERR")
 S HLNXST="ERROR" D STATUS^HLCSMM1(HLNXST) H 1
 S HLPARAM=$$PARAM^HLCS2,XMTO("G."_$P(HLPARAM,U,8))="",XMTO(.5)=""
 S (HLX,HLZ)=0
 F  S HLX=$O(^TMP("XMERR",$J,HLX)) Q:'HLX  D
 . S HLZ=HLZ+1,^TMP($J,"HLERR",HLZ)=""
 . S HLY=0
 . F  S HLY=$O(^TMP("XMERR",$J,HLX,"TEXT",HLY)) Q:'HLY  D
 . . S HLZ=HLZ+1,^TMP($J,"HLERR",HLZ)=$G(^TMP("XMERR",$J,HLX,"TEXT",HLY))
 . I $D(^TMP("XMERR",$J,HLX,"PARAM","VALUE")) S HLZ=HLZ+1,^TMP($J,"HLERR",HLZ)=^TMP("XMERR",$J,HLX,"PARAM","VALUE")
 S HLZ=HLZ+1,^TMP($J,"HLERR",HLZ)=""
 S HLZ=HLZ+1,^TMP($J,"HLERR",HLZ)="HL7 Logical Link: "_$G(HLDAN)
 S XMSUB="Error handing HL7 message off to Mailman"
 S XMINSTR("FROM")="POSTMASTER" ; msg will appear new, nomatter who receives it.
 D SENDMSG^XMXAPI(DUZ,XMSUB,"^TMP($J,""HLERR"")",.XMTO,.XMINSTR)
 K ^TMP($J,"HLERR"),XMERR,^TMP("XMERR",$J)
 Q