1 | DGRUDYN ;ALB/SCK - RAI/MDS COTS DYNAMIC ADDRESSING ROUTINE; 9-2-99 ; 6/23/03 3:25pm
|
---|
2 | ;;5.3;Registration;**190,328,354,357,473,501**;Aug 13, 1993
|
---|
3 | ;
|
---|
4 | EN(EVENT) ;
|
---|
5 | ;
|
---|
6 | ; Input CLIENT - HL7 Client protocol
|
---|
7 | ; DGWARD - Ward location [Optional]
|
---|
8 | ;
|
---|
9 | N DGENTRY,DGDIV,DGSCN,DGSITE,HLNODE,DGSTN,DGWARD,DGIEN,DGFAC,CLIENT
|
---|
10 | ;
|
---|
11 | Q:$G(EVENT)']""
|
---|
12 | ;
|
---|
13 | ; Extract HL7 message to local array for processing
|
---|
14 | N I,J,X
|
---|
15 | F I=1:1 X HLNEXT Q:HLQUIT'>0 D
|
---|
16 | . S X(I)=HLNODE,J=0
|
---|
17 | . F S J=$O(HLNODE(J)) Q:'J S X(I,J)=HLNODE(J)
|
---|
18 | ;
|
---|
19 | ; Look for PV1 segment. If A03 or A21, get previous ward, otherwise get current ward location.
|
---|
20 | S I=0
|
---|
21 | F S I=$O(X(I)) Q:'I D
|
---|
22 | . I $P(X(I),"^",1)="PV1" D
|
---|
23 | . . I "A03"[EVENT S DGWARD=$$WARD(X(I),7)
|
---|
24 | . . I "A11"[EVENT S DGWARD=$$WARD(X(I),7) ; Retrieve ward prior toadmission cancellation
|
---|
25 | . . I "A21"[EVENT S DGWARD=$$WARD(X(I),7)
|
---|
26 | . . I '$G(DGWARD) S DGWARD=$$WARD(X(I),4)
|
---|
27 | ;
|
---|
28 | ; Get division for ward
|
---|
29 | S DGDIV=+$$GET1^DIQ(42,DGWARD,.015,"I")
|
---|
30 | ;
|
---|
31 | ; Retrieve subscription control number for division
|
---|
32 | S DGSCN=+$$GET1^DIQ(40.8,DGDIV,900.01)
|
---|
33 | ;
|
---|
34 | ;set HLL("LINKS") array
|
---|
35 | K HLL ;added p-357
|
---|
36 | D GET^HLSUB(DGSCN,2,"",.HLL) ;added p-357
|
---|
37 | ;
|
---|
38 | ; Set client protocol for destination
|
---|
39 | S DGSTN=$$SITE^VASITE($$NOW^XLFDT,DGDIV)
|
---|
40 | ; S DGAPIEN=$P(HLL("LINKS",1),"^",4) ;changed p-357, disabled p-501
|
---|
41 | S DGAPIEN=$$GET1^DIQ(771,$P(HLL("LINKS",1),"^",4),.01) ; added p-501
|
---|
42 | S DGFAC=$$GET1^DIQ(771,$P(HLL("LINKS",1),"^",4),3) ; added p-501
|
---|
43 | ; S CLIENT="DGRU-RAI-"_EVENT_"-"_DGAPIEN ;changed p-357,disabled p501
|
---|
44 | S CLIENT="DGRU-RAI-"_EVENT ; added p-501
|
---|
45 | S $P(HLL("LINKS",1),"^",1)=CLIENT ;changed p-357
|
---|
46 | S HLP("SUBSCRIBER")="^^^"_DGAPIEN_"^"_DGFAC ; added p-501
|
---|
47 | Q
|
---|
48 | ;
|
---|
49 | WARD(DGPV1,DGP) ; Retrieve Ward IEN for Division lookup. If the ward has been
|
---|
50 | ; "translated", then return the original Ward IEN.
|
---|
51 | ; Input
|
---|
52 | ; DGPV1 - Copy of the PV1 segment
|
---|
53 | ; DGP - Piece containing the ward to be checked
|
---|
54 | ;
|
---|
55 | N DGW,DGN,Y,DIC,DGIEN,DGX
|
---|
56 | ;
|
---|
57 | S DGW=$P(DGPV1,"^",DGP),DGN=$P(DGW,"~",1)
|
---|
58 | S DGIEN=$$FIND1^DIC(42,"","BX",DGN,"","","DGERR")
|
---|
59 | ;
|
---|
60 | ; If the Lookup is unable to find a valid ward location, then check to see if this
|
---|
61 | ; is a translated ward name. If it is, then return original ward ien
|
---|
62 | I DGIEN<1 D
|
---|
63 | . S DGX=$$FIND1^DIC(46.12,"","",DGN,"AC")
|
---|
64 | . I DGX>0 S DGIEN=+$G(^DGRU(46.12,DGX,0)) ;p-473
|
---|
65 | . E D ;p-473
|
---|
66 | .. S DGX=$O(^DGRU(46.12,"AC",DGN,0)) ;p-473
|
---|
67 | .. I DGX>0 S DGIEN=+$G(^DGRU(46.12,DGX,0)) ;p-473
|
---|
68 | Q DGIEN
|
---|
69 | ;
|
---|
70 | ENMFU(DGEVENT,DGDIV) ;ENTRY POINT FOR MASTER FILE UPDATE ROUTING
|
---|
71 | ;
|
---|
72 | N DGAPIEN,DGFAC,CLIENT
|
---|
73 | S DGSCN=$$GET1^DIQ(40.8,DGDIV,900.01) ;Retrieve the Subscription Control Number for the division
|
---|
74 | Q:DGSCN']"" ;Quit if division does not have a Subscription Control Number
|
---|
75 | S DGSTN=$$SITE^VASITE($$NOW^XLFDT,DGDIV) ;Retrieve station info for division
|
---|
76 | K HLL ;changed p-357
|
---|
77 | D GET^HLSUB(DGSCN,2,"",.HLL) ;changed p-357
|
---|
78 | ; S DGAPIEN=$P(HLL("LINKS",1),"^",4) ;ADDED P-357, disabled p-501
|
---|
79 | S DGAPIEN=$$GET1^DIQ(771,$P(HLL("LINKS",1),"^",4),.01) ; added p-501
|
---|
80 | S DGFAC=$$GET1^DIQ(771,$P(HLL("LINKS",1),"^",4),3) ; added p-501
|
---|
81 | ; S CLIENT="DGRU-RAI-"_DGEVENT_"-"_DGAPIEN ;changed p-357 Set client variable using event type and receiving app,disabled p-501
|
---|
82 | S CLIENT="DGRU-RAI-"_DGEVENT ; added p-501
|
---|
83 | S $P(HLL("LINKS",1),"^",1)=CLIENT ;added p-357
|
---|
84 | S HLP("SUBSCRIBER")="^^^"_DGAPIEN_"^"_DGFAC ; added p-501
|
---|
85 | Q
|
---|
86 | ;
|
---|