MPIFDNL ;OAK/TKW-CALL RPC TO ADD TO MPI DO NOT LINK FILE #985.28 ;9 Apr 2013 2:18 PM
;;1.0;MASTER PATIENT INDEX AUSTIN;**52,55,57**;30 Apr 99;Build 2
;
;Reference to ^XWB2HL7 supported by IA #3144
;Reference to ^XWBDRPC supported by IA #3149
;
CALLRPC(MPIFDUZ,MPIFSITE,MPIFFR,MPIFTO,MPIFINAC) ; Activate (add if necessary) or
; inactivate entry on MPI DO NOT LINK file (#985.28)
;
; Called from option XDR VERIFY ALL when patient pair status set to VERIFIED, NOT A DUPLICATE
; Called from option XDR EDIT DUP RECORD STATUS when status set to POTENTIAL DUPLICATE, UNVERIFIED
; MPIFDUZ = DUZ of current user (REQUIRED)
; MPIFSITE = IEN from file 4 for current users institution (from DUZ(2)) (REQUIRED)
; MPIFFR = First Patient IEN (DFN) from File 2 at the VistA site (REQUIRED)
; MPIFTO = Second Patient IEN (DFN) from file 2 at the VistA site (REQUIRED)
; MPIFINAC = If set to 1, entry will be inactivated (OPTIONAL)
;
; Call KERNEL routine to call remote RPC
; 1) Return array
; 2) Station number where RPC is to be executed (MPI="200M")
; 3) Name of RPC at VistA site
; 4) Version number
; 5) SOURCEID = TO_DFN~STATION~Assigning_Authority~Source_Type (Ex. 12345~500~USVHA~PI)
; 6) DNLSOURCEID = FROM_DFN~STATION~Assigning_Authority~Source_Type
; 7) DNLIDENTIFIEDBY = Name of person whose DUZ represents current user
; 8) DNLEVENT = "P" (KERNEL Duplicate Merge potential match resolution)
; 9) DNLIDENTIFYINGLOCATION = VistA station number
; 10) INACTIVATE_FLAG = (optional) set to "Y" if entry is to be inactivated.
;
N MPIFRTN,MPIFNAME,MPIFSTA,MPISTA,MPIFFRP,MPIFTOP,MPIFHNDL,MPIFUERR,X
; Set MPI station number
S MPISTA="200M"
; Get current users name and current station number
S MPIFDUZ=+$G(MPIFDUZ),MPIFSITE=+$G(MPIFSITE)
S (MPIFNAME,MPIFSTA)=""
I MPIFSITE,$D(^DIC(4,MPIFSITE,0)) S MPIFSTA=$$GET1^DIQ(4,+MPIFSITE_",",99)
I MPIFSTA="" D Q
. D ERRMSG(MPIFNAME,MPIFSITE,MPIFFR,MPIFTO,"missing or invalid value in user's station DUZ(2) parameter")
. Q
I $D(^VA(200,MPIFDUZ,0)) S MPIFNAME=$$GET1^DIQ(200,MPIFDUZ_",",.01)
I ('MPIFDUZ)!(MPIFNAME'?1U.E1","1U.E) D Q
. D ERRMSG(MPIFDUZ,MPIFSTA,MPIFFR,MPIFTO,"missing or invalid value in users DUZ variable")
. Q
S MPIFUERR=0
S X=$$GET1^DIQ(200,MPIFDUZ_",",9)
; If station is not MANILA-RO, user must have an SSN.
I MPIFSTA'=358,X'?9N D Q
. D ERRMSG(MPIFDUZ,MPIFSTA,MPIFFR,MPIFTO,"Current user has missing or invalid SSN")
. Q
S MPIFFR=+$G(MPIFFR),MPIFTO=+$G(MPIFTO)
I ('$D(^DPT(MPIFFR,0)))!('$D(^DPT(MPIFTO,0))) D Q
. D ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,"invalid FROM or TO patient input variable")
. Q
S MPIFSTA=$P($$SITE^VASITE,U,3) ;**55,MPIC 2161: Reset site, don't use DUZ(2)
; Build FROM patient parameter
S MPIFFRP=MPIFFR_"~"_MPIFSTA_"~USVHA~PI"
; Build TO patient parameter
S MPIFTOP=MPIFTO_"~"_MPIFSTA_"~USVHA~PI"
; Call RPC to Activate or Inactivate the entry in the MPI DO NOT LINK file.
I $G(MPIFINAC) D EN1^XWB2HL7(.MPIFRTN,MPISTA,"MPIF DNL ADD UPD",1,MPIFTOP,MPIFFRP,"P",MPIFSTA,MPIFNAME,"Y")
I '$G(MPIFINAC) D EN1^XWB2HL7(.MPIFRTN,MPISTA,"MPIF DNL ADD UPD",1,MPIFTOP,MPIFFRP,"P",MPIFSTA,MPIFNAME)
; If RPC was not scheduled, return error.
I $G(MPIFRTN(0))=""!($P($G(MPIFRTN(0)),U)=0)!(+$G(MPIFRTN(0))=-1) D Q
. S X=$P($G(MPIFRTN(0)),U,2)
. S:X="" X=$P($G(MPIFRTN(1)),U,2)
. D ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,X)
. Q
; Schedule a taskman job to process results of RPC
S MPIFHNDL=MPIFRTN(0)
N ZTIO,ZTSK,ZTRTN,ZTDESC,ZTSAVE,ZTDTH,Y
S ZTIO="",ZTRTN="CHKRSLT^MPIFDNL",ZTDTH=$H
S ZTSAVE("MPIFHNDL")=MPIFHNDL,ZTSAVE("MPIFNAME")=MPIFNAME,ZTSAVE("MPIFSTA")=MPIFSTA
S ZTSAVE("MPIFFR")=MPIFFR,ZTSAVE("MPIFTO")=MPIFTO
S ZTDESC="Check Results from call to RPC MPIF DNL ADD UPD"
D ^%ZTLOAD
I '$G(ZTSK) D Q
. S MPIFMSG="Results not returned from RPC to log an MPI DO NOT LINK entry for User "_MPIFNAME_" at station "_MPIFSTA_", for "_MPIFFR_" and "_MPIFTO_"."
. D EXC^RGHLLOG(208,MPIFMSG,MPIFTO)
. D STOP^RGHLLOG(0)
. Q
Q
;
CHKRSLT ; Check results from calling RPC (QUEUED job)
;**57,MVI_1414 (mko): Call RPCCHK^XWB2HL7 instead of RTNDATA^XWBDRPC to check for results
N MPIFCNT,MPIFRTN,X
F MPIFCNT=1:1:20 K MPIFRTN D RPCCHK^XWB2HL7(.MPIFRTN,MPIFHNDL) Q:+MPIFRTN(0)=1 Q:+MPIFRTN(0)=-1 H 5
I +MPIFRTN(0)=-1 S X=$P($G(MPIFRTN(0)),U,2) D ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,X) Q
I +MPIFRTN(0)'=1 D ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,"Timeout") Q
; Get results
K MPIFRTN D RTNDATA^XWBDRPC(.MPIFRTN,MPIFHNDL)
I $P(MPIFRTN(0),U)=-1 S X=$P($G(MPIFRTN(0)),U,2) D ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,X)
Q
;S MPIFDONE=0
;F MPIFCNT=1:1:20 D Q:MPIFDONE
;. H 5
;. D RTNDATA^XWBDRPC(.MPIFRTN,MPIFHNDL)
;. Q:$P(MPIFRTN(0),U)=0 ; Not done
;. I $P(MPIFRTN(0),U)=-1 D Q
;. . I MPIFRTN(0)["Not DONE" Q
;. . S X=$P($G(MPIFRTN(0)),U,2)
;. . S:X="" X=$P($G(MPIFRTN(1)),U,2)
;. . D ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,X)
;. . S MPIFDONE=1
;. . Q
;. ; Success.
;. S MPIFDONE=1 Q
;Q
;
ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,MPIFMSG) ; Send error to CIRN HL7 EXCEPTION LOG (991.1)
S MPIFMSG="User "_MPIFNAME_" at station "_MPIFSTA_" failed to log a DO NOT LINK event for "_MPIFFR_" and "_MPIFTO_" due to "_MPIFMSG
; If MPIFTO is invalid, set it to null so it won't cause a problem logging the error
I '$D(^DPT(+MPIFTO,0)) S MPIFTO=""
D EXC^RGHLLOG(208,MPIFMSG,MPIFTO)
D STOP^RGHLLOG(0)
Q
;
DNLCHK(MPIFREC1,MPIFREC2) ; Checks whether records with DFNs MPIFREC1 and
; MPIFREC2 are verified as not duplicates in the MPI DO NOT LINK file.
; (New entry point created in MPIF*1.0*55, MPIC_1834)
; Input:
; MPIFREC1 - DFN for record 1 in the Patient file
; MPIFREC2 - DFN for record 2 in the Patient file
; Returns:
; 0 - if the are no problems and the records can be
; added to the Duplicate Record file
; -1^error message - if the there was a problem calling the MPI RPC
; or if the record pair is in the MPI DO NOT LINK
; file.
;
N MPIFERR,MPIFSITE,MPIFID,MPIFI,MPIFREC,MPIICN1,MPIICN2
S MPIFERR=0
;
; Find records that should not be merged with MPIFREC1
; Use the ICN if available,
S MPIFSITE=$P($$SITE^VASITE,U,3)
S MPIFICN1=$$GETICN^MPIF001(MPIFREC1)
S MPIFICN2=$$GETICN^MPIF001(MPIFREC2)
I MPIFICN1>0 D
. S MPIFID=MPIFICN1_"|200M|USVHA|NI"
E D
. S MPIFID=MPIFREC1_"|"_MPIFSITE_"|USVHA|PI"
D CALLRPCD(.MPIFRES,MPIFID)
;
; Check for errors invoking RPC
I $P($G(MPIFRES(0)),U)=-1!(+$G(MPIFRES)=-1) D Q MPIFERR
. S MPIFERR="-1^Remote procedure call to MPI to return DO NOT LINK records failed. "_$P($G(MPIFRES(0)),U,2)
;
; Loop through the records returned by the MPI EVENT LIST call and see
; if any of the returned records match MPIFREC2 or MPIFICN2
S MPIFI="" F S MPIFI=$O(MPIFRES(MPIFI)) Q:MPIFI="" D Q:MPIFERR
. Q:MPIFRES(MPIFI)'["^DO NOT LINK^"
. S MPIFID2=$P(MPIFRES(MPIFI),"^DO NOT LINK^",2,999)
. I $P(MPIFID2,U,1,4)=(MPIFREC2_U_MPIFSITE_"^USVHA^PI")!($P(MPIFID2,U,1,4)=(MPIFICN2_"^200M^USVHA^NI")) D
.. S MPIFERR="-1^The records with DFN #"_MPIFREC1_" and "_MPIFREC2_" have already been identified as not duplicates in the MPI NOT LINK file, and therefore cannot be added as a duplicate pair."
;
Q MPIFERR
;
CALLRPCD(MPIFRES,MPIFID) ; Uses the DIRECT^XWB2HL7 API to call the
; "MPI EVENT LIST" Remote Procedure on the MPI directly. This RPC
; returns the list of records that have been marked as DO NOT LINK
; with the record identified by the Source ID input parameter.
; (Entry point created in MPIF*1.0*55, MPIC_1834)
;
; Input:
; MPIFID = The source ID in the format:
; DFN/ICN|SourceSytemID|SourceAssigningAuthority|IDType
; Example:
; 100001440|500|USVHA|PI
; Output:
; .MPIFRES = Array of records that should not be linked with the
; source ID passed in
; Example output:
; RESULT(0)="100001440|500|USVHA|PI^DO NOT LINK^100001439^500^USVHA^PI"
; RESULT(1)="100001440|500|USVHA|PI^DO NOT LINK^100002113^500^USVHA^PI"
;
N MPIFRPC,MPIFSTA
;
; Setup input parameters and call the DIRECT^XWB2HL7 entry point to
; invoke the "MPI EVENT LIST" Remote Procedure on the MPI.
S MPIFRPC="MPI EVENT LIST"
S MPIFSTA="200M"
D DIRECT^XWB2HL7(.MPIFRES,MPIFSTA,MPIFRPC,1,MPIFID)
Q
;
--- Routine Detail --- with STRUCTURED ROUTINE LISTING ---[H[J[2J[HMPIFDNL 8463 printed Dec 13, 2024@02:11:04 Page 2
MPIFDNL ;OAK/TKW-CALL RPC TO ADD TO MPI DO NOT LINK FILE #985.28 ;9 Apr 2013 2:18 PM
+1 ;;1.0;MASTER PATIENT INDEX AUSTIN;**52,55,57**;30 Apr 99;Build 2
+2 ;
+3 ;Reference to ^XWB2HL7 supported by IA #3144
+4 ;Reference to ^XWBDRPC supported by IA #3149
+5 ;
CALLRPC(MPIFDUZ,MPIFSITE,MPIFFR,MPIFTO,MPIFINAC) ; Activate (add if necessary) or
+1 ; inactivate entry on MPI DO NOT LINK file (#985.28)
+2 ;
+3 ; Called from option XDR VERIFY ALL when patient pair status set to VERIFIED, NOT A DUPLICATE
+4 ; Called from option XDR EDIT DUP RECORD STATUS when status set to POTENTIAL DUPLICATE, UNVERIFIED
+5 ; MPIFDUZ = DUZ of current user (REQUIRED)
+6 ; MPIFSITE = IEN from file 4 for current users institution (from DUZ(2)) (REQUIRED)
+7 ; MPIFFR = First Patient IEN (DFN) from File 2 at the VistA site (REQUIRED)
+8 ; MPIFTO = Second Patient IEN (DFN) from file 2 at the VistA site (REQUIRED)
+9 ; MPIFINAC = If set to 1, entry will be inactivated (OPTIONAL)
+10 ;
+11 ; Call KERNEL routine to call remote RPC
+12 ; 1) Return array
+13 ; 2) Station number where RPC is to be executed (MPI="200M")
+14 ; 3) Name of RPC at VistA site
+15 ; 4) Version number
+16 ; 5) SOURCEID = TO_DFN~STATION~Assigning_Authority~Source_Type (Ex. 12345~500~USVHA~PI)
+17 ; 6) DNLSOURCEID = FROM_DFN~STATION~Assigning_Authority~Source_Type
+18 ; 7) DNLIDENTIFIEDBY = Name of person whose DUZ represents current user
+19 ; 8) DNLEVENT = "P" (KERNEL Duplicate Merge potential match resolution)
+20 ; 9) DNLIDENTIFYINGLOCATION = VistA station number
+21 ; 10) INACTIVATE_FLAG = (optional) set to "Y" if entry is to be inactivated.
+22 ;
+23 NEW MPIFRTN,MPIFNAME,MPIFSTA,MPISTA,MPIFFRP,MPIFTOP,MPIFHNDL,MPIFUERR,X
+24 ; Set MPI station number
+25 SET MPISTA="200M"
+26 ; Get current users name and current station number
+27 SET MPIFDUZ=+$GET(MPIFDUZ)
SET MPIFSITE=+$GET(MPIFSITE)
+28 SET (MPIFNAME,MPIFSTA)=""
+29 IF MPIFSITE
IF $DATA(^DIC(4,MPIFSITE,0))
SET MPIFSTA=$$GET1^DIQ(4,+MPIFSITE_",",99)
+30 IF MPIFSTA=""
Begin DoDot:1
+31 DO ERRMSG(MPIFNAME,MPIFSITE,MPIFFR,MPIFTO,"missing or invalid value in user's station DUZ(2) parameter")
+32 QUIT
End DoDot:1
QUIT
+33 IF $DATA(^VA(200,MPIFDUZ,0))
SET MPIFNAME=$$GET1^DIQ(200,MPIFDUZ_",",.01)
+34 IF ('MPIFDUZ)!(MPIFNAME'?1U.E1","1U.E)
Begin DoDot:1
+35 DO ERRMSG(MPIFDUZ,MPIFSTA,MPIFFR,MPIFTO,"missing or invalid value in users DUZ variable")
+36 QUIT
End DoDot:1
QUIT
+37 SET MPIFUERR=0
+38 SET X=$$GET1^DIQ(200,MPIFDUZ_",",9)
+39 ; If station is not MANILA-RO, user must have an SSN.
+40 IF MPIFSTA'=358
IF X'?9N
Begin DoDot:1
+41 DO ERRMSG(MPIFDUZ,MPIFSTA,MPIFFR,MPIFTO,"Current user has missing or invalid SSN")
+42 QUIT
End DoDot:1
QUIT
+43 SET MPIFFR=+$GET(MPIFFR)
SET MPIFTO=+$GET(MPIFTO)
+44 IF ('$DATA(^DPT(MPIFFR,0)))!('$DATA(^DPT(MPIFTO,0)))
Begin DoDot:1
+45 DO ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,"invalid FROM or TO patient input variable")
+46 QUIT
End DoDot:1
QUIT
+47 ;**55,MPIC 2161: Reset site, don't use DUZ(2)
SET MPIFSTA=$PIECE($$SITE^VASITE,U,3)
+48 ; Build FROM patient parameter
+49 SET MPIFFRP=MPIFFR_"~"_MPIFSTA_"~USVHA~PI"
+50 ; Build TO patient parameter
+51 SET MPIFTOP=MPIFTO_"~"_MPIFSTA_"~USVHA~PI"
+52 ; Call RPC to Activate or Inactivate the entry in the MPI DO NOT LINK file.
+53 IF $GET(MPIFINAC)
DO EN1^XWB2HL7(.MPIFRTN,MPISTA,"MPIF DNL ADD UPD",1,MPIFTOP,MPIFFRP,"P",MPIFSTA,MPIFNAME,"Y")
+54 IF '$GET(MPIFINAC)
DO EN1^XWB2HL7(.MPIFRTN,MPISTA,"MPIF DNL ADD UPD",1,MPIFTOP,MPIFFRP,"P",MPIFSTA,MPIFNAME)
+55 ; If RPC was not scheduled, return error.
+56 IF $GET(MPIFRTN(0))=""!($PIECE($GET(MPIFRTN(0)),U)=0)!(+$GET(MPIFRTN(0))=-1)
Begin DoDot:1
+57 SET X=$PIECE($GET(MPIFRTN(0)),U,2)
+58 if X=""
SET X=$PIECE($GET(MPIFRTN(1)),U,2)
+59 DO ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,X)
+60 QUIT
End DoDot:1
QUIT
+61 ; Schedule a taskman job to process results of RPC
+62 SET MPIFHNDL=MPIFRTN(0)
+63 NEW ZTIO,ZTSK,ZTRTN,ZTDESC,ZTSAVE,ZTDTH,Y
+64 SET ZTIO=""
SET ZTRTN="CHKRSLT^MPIFDNL"
SET ZTDTH=$HOROLOG
+65 SET ZTSAVE("MPIFHNDL")=MPIFHNDL
SET ZTSAVE("MPIFNAME")=MPIFNAME
SET ZTSAVE("MPIFSTA")=MPIFSTA
+66 SET ZTSAVE("MPIFFR")=MPIFFR
SET ZTSAVE("MPIFTO")=MPIFTO
+67 SET ZTDESC="Check Results from call to RPC MPIF DNL ADD UPD"
+68 DO ^%ZTLOAD
+69 IF '$GET(ZTSK)
Begin DoDot:1
+70 SET MPIFMSG="Results not returned from RPC to log an MPI DO NOT LINK entry for User "_MPIFNAME_" at station "_MPIFSTA_", for "_MPIFFR_" and "_MPIFTO_"."
+71 DO EXC^RGHLLOG(208,MPIFMSG,MPIFTO)
+72 DO STOP^RGHLLOG(0)
+73 QUIT
End DoDot:1
QUIT
+74 QUIT
+75 ;
CHKRSLT ; Check results from calling RPC (QUEUED job)
+1 ;**57,MVI_1414 (mko): Call RPCCHK^XWB2HL7 instead of RTNDATA^XWBDRPC to check for results
+2 NEW MPIFCNT,MPIFRTN,X
+3 FOR MPIFCNT=1:1:20
KILL MPIFRTN
DO RPCCHK^XWB2HL7(.MPIFRTN,MPIFHNDL)
if +MPIFRTN(0)=1
QUIT
if +MPIFRTN(0)=-1
QUIT
HANG 5
+4 IF +MPIFRTN(0)=-1
SET X=$PIECE($GET(MPIFRTN(0)),U,2)
DO ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,X)
QUIT
+5 IF +MPIFRTN(0)'=1
DO ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,"Timeout")
QUIT
+6 ; Get results
+7 KILL MPIFRTN
DO RTNDATA^XWBDRPC(.MPIFRTN,MPIFHNDL)
+8 IF $PIECE(MPIFRTN(0),U)=-1
SET X=$PIECE($GET(MPIFRTN(0)),U,2)
DO ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,X)
+9 QUIT
+10 ;S MPIFDONE=0
+11 ;F MPIFCNT=1:1:20 D Q:MPIFDONE
+12 ;. H 5
+13 ;. D RTNDATA^XWBDRPC(.MPIFRTN,MPIFHNDL)
+14 ;. Q:$P(MPIFRTN(0),U)=0 ; Not done
+15 ;. I $P(MPIFRTN(0),U)=-1 D Q
+16 ;. . I MPIFRTN(0)["Not DONE" Q
+17 ;. . S X=$P($G(MPIFRTN(0)),U,2)
+18 ;. . S:X="" X=$P($G(MPIFRTN(1)),U,2)
+19 ;. . D ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,X)
+20 ;. . S MPIFDONE=1
+21 ;. . Q
+22 ;. ; Success.
+23 ;. S MPIFDONE=1 Q
+24 ;Q
+25 ;
ERRMSG(MPIFNAME,MPIFSTA,MPIFFR,MPIFTO,MPIFMSG) ; Send error to CIRN HL7 EXCEPTION LOG (991.1)
+1 SET MPIFMSG="User "_MPIFNAME_" at station "_MPIFSTA_" failed to log a DO NOT LINK event for "_MPIFFR_" and "_MPIFTO_" due to "_MPIFMSG
+2 ; If MPIFTO is invalid, set it to null so it won't cause a problem logging the error
+3 IF '$DATA(^DPT(+MPIFTO,0))
SET MPIFTO=""
+4 DO EXC^RGHLLOG(208,MPIFMSG,MPIFTO)
+5 DO STOP^RGHLLOG(0)
+6 QUIT
+7 ;
DNLCHK(MPIFREC1,MPIFREC2) ; Checks whether records with DFNs MPIFREC1 and
+1 ; MPIFREC2 are verified as not duplicates in the MPI DO NOT LINK file.
+2 ; (New entry point created in MPIF*1.0*55, MPIC_1834)
+3 ; Input:
+4 ; MPIFREC1 - DFN for record 1 in the Patient file
+5 ; MPIFREC2 - DFN for record 2 in the Patient file
+6 ; Returns:
+7 ; 0 - if the are no problems and the records can be
+8 ; added to the Duplicate Record file
+9 ; -1^error message - if the there was a problem calling the MPI RPC
+10 ; or if the record pair is in the MPI DO NOT LINK
+11 ; file.
+12 ;
+13 NEW MPIFERR,MPIFSITE,MPIFID,MPIFI,MPIFREC,MPIICN1,MPIICN2
+14 SET MPIFERR=0
+15 ;
+16 ; Find records that should not be merged with MPIFREC1
+17 ; Use the ICN if available,
+18 SET MPIFSITE=$PIECE($$SITE^VASITE,U,3)
+19 SET MPIFICN1=$$GETICN^MPIF001(MPIFREC1)
+20 SET MPIFICN2=$$GETICN^MPIF001(MPIFREC2)
+21 IF MPIFICN1>0
Begin DoDot:1
+22 SET MPIFID=MPIFICN1_"|200M|USVHA|NI"
End DoDot:1
+23 IF '$TEST
Begin DoDot:1
+24 SET MPIFID=MPIFREC1_"|"_MPIFSITE_"|USVHA|PI"
End DoDot:1
+25 DO CALLRPCD(.MPIFRES,MPIFID)
+26 ;
+27 ; Check for errors invoking RPC
+28 IF $PIECE($GET(MPIFRES(0)),U)=-1!(+$GET(MPIFRES)=-1)
Begin DoDot:1
+29 SET MPIFERR="-1^Remote procedure call to MPI to return DO NOT LINK records failed. "_$PIECE($GET(MPIFRES(0)),U,2)
End DoDot:1
QUIT MPIFERR
+30 ;
+31 ; Loop through the records returned by the MPI EVENT LIST call and see
+32 ; if any of the returned records match MPIFREC2 or MPIFICN2
+33 SET MPIFI=""
FOR
SET MPIFI=$ORDER(MPIFRES(MPIFI))
if MPIFI=""
QUIT
Begin DoDot:1
+34 if MPIFRES(MPIFI)'["^DO NOT LINK^"
QUIT
+35 SET MPIFID2=$PIECE(MPIFRES(MPIFI),"^DO NOT LINK^",2,999)
+36 IF $PIECE(MPIFID2,U,1,4)=(MPIFREC2_U_MPIFSITE_"^USVHA^PI")!($PIECE(MPIFID2,U,1,4)=(MPIFICN2_"^200M^USVHA^NI"))
Begin DoDot:2
+37 SET MPIFERR="-1^The records with DFN #"_MPIFREC1_" and "_MPIFREC2_" have already been identified as not duplicates in the MPI NOT LINK file, and therefore cannot be added as a duplicate pair."
End DoDot:2
End DoDot:1
if MPIFERR
QUIT
+38 ;
+39 QUIT MPIFERR
+40 ;
CALLRPCD(MPIFRES,MPIFID) ; Uses the DIRECT^XWB2HL7 API to call the
+1 ; "MPI EVENT LIST" Remote Procedure on the MPI directly. This RPC
+2 ; returns the list of records that have been marked as DO NOT LINK
+3 ; with the record identified by the Source ID input parameter.
+4 ; (Entry point created in MPIF*1.0*55, MPIC_1834)
+5 ;
+6 ; Input:
+7 ; MPIFID = The source ID in the format:
+8 ; DFN/ICN|SourceSytemID|SourceAssigningAuthority|IDType
+9 ; Example:
+10 ; 100001440|500|USVHA|PI
+11 ; Output:
+12 ; .MPIFRES = Array of records that should not be linked with the
+13 ; source ID passed in
+14 ; Example output:
+15 ; RESULT(0)="100001440|500|USVHA|PI^DO NOT LINK^100001439^500^USVHA^PI"
+16 ; RESULT(1)="100001440|500|USVHA|PI^DO NOT LINK^100002113^500^USVHA^PI"
+17 ;
+18 NEW MPIFRPC,MPIFSTA
+19 ;
+20 ; Setup input parameters and call the DIRECT^XWB2HL7 entry point to
+21 ; invoke the "MPI EVENT LIST" Remote Procedure on the MPI.
+22 SET MPIFRPC="MPI EVENT LIST"
+23 SET MPIFSTA="200M"
+24 DO DIRECT^XWB2HL7(.MPIFRES,MPIFSTA,MPIFRPC,1,MPIFID)
+25 QUIT
+26 ;