718 lines
33 KiB
Mathematica
718 lines
33 KiB
Mathematica
XBSAN ;IHS/ITSC/LAB/FJE;SANITIZE RPMS DATABASE; [ 01/29/2004 11:10 AM ]
|
|
;;4.0;XB;;Jul 20, 2009;Build 2
|
|
W !,"This routine sanitizes and deletes RPMS data. To use you must type: D START^XBSAN",!!
|
|
Q
|
|
START ;
|
|
S (XBDUZ,XBDEL,XBPAT,XBPHR,XBBH,XBCHR,XBPOS,XB3PB,XBAR,XBLAB,XBMMDEL,XBAUDEL,XBNCDEL)=0
|
|
K ^XTMP("SAN")
|
|
S ^XTMP("SAN","LASTDFN")=0
|
|
W !,"This routine will first sanitize AND randomize the NEW PERSON file in the RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want to convert the new person data?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBDUZ=1
|
|
W !,"This routine will then REMOVE/DELETE UNNEEDED PATIENT DATA in the RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want this data deleted?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBDEL=1
|
|
W !!,"This routine will then sanitize the PATIENT FILES of a RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want to convert the patient data",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBPAT=1
|
|
W !!,"This routine will then sanitize the POLICY HOLDER FILE of a RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want to convert the POLICY HOLDER data?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBPHR=1
|
|
W !!,"This routine will then delete SENSITIVE CHR DATA from a RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want to delete this CHR patient data?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBCHR=1
|
|
W !!,"This routine will then delete SENSITIVE BH VERSION 3.0 COMPLIANT DATA from a RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want to delete this CHR patient data?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBBH=1
|
|
W !,"This routine will then REMOVE/DELETE UNNEEDED POS DATA in the RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want this data deleted?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBPOS=1
|
|
W !,"This routine will then REMOVE/DELETE UNNEEDED 3PB DATA in the RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want this data deleted?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XB3PB=1
|
|
W !,"This routine will then REMOVE/DELETE UNNEEDED AR DATA in the RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want this data deleted?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBAR=1
|
|
W !,"This routine will then REMOVE/DELETE UNNEEDED LAB DATA in the RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want this data deleted?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBLAB=1
|
|
W !,"This routine will then REMOVE/DELETE MAILMAN MESSAGES in the RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want this data deleted?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBMMDEL=1
|
|
W !,"This routine will then REMOVE/DELETE AUDIT DATA in the RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want this data deleted?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBAUDEL=1
|
|
W !,"This routine will then REMOVE/DELETE NAME COMPONENTS in the RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Do you want this data deleted?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
S:Y=1 XBNCDEL=1
|
|
W !,"All failed fileman update data can be found in: ^XTMP(""SAN"",""FAILURE"", GLOBAL"
|
|
W !,"?? display usually means that there was a fileman update failure"
|
|
W !,"If a hard error like an UNDEFINED occurs during the Patient scrambling,"
|
|
W !," you can restart at the next patient by typing: RESTART^XBSAN "
|
|
W !,"This routine does not purge HL7, or ARMS data."
|
|
W !,"When finished...don't forget to manually address the above and RENAME Institutions",!!
|
|
W !!,"This routine is about to scramble the RPMS database."
|
|
S DIR(0)="Y",DIR("A")="Last chance: Do you want your RPMS data SANITIZED?",DIR("B")="N" KILL DA D ^DIR KILL DIR
|
|
Q:Y'=1
|
|
D ^XBKVAR
|
|
W !,"Collecting random names" D CLEAN
|
|
I XBDUZ W !,"SCRAMBLING FILE 200" D DUZ
|
|
I XBDEL W !,"DELETING PAT INFO" D PATDEL
|
|
RESTART ;WILL RESTART PAT SCRAMBLE IF HARD ERROR OCCURS
|
|
I $G(^XTMP("SAN","LASTDFN"))>0 S ^XTMP("SAN","FAILURE","PATDFN",^XTMP("SAN","LASTDFN"))=""
|
|
I XBPAT W !,"SCRAMBLING PAT FILE" D PAT
|
|
I XBPHR W !,"SCRAMBLING POLICY FILE" D PHR
|
|
I XBCHR W !,"SCRAMBLING CHR FILE" D CHR
|
|
I XBBH W !,"DELETING BH INFO" D BH
|
|
I XBPOS W !,"DELETING POS INFO" D POSDEL
|
|
I XB3PB W !,"SCRAMBLING 3PB FILE" D TPB
|
|
I XBAR W !,"SCRAMBLING AR FILE" D AR
|
|
I XBLAB W !,"SCRAMBLING LAB FILES" D LAB
|
|
I XBMMDEL W !,"DELETING MAILMAN MESSAGES" D MMDEL
|
|
I XBAUDEL W !,"DELETING AUDIT DATA" D AUDEL
|
|
I XBNCDEL W !,"DELETING NAME COMPONENTS" D NCDEL
|
|
D PAT2
|
|
S ^XTMP("SAN","PROCESS","XBSAN")="FINISHED"
|
|
W !,"FINISHED"
|
|
D LISTE
|
|
D EOJ
|
|
Q
|
|
;
|
|
PAT D ^XBKVAR
|
|
S XBCHART=100000
|
|
S DFN=+$G(^XTMP("SAN","LASTDFN")) I DFN W !,"RESTARTING PATIENT SCRAMBLE AFTER "_DFN,!
|
|
F S DFN=$O(^DPT(DFN)) Q:DFN'=+DFN D PROCPAT
|
|
S ^XTMP("SAN","PROCESS","PAT")="FINISHED"
|
|
Q
|
|
;
|
|
PAT2 D ^XBKVAR
|
|
S XBCHART=100000
|
|
W !,"RETRYING FAILED PATIENTS",!
|
|
S DFN=0 F S DFN=$O(^XTMP("SAN","FAILURE","PATNAME",DFN)) Q:DFN'=+DFN D
|
|
.S Y=DFN D ^AUPNPAT
|
|
.S XBSCR=$S(AUPNSEX="M":3,1:2)
|
|
.D FNAME
|
|
.D LNAME
|
|
.S XBNAME=XBLNAME_","_XBFNAME
|
|
.S DA=DFN,DIE="^DPT(",DR=".01///"_XBNAME D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATNAME2",DFN)="" W !,$P(^DPT(DFN,0),U,1)," ",XBNAME
|
|
.D ^XBFMK
|
|
S ^XTMP("SAN","PROCESS","PAT")="FINISHED"
|
|
Q
|
|
CHR ;
|
|
S X=0 F S X=$O(^BCHR(X)) Q:X'=+X K ^BCHR(X,51),^BCHR(X,61),^BCHR(X,71)
|
|
S ^XTMP("SAN","PROCESS","CHR")="FINISHED"
|
|
Q
|
|
BH ;version 3.0 compliant only
|
|
S X=0 F S X=$O(^AMHREC(X)) Q:X'=+X K ^AMHREC(X,31),^AMHREC(X,81),^AMHREC(X,21)
|
|
S X=0 F S X=$O(^AMHPTXP(X)) Q:X'=+X K ^AMHPTXP(X,18)
|
|
S ^XTMP("SAN","PROCESS","BH")="FINISHED"
|
|
Q
|
|
PHR ;
|
|
;policy holders not pointing to a patient
|
|
S XBP=0 F S XBP=$O(^AUPN3PPH(XBP)) Q:XBP'=+XBP D
|
|
.Q:$P(^AUPN3PPH(XBP,0),U,2) ;already converted
|
|
.S XBS=$P(^AUPN3PPH(XBP,0),U,8) I XBS="" S XBS="M"
|
|
.S XBSCR=$S(XBS="M":3,1:2)
|
|
.D FNAME
|
|
.D LNAME
|
|
.S XBNAME=XBLNAME_","_XBFNAME
|
|
.D PHNR
|
|
.S XBPHN="555-777-"_XBPHN
|
|
.S DA=XBP,DIE="^AUPN3PPH(",DR=".01///"_XBNAME_";.14///"_XBPHN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","POLICYPHONE",DFN)=""
|
|
.D ^XBFMK
|
|
.D SSNR
|
|
.S DA=XBP,DIE="^AUPN3PPH(",DR=".04///"_XBSSN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","POLICYSSN",DFN)=""
|
|
.D ^XBFMK
|
|
.S X=^XTMP("SAN",$J,"ADL1") D R S XBADDR=^XTMP("SAN",$J,"ADL1",X)
|
|
.S $P(^AUPN3PPH(XBP,0),U,9)=XBADDR
|
|
.S XBD=$P(^AUPN3PPH(XBP,0),U,19) I XBD]"" S XBD=$$FMADD^XLFDT(XBD,-33)
|
|
.S DA=XBP,DIE="^AUPN3PPH(",DR=".19///"_XBD D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","POLICYDOB",DA)=""
|
|
.D ^XBFMK
|
|
S ^XTMP("SAN","PROCESS","POLICY")="FINISHED"
|
|
Q
|
|
PROCPAT ;
|
|
S ^XTMP("SAN","LASTDFN")=DFN
|
|
I '(DFN#5000) W !,"."_DFN_"."
|
|
D ^XBFMK
|
|
S Y=DFN D ^AUPNPAT
|
|
D F201
|
|
D F203 ;subtract 33 days from dob
|
|
D F209
|
|
D F2111
|
|
D F2131
|
|
D F2132
|
|
D F2211
|
|
D F2212
|
|
D F2213
|
|
D F2219
|
|
D F22401
|
|
D F22402
|
|
D F22403
|
|
D OTHNAME
|
|
D TEN ;tribal enrollment number
|
|
D BRTH
|
|
D DTH
|
|
D PN
|
|
D EMPL
|
|
D NKR
|
|
D ECR
|
|
D XBCHART
|
|
D INSURE
|
|
D POLICY
|
|
Q
|
|
EOJ ;
|
|
D EN^XBVK("XB")
|
|
K DFN,XBH,OTDFN,XBB,AUPNSEX,X,X2,XB3PB,XBAR,XBAUDEL
|
|
K DA,DIE,DIK,DIR,DR,DUZSSN,I,XBA,XBADDR,XBADL1
|
|
K XBBH,XBC,XBCHART,XBCHR,XBD,XBDAD,XBDEANUM,XBDEL,XBDFIRST,XBDLAST,XBDNAME
|
|
K XBDOB,XBDUZ,XBFIRST,XBFNAME,XBH,XBLAB,XBLNAME,XBMDFN,XBMMDEL,XBMOM
|
|
K XBNAME,XBNCDEL,XBNOK,XBNOKADL,XBP,XBPAT,XBPHN,XBPHR,XBPOS,XBS
|
|
K XBSCR,XBSEX,XBSSN,XBTEN,XBVAL,XBVANUM,XBX,Y,Z
|
|
W !,"If all data appears correct and you have chaecked failures, kill the ^XTMP(""SAN"") global",!!
|
|
Q
|
|
NKR ;
|
|
I $P($G(^AUPNPAT(DFN,28)),U,2)]"" S DA=DFN,DIE="^AUPNPAT(",DR="2802///`"_$O(^AUTTRLSH("B","MOTHER",0)) D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","PATNKR",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
ECR ;
|
|
I $P($G(^AUPNPAT(DFN,31)),U,2)]"" S DA=DFN,DIE="^AUPNPAT(",DR="3102///`"_$O(^AUTTRLSH("B","MOTHER",0)) D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","PATECR",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
EMPL ;employer .19
|
|
I $P($G(^AUPNPAT(DFN,0)),U,19)]"" S DA=DFN,DIE="^AUPNPAT(",DR=".19///FIRST AMERICAN BANK" D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","PATEMP",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
PN ;
|
|
I $P($G(^AUPNPAT(DFN,0)),U,31)]"" S DA=DFN,DIE="^AUPNPAT(",DR=".31///"_$P(^DPT(DFN,0),U) D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","PATPN",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
TEN ;
|
|
S XBTEN="TN - "_DFN
|
|
I $P($G(^AUPNPAT(DFN,0)),U,7)]"" S DA=DFN,DIE="^AUPNPAT(",DR=".07///"_XBTEN D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","PATTEN",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
BRTH ;
|
|
I $P($G(^AUPNPAT(DFN,11)),U,5)]"" S XBTEN=$E(DFN_"000000",1,7),DA=DFN,DIE="^AUPNPAT(",DR="1105///"_XBTEN D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","PATBIRTH",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
DTH ;
|
|
I $P($G(^AUPNPAT(DFN,11)),U,16)]"" S XBTEN=$E("D"_DFN_"00000",1,7),DA=DFN,DIE="^AUPNPAT(",DR="1105///"_XBTEN D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","PATDEATH",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
F201 ;
|
|
S XBSCR=$S(AUPNSEX="M":3,1:2)
|
|
D FNAME
|
|
D LNAME
|
|
S XBNAME=XBLNAME_","_XBFNAME
|
|
S DA=DFN,DIE="^DPT(",DR=".01///"_XBNAME D ^DIE
|
|
I $D(Y) S ^XTMP("SAN","FAILURE","PATNAME",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
FNAME ;
|
|
I XBSCR=3 S X=^XTMP("SAN",$J,"FIRSTM") D R S XBFNAME=^XTMP("SAN",$J,"FIRSTM",X) Q
|
|
S X=^XTMP("SAN",$J,"FIRSTF") D R S XBFNAME=^XTMP("SAN",$J,"FIRSTF",X)
|
|
Q
|
|
LNAME ;
|
|
S X=^XTMP("SAN",$J,"LAST") D R S XBLNAME=^XTMP("SAN",$J,"LAST",X)
|
|
Q
|
|
F203 ;dob
|
|
S XBDOB=$P(^DPT(DFN,0),U,3)
|
|
I XBDOB="" Q
|
|
S XBDOB=$$FMADD^XLFDT(XBDOB,-33)
|
|
S DIE="^DPT(",DA=DFN,DR=".03///"_XBDOB D ^DIE
|
|
I $D(Y) S ^XTMP("SAN","FAILURE","PATDOB",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
F2211 ;nok/emergency contact name
|
|
S XBSCR=2 D FNAME S XBNOK=XBLNAME_","_XBFNAME
|
|
I $P($G(^DPT(DFN,.21)),U,1)]"" D
|
|
.D ^XBFMK
|
|
.S DIE="^DPT(",DR=".211///"_XBNOK,DA=DFN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATNOK",DFN)=""
|
|
.D ^XBFMK
|
|
I $P($G(^DPT(DFN,.33)),U,1)]"" D
|
|
.S DIE="^DPT(",DR=".331///"_XBNOK,DA=DFN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATECN",DFN)=""
|
|
.D ^XBFMK
|
|
Q
|
|
F2212 ;
|
|
D ^XBFMK
|
|
I $P($G(^DPT(DFN,.21)),U,2)]"" D
|
|
.S DA=DFN,DIE="^DPT(",DR=".212///MOTHER" D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATNOKMOTHER",DFN)=""
|
|
.D ^XBFMK
|
|
I $P($G(^DPT(DFN,.33)),U,2)]"" D
|
|
.S DA=DFN,DIE="^DPT(",DR=".332///"_"MOTHER" D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATECNMOTHER",DFN)=""
|
|
.D ^XBFMK
|
|
Q
|
|
F22401 ;father's name
|
|
I $P($G(^DPT(DFN,.24)),U,1)="" Q
|
|
S XBSCR=3 D FNAME S XBDAD=XBLNAME_","_XBFNAME
|
|
S DIE="^DPT(",DR=".2401///"_XBDAD,DA=DFN D ^DIE
|
|
I $D(Y) S ^XTMP("SAN","FAILURE","PATFATHER",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
F22402 ;mother's name
|
|
S XBSCR=2 D FNAME S XBMOM=XBLNAME_","_XBFNAME
|
|
I $P($G(^DPT(DFN,.24)),U,2)="" Q
|
|
S DIE="^DPT(",DR=".2402///"_XBMOM,DA=DFN D ^DIE
|
|
I $D(Y) S ^XTMP("SAN","FAILURE","PATMOTHER",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
F22403 ;mother's maiden name
|
|
D LNAME
|
|
S XBMMN=XBLNAME_","_$P(XBMOM,",",2)
|
|
I $P($G(^DPT(DFN,.24)),U,3)="" Q
|
|
S DIE="^DPT(",DR=".2403///"_XBMMN,DA=DFN D ^DIE
|
|
I $D(Y) S ^XTMP("SAN","FAILURE","PATMOTHMAIDNAM",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
OTHNAME ;
|
|
S OTDFN=0 F S OTDFN=$O(^DPT(DFN,.01,OTDFN)) Q:OTDFN'=+OTDFN D
|
|
.D LNAME
|
|
.S XBNAME=XBLNAME_","_XBFNAME
|
|
.S DA=OTDFN,DIE="^DPT("_DFN_",.01,",DA(1)=DFN,DR=".01///"_XBNAME D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATOTHRNAME",DFN)=""
|
|
.D ^XBFMK
|
|
Q
|
|
F2111 ;
|
|
I $P($G(^DPT(DFN,.11)),U,1)]"" D
|
|
.S X=^XTMP("SAN",$J,"ADL1") D R S XBADDR=^XTMP("SAN",$J,"ADL1",X)
|
|
.S DIE="^DPT(",DR=".111///"_XBADDR,DA=DFN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATADDRESS",DFN)=""
|
|
.D ^XBFMK
|
|
.S $P(^DPT(DFN,.11),U,2)="" ;addr 2nd line
|
|
.S $P(^DPT(DFN,.11),U,3)="" ;addr 3rd line
|
|
Q
|
|
F2213 ;
|
|
I $P($G(^DPT(DFN,.21)),U,3)]"" D
|
|
.S X=^XTMP("SAN",$J,"ADL1") D R S XBADDR=^XTMP("SAN",$J,"ADL1",X)
|
|
.S DIE="^DPT(",DR=".213///"_XBADDR,DA=DFN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATADDRESSL11",DFN)=""
|
|
.D ^XBFMK
|
|
I $P($G(^DPT(DFN,.33)),U,3)]"" D
|
|
.S X=^XTMP("SAN",$J,"ADL1") D R S XBADDR=^XTMP("SAN",$J,"ADL1",X)
|
|
.S DIE="^DPT(",DR=".333.//"_XBADDR,DA=DFN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATADDRESSL111",DFN)=""
|
|
.D ^XBFMK
|
|
Q
|
|
POLICY ;
|
|
;loop through policy holder
|
|
;if has patient pointer use patient name and address and
|
|
D ^XBFMK
|
|
S XBP=$O(^AUPN3PPH("C",DFN,0))
|
|
I 'XBP K XBP Q
|
|
S XBTEN=$P($G(^DPT(DFN,.11)),U,1)
|
|
S DA=XBP,DIE="^AUPN3PPH(",DR=".01///"_XBNAME_";.04///"_XBSSN_";.09///"_XBTEN_";.11///@;.13///@;.14///@;.19///"_XBDOB D ^DIE
|
|
I $D(Y) S ^XTMP("SAN","FAILURE","PATPOLICY",DA)=""
|
|
D ^XBFMK
|
|
Q
|
|
INSURE ;
|
|
D MCR,PI,MCD,RR
|
|
Q
|
|
MCR ;
|
|
;MEDICARE
|
|
Q:'$D(^AUPNMCR(DFN))
|
|
S X=^XTMP("SAN",$J,"DLAST") D R S XBDLAST=^XTMP("SAN",$J,"DLAST",X)
|
|
S X=^XTMP("SAN",$J,"DFIRST") D R S XBDFIRST=^XTMP("SAN",$J,"DFIRST",X)
|
|
S XBDLAST=XBDLAST_","_XBDFIRST
|
|
D SSNR
|
|
S DIE="^AUPNMCR(",DA=DFN,DR=".03///"_XBSSN_";.14///"_XBDLAST_";2101///"_$P(^DPT(DFN,0),U,1)_";2102///"_$P(^DPT(DFN,0),U,3) D ^DIE
|
|
I $D(Y) S ^XTMP("SAN","FAILURE","PATMEDICARE",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
PI ;
|
|
Q:'$D(^AUPNPRVT(DFN))
|
|
Q:'$D(^AUPNPRVT(DFN,11))
|
|
S XBMDFN=0 F S XBMDFN=$O(^AUPNPRVT(DFN,11,XBMDFN)) Q:XBMDFN'=+XBMDFN D
|
|
.S $P(^AUPNPRVT(DFN,11,XBMDFN,0),U,2)=XBSSN
|
|
.S $P(^AUPNPRVT(DFN,11,XBMDFN,0),U,4)=XBNAME
|
|
.S $P(^AUPNPRVT(DFN,11,XBMDFN,0),U,12)=""
|
|
.S $P(^AUPNPRVT(DFN,11,XBMDFN,0),U,14)=""
|
|
Q
|
|
;
|
|
RR ;
|
|
Q:'$D(^AUPNRRE(DFN))
|
|
S X=^XTMP("SAN",$J,"DLAST") D R S XBDLAST=^XTMP("SAN",$J,"DLAST",X)
|
|
S X=^XTMP("SAN",$J,"DFIRST") D R S XBDFIRST=^XTMP("SAN",$J,"DFIRST",X)
|
|
S XBDLAST=XBDLAST_","_XBDFIRST
|
|
D SSNR
|
|
S DIE="^AUPNRRE(",DA=DFN,DR=".04///"_XBSSN_";.14///"_XBDLAST_";2101///"_$P(^DPT(DFN,0),U,1)_";2102///"_$P(^DPT(DFN,0),U,3) D ^DIE
|
|
I $D(Y) S ^XTMP("SAN","FAILURE","PATRAILROAD",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
MCD ;
|
|
S XBMDFN=0 F S XBMDFN=$O(^AUPNMCD("B",DFN,XBMDFN)) Q:XBMDFN'=+XBMDFN D
|
|
.S X=^XTMP("SAN",$J,"DLAST") D R S XBDLAST=^XTMP("SAN",$J,"DLAST",X)
|
|
.S X=^XTMP("SAN",$J,"DFIRST") D R S XBDFIRST=^XTMP("SAN",$J,"DFIRST",X)
|
|
.S DIE="^AUPNMCD(",DA=XBMDFN,DR=".05///@;.12///@;.13///@" D ^DIE
|
|
.D ^XBFMK
|
|
.S XBDNAME=XBDLAST_","_XBDFIRST
|
|
.D SSNR
|
|
.S DIE="^AUPNMCD(",DA=XBMDFN,DR=".03///"_XBSSN_";.14///"_XBDNAME_";2101///"_$P(^DPT(DFN,0),U,1)_";2102///"_$P(^DPT(DFN,0),U,3)_";.05///"_$P(^DPT(DFN,0),U,1) D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATMEDICAID",DA)=""
|
|
.D ^XBFMK
|
|
Q
|
|
XBCHART ;
|
|
S XBH=0 F S XBH=$O(^AUPNPAT(DFN,41,XBH)) Q:XBH'=+XBH S XBCHART=XBCHART+1 D
|
|
.S DA=XBH,DIE="^AUPNPAT("_DFN_",41,",DA(1)=DFN,DR=".02///"_XBCHART D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATCHART",DFN)=""
|
|
.D ^XBFMK
|
|
Q
|
|
F209 ;
|
|
I $P($G(^DPT(DFN,0)),U,9)="" Q
|
|
D SSNR
|
|
S DIE="^DPT(",DA=DFN,DR=".09///"_XBSSN D ^DIE
|
|
I $D(Y) S DA=DFN,DIE="^DPT(",DR=".09///@" D ^DIE
|
|
I $D(Y) S ^XTMP("SAN","FAILURE","PATSSN",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
F2219 ;nok phone
|
|
I $P($G(^DPT(DFN,.21)),U,9)]"" D PHNR D ;S $P(^DPT(DFN,.21),U,9)="555-888-"_XBPHN
|
|
.S XBPHN="555-888-"_XBPHN
|
|
.S DIE="^DPT(",DA=DFN,DR=".219///"_XBPHN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATPHONE",DFN)=""
|
|
.D ^XBFMK
|
|
I $P($G(^DPT(DFN,.33)),U,9)]"" D PHNR D ;S $P(^DPT(DFN,.33),U,9)="555-888-"_XBPHN
|
|
.S XBPHN="555-888-"_XBPHN
|
|
.S DIE="^DPT(",DA=DFN,DR=".339///"_XBPHN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATPHONE1",DFN)=""
|
|
.D ^XBFMK
|
|
Q
|
|
F2131 ;
|
|
I $P($G(^DPT(DFN,.13)),U,1)]"" D PHNR D
|
|
.S XBPHN="555-555-"_XBPHN
|
|
.S DIE="^DPT(",DA=DFN,DR=".131///"_XBPHN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATPHONE2",DFN)=""
|
|
.D ^XBFMK
|
|
Q
|
|
F2132 ;
|
|
Q:$P($G(^DPT(DFN,.13)),U,2)="" ;no office phone
|
|
D PHNR S XBPHN="555-999-"_XBPHN
|
|
S DIE="^DPT(",DA=DFN,DR=".132///"_XBPHN D ^DIE
|
|
I $D(Y) S ^XTMP("SAN","FAILURE","PATPHONE3",DFN)=""
|
|
D ^XBFMK
|
|
Q
|
|
;
|
|
DELP ;delete patients with no visits
|
|
;S XBCNT=0,XBP=0 F S XBP=$O(^DPT(XBP)) Q:XBP'=+XBP D
|
|
;.Q:$D(^AUPNVSIT("AC",XBP))
|
|
;.S DA=XBP,DIK="^DPT(" D ^DIK
|
|
;.S DA=XBP,DIK="^AUPNPAT(" D ^DIK
|
|
;.W DA,":" S XBCNT=XBCNT+1
|
|
;.Q
|
|
;W !,XBCNT
|
|
;Q
|
|
CLEAN ;
|
|
K ^XTMP("SAN",$J,"FIRSTM")
|
|
K ^XTMP("SAN",$J,"FIRSTF")
|
|
K ^XTMP("SAN",$J,"ADL1")
|
|
K ^XTMP("SAN",$J,"NOKADL")
|
|
K ^XTMP("SAN","FAILURE")
|
|
K ^XTMP("SAN",$J,"DLAST")
|
|
K ^XTMP("SAN",$J,"DFIRST")
|
|
K ^XTMP("SAN","PROCESS","DUZ")
|
|
K ^XTMP("SAN","DUZFAILURE")
|
|
D ^XBKVAR
|
|
S (XBC(1),XBC(2))=0,XBX=1 F S XBX=$O(^VA(200,XBX)) Q:+XBX=0 D
|
|
.S XBNAME=$P($G(^VA(200,XBX,0)),U,1)
|
|
.S XBLAST=$P(XBNAME,",",1) S:'$L(XBLAST) XBLAST="MOUSE"
|
|
.S XBFIRST=$P(XBNAME,",",2) S:'$L(XBFIRST) XBFIRST="MICKEY"_+XBX
|
|
.S XBC(1)=XBC(1)+1,^XTMP("SAN",$J,"DLAST")=XBC(1),^XTMP("SAN",$J,"DLAST",XBC(1))=XBLAST
|
|
.S XBC(2)=XBC(2)+1,^XTMP("SAN",$J,"DFIRST")=XBC(2),^XTMP("SAN",$J,"DFIRST",XBC(2))=XBFIRST
|
|
D ^XBKVAR
|
|
F I=1:1:5 S XBC(I)=0
|
|
S Y=0 F S Y=$O(^DPT(Y)) Q:+Y=0 D
|
|
.S XBVAL=$G(^DPT(Y,0))
|
|
.S XBNAME=$P(XBVAL,U,1)
|
|
.S XBLAST=$P(XBNAME,",",1)
|
|
.S XBFIRST=$P(XBNAME,",",2)
|
|
.S XBSEX=$P(XBVAL,U,2)
|
|
.S XBADL1=$P($G(^DPT(Y,.11)),U,1)
|
|
.S XBNOKADL=$P($G(^DPT(Y,.33)),U,3)
|
|
SET .S XBC(1)=XBC(1)+1,^XTMP("SAN",$J,"LAST")=XBC(1),^XTMP("SAN",$J,"LAST",XBC(1))=XBLAST
|
|
.I $L(XBSEX) S:XBSEX="M" XBC(2)=XBC(2)+1,^XTMP("SAN",$J,"FIRSTM")=XBC(2),^XTMP("SAN",$J,"FIRSTM",XBC(2))=XBFIRST
|
|
.I $L(XBSEX) S:XBSEX="F" XBC(3)=XBC(3)+1,^XTMP("SAN",$J,"FIRSTF")=XBC(3),^XTMP("SAN",$J,"FIRSTF",XBC(3))=XBFIRST
|
|
.I $L(XBADL1) S XBC(5)=XBC(5)+1,^XTMP("SAN",$J,"ADL1")=XBC(5),^XTMP("SAN",$J,"ADL1",XBC(5))=XBADL1
|
|
.I $L(XBNOKADL) S XBC(5)=XBC(5)+1,^XTMP("SAN",$J,"ADL1")=XBC(5),^XTMP("SAN",$J,"ADL1",XBC(5))=XBNOKADL
|
|
Q
|
|
R S X2=$R(X) I X2=0 G R
|
|
S X=X2
|
|
Q
|
|
;
|
|
DUZ ;SCRAMBLES USER NAMES
|
|
K ^XTMP("SAN","FAILURE","DUZ")
|
|
K ^XTMP("SAN","FAILURE","DUZA")
|
|
DUZA D ^XBFMK
|
|
S XBX=1 F S XBX=$O(^VA(200,XBX)) Q:+XBX=0 D
|
|
.S X=^XTMP("SAN",$J,"DLAST") D R S XBLAST=^XTMP("SAN",$J,"DLAST",X)
|
|
.S X=^XTMP("SAN",$J,"DFIRST") D R S XBFIRST=^XTMP("SAN",$J,"DFIRST",X)
|
|
.D DUZSSN
|
|
.;W !,$P(^VA(200,XBX,0),"^",1)," ",XBLAST," ",XBFIRST,$P($G(^VA(200,XBX,1)),"^",9)," ",DUZSSN
|
|
.I DUZSSN S DA=XBX,DIE=200,DR=".01///"_XBLAST_","_XBFIRST_";9///"_DUZSSN D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","DUZ",XBX)=""
|
|
.I 'DUZSSN S DA=XBX,DIE=200,DR=".01///"_XBLAST_","_XBFIRST D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","DUZ",XBX)=""
|
|
.S DA=XBX,DIE=200,DR=";1///"_$E(XBLAST,1,3)_";13///"_$E(XBLAST,1,8) D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","DUZINITIALS",XBX)=""
|
|
.S XBVANUM=1000000+XBX
|
|
.S XBDEANUM=2000000+XBX
|
|
.S DA=XBX,DIE=200,DR=";53.2///"_XBDEANUM_";53.3///"_XBVANUM D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","DUZDEAVA",XBX)=""
|
|
.D ^XBFMK
|
|
S ^XTMP("SAN","PROCESS","DUZ")="FINISHED"
|
|
Q
|
|
DUZSSN ;CHANGES SSN FOR USER FILE
|
|
S DUZSSN=$P($G(^VA(200,XBX,1)),"^",9)
|
|
I DUZSSN D DUZSSNR S DUZSSN=XBSSN
|
|
Q
|
|
DUZSSNR ;FIND RANDOM SSN
|
|
F S XBSSN=$R(999999999) Q:XBSSN>100000000&(XBSSN<800000000)
|
|
I $D(^VA(200,"SSN",XBSSN)) G DUZSSNR
|
|
Q
|
|
ALLSSN ;ADDS SSN TO EVERY PATIENT
|
|
D ^XBFMK
|
|
S XBX=0 F S XBX=$O(^DPT(XBX)) Q:+XBX=0 D
|
|
.Q:$L($P($G(^DPT(XBX,0)),"^",9))
|
|
.D SSNR
|
|
.S DA=XBX,DIE=2,DR=".09///"_XBSSN D ^DIE K DIE,DA
|
|
.D ^XBFMK
|
|
S ^XTMP("SAN","PROCESS","SSN-ALL")="FINISHED"
|
|
Q
|
|
SSNR ;FIND RANDOM SSN
|
|
F S XBSSN=$R(999999999) Q:XBSSN>100000000&(XBSSN<800000000)
|
|
I $D(^DPT("SSN",XBSSN)) G SSNR
|
|
Q
|
|
PHNR ;FIND RANDOM PHONE
|
|
F S XBPHN=$R(9999) Q:XBPHN>1000&(XBPHN<9999)
|
|
Q
|
|
;
|
|
PATDEL ;
|
|
S DFN=0 F S DFN=$O(^DPT(DFN)) Q:DFN'=+DFN D
|
|
.I $P($G(^DPT(DFN,0)),U,10)]"" S DA=DFN,DIE=2,DR=".091///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL091",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.101)),U,1)]"" S DA=DFN,DIE=2,DR=".101///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL101",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.111)),U,1)]"" S DA=DFN,DIE=2,DR=".1181///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1181",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.111)),U,2)]"" S DA=DFN,DIE=2,DR=".1182///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1182",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.111)),U,3)]"" S DA=DFN,DIE=2,DR=".1183///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1183",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.111)),U,4)]"" S DA=DFN,DIE=2,DR=".1184///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1184",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.111)),U,5)]"" S DA=DFN,DIE=2,DR=".1185///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1185",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.111)),U,6)]"" S DA=DFN,DIE=2,DR=".1186///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1186",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.111)),U,7)]"" S DA=DFN,DIE=2,DR=".1187///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1187",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.12)),U,1)]"" S DA=DFN,DIE=2,DR=".121///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL121",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.12)),U,2)]"" S DA=DFN,DIE=2,DR=".122///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL122",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.12)),U,3)]"" S DA=DFN,DIE=2,DR=".123///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL123",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.12)),U,4)]"" S DA=DFN,DIE=2,DR=".124///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL124",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.12)),U,5)]"" S DA=DFN,DIE=2,DR=".125///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL125",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.12)),U,6)]"" S DA=DFN,DIE=2,DR=".126///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL126",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.12)),U,7)]"" S DA=DFN,DIE=2,DR=".127///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL127",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.121)),U,1)]"" S DA=DFN,DIE=2,DR=".1211///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1211",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.121)),U,2)]"" S DA=DFN,DIE=2,DR=".1212///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PAT1212",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.121)),U,3)]"" S DA=DFN,DIE=2,DR=".1213///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PAT1213",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.121)),U,4)]"" S DA=DFN,DIE=2,DR=".1214///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PAT1214",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.121)),U,5)]"" S DA=DFN,DIE=2,DR=".1215///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PAT1215",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.121)),U,6)]"" S DA=DFN,DIE=2,DR=".1216///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1216",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.121)),U,7)]"" S DA=DFN,DIE=2,DR=".1217///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1217",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.121)),U,8)]"" S DA=DFN,DIE=2,DR=".1218///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1218",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.121)),U,10)]"" S DA=DFN,DIE=2,DR=".1219///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1219",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.111)),U,1)]"" S DA=DFN,DIE=2,DR=".1181///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1181",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.13)),U,3)]"" S DA=DFN,DIE=2,DR=".133///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL133",DFN)="" D ^XBFMK
|
|
.I $P($G(^DPT(DFN,.13)),U,4)]"" S DA=DFN,DIE=2,DR=".134///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL134",DFN)="" D ^XBFMK
|
|
.I $P($G(^AUPNPAT(DFN,3)),U,2)]"" S DA=DFN,DIE="AUPNPAT(",DR=".32///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL32",DFN)="" D ^XBFMK
|
|
.I $P($G(^AUPNPAT(DFN,11)),U,18)]"" S DA=DFN,DIE="AUPNPAT(",DR="1118///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL1118",DFN)="" D ^XBFMK
|
|
.I $P($G(^AUPNPAT(DFN,26)),U,2)]"" S DA=DFN,DIE="AUPNPAT(",DR="2602///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL2602",DFN)="" D ^XBFMK
|
|
.I $P($G(^AUPNPAT(DFN,26)),U,5)]"" S DA=DFN,DIE="AUPNPAT(",DR="2605///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL2605",DFN)="" D ^XBFMK
|
|
.I $P($G(^AUPNPAT(DFN,99999999)),U,1)]"" S DA=DFN,DIE="AUPNPAT(",DR="99999999///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","PATDEL99999999",DFN)="" D ^XBFMK
|
|
.F X=12:1:15 K ^AUPNPAT(DFN,X)
|
|
.K ^AUPNPAT(DFN,42)
|
|
S ^XTMP("SAN","PROCESS","PATDELETEDATA")="FINISHED"
|
|
Q
|
|
POSDEL ;
|
|
S XBX=0 F S XBX=$O(^ABSPC(XBX)) Q:+XBX=0 D
|
|
.S DA=XBX,DIK="^ABSPC(" D ^DIK,^XBFMK
|
|
S XBX=0 F S XBX=$O(^ABSPR(XBX)) Q:+XBX=0 D
|
|
.S DA=XBX,DIK="^ABSPR(" D ^DIK,^XBFMK
|
|
S DA=1,DIE="ABSP(9002313.56,",DR=".01///OUTPATIENT SITE;.02///12345;.03///456789;.05///123456789;.06///987654"
|
|
D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","POSDELETE",DA)="" D ^XBFMK
|
|
K ^ABSP(9002313.56,1,"ADDR")
|
|
K ^ABSP(9002313.56,1,"INSURER-ASSIGNED #")
|
|
K ^ABSP(9002313.56,1,"OPSITE")
|
|
S ^XTMP("SAN","PROCESS","POSDEL")="FINNISHED"
|
|
Q
|
|
AR ;
|
|
D ^XBFMK S U="^",XBA=0 F S XBA=$O(^BARBL(XBA)) Q:+XBA=0 D
|
|
.S XBB=0 F S XBB=$O(^BARBL(XBA,XBB)) Q:+XBB=0 D
|
|
..I $P($G(^BARBL(XBA,XBB,0)),U,12)]"" S DA=XBB,DIE="90050.01",DUZ(2)=XBA,DR="12///@" D ^DIE,^XBFMK
|
|
..I $P($G(^BARBL(XBA,XBB,1)),U,5)]"" D
|
|
...D SSNR S DA=XBB,DIE="90050.01",DUZ(2)=XBA,DR="105///"_XBSSN D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","AR105",DA)="" D ^XBFMK
|
|
..I $P($G(^BARBL(XBA,XBB,1)),U,6)]"" S DA=XBB,DIE="90050.01",DUZ(2)=XBA,DR="106///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","AR106",DA)="" D ^XBFMK
|
|
..I $P($G(^BARBL(XBA,XBB,1)),U,7)]"" D
|
|
...D SSNR S XBTEN=$E(XBSSN,1,5),DA=XBB,DIE="90050.01",DUZ(2)=XBA,DR="107///"_XBTEN D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","AR107E",DA)="" D ^XBFMK
|
|
..I $P($G(^BARBL(XBA,XBB,1)),U,16)]"" S DA=XBB,DIE="90050.01",DUZ(2)=XBA,DR="116///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","AR116",DA)="" D ^XBFMK
|
|
..I $P($G(^BARBL(XBA,XBB,2)),U,3)]"" S DA=XBB,DIE="90050.01",DUZ(2)=XBA,DR="203///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","AR203",DA)="" D ^XBFMK
|
|
..I $P($G(^BARBL(XBA,XBB,2)),U,4)]"" S DA=XBB,DIE="90050.01",DUZ(2)=XBA,DR="204///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","AR204",DA)="" D ^XBFMK
|
|
..I $P($G(^BARBL(XBA,XBB,2)),U,16)]"" S DA=XBB,DIE="90050.01",DUZ(2)=XBA,DR="216///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","AR216",DA)="" D ^XBFMK
|
|
..I $P($G(^BARBL(XBA,XBB,2)),U,17)]"" S DA=XBB,DIE="90050.01",DUZ(2)=XBA,DR="217///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","AR217",DA)="" D ^XBFMK
|
|
..S DUZ(2)=XBA K ^BARBL(DUZ(2),XBB,10),^BARBL(DUZ(2),XBB,5),^BARBL(DUZ(2),XBB,6)
|
|
..I $P($G(^BARBL(XBA,XBB,7)),U,1)]"" S DA=XBB,DIE="90050.01",DUZ(2)=XBA,DR="701///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","AR701",DA)="" D ^XBFMK
|
|
..I $P($G(^BARBL(XBA,XBB,7)),U,2)]"" S DA=XBB,DIE="90050.01",DUZ(2)=XBA,DR="702///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","AR702",DA)="" D ^XBFMK
|
|
S ^XTMP("SAN","PROCESS","AR-BILL")="FINISHED"
|
|
S XBA=0 F S XBA=$O(^BARCOL(XBA)) Q:+XBA=0 D
|
|
.S XBB=0 F S XBB=$O(^BARCOL(XBA,XBB)) Q:+XBB=0 K ^BARTR(XBA,XBB,10)
|
|
S ^XTMP("SAN","PROCESS","AR-TRAN")="FINISHED"
|
|
S XBA=0 F S XBA=$O(^BARCOL(XBA)) Q:+XBA=0 D
|
|
.S XBB=0 F S XBB=$O(^BARCOL(XBA,XBB)) Q:+XBB=0 D
|
|
..S XBC=0 F S XBC=$O(^BARCOL(XBA,XBB,"1",XBC)) Q:+XBC=0 D
|
|
...I $P($G(^BARCOL(XBA,XBB,1,XBC,0)),U,12)]"" S DIE="^BARCOL(XBA,XBB,1,",DA=XBC,DA(1)=XBB,DUZ(2)=XBA,DR="12///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","ARCOL12",DA)="" D ^XBFMK
|
|
...I $P($G(^BARCOL(XBA,XBB,1,XBC,0)),U,13)]"" S DIE="^BARCOL(XBA,XBB,1,",DA=XBC,DA(1)=XBB,DUZ(2)=XBA,DR="13///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","ARCOL13",DA)="" D ^XBFMK
|
|
...I $P($G(^BARCOL(XBA,XBB,1,XBC,0)),U,14)]"" S DIE="^BARCOL(XBA,XBB,1,",DA=XBC,DA(1)=XBB,DUZ(2)=XBA,DR="14///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","ARCOL14",DA)="" D ^XBFMK
|
|
...K ^BARCOL(XBA,XBB,"1",XBC,5)
|
|
S ^XTMP("SAN","PROCESS","AR-COLL")="FINISHED"
|
|
S XBA=0 F S XBA=$O(^BAREDI("I",XBA)) Q:+XBA=0 D
|
|
.S XBB=0 F S XBB=$O(^BAREDI("I",XBA,XBB)) Q:+XBB=0 D
|
|
..S DIK="^BAREDI(""I"",XBA,",DA=XBB,DUZ(2)=XBA=XBA D ^DIK,^XBFMK
|
|
S ^XTMP("SAN","PROCESS","AR-EDIIMP")="FINISHED"
|
|
S XBA=0 F S XBA=$O(^BAREDI("C",XBA)) Q:+XBA=0 D
|
|
.S XBB=0 F S XBB=$O(^BAREDI("C",XBA,XBB)) Q:+XBB=0 D
|
|
..I $P($G(^BAREDI("C",XBA,XBB,0)),U,3)]"" S DIE="^BAREDI(""C"",XBA,XBB,",DA=XBB,DUZ(2)=XBA,DR=".03///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","BAREDI03",DA)="" D ^XBFMK
|
|
S ^XTMP("SAN","PROCESS","AR-EDIC")="FINISHED"
|
|
S XBA=0 F S XBB=$O(^BAR835(XBA)) Q:+XBA=0 D
|
|
.I $P($G(^BAR835(XBA,1)),U,1)]"" S DIE="^BAR835,",DA=XBA,DR=".11///@" D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","AR11",DA)="" D ^XBFMK
|
|
S ^XTMP("SAN","PROCESS","AR-EDI835")="FINISHED"
|
|
Q
|
|
TPB ;3RD PARTY BILLING
|
|
D ^XBFMK
|
|
S U="^",XBA=0 F S XBA=$O(^ABMDCLM(XBA)) Q:+XBA=0 D
|
|
.S XBB=0 F S XBB=$O(^ABMDCLM(XBA,XBB)) Q:+XBB=0 D
|
|
..I $L($P($G(^ABMDCLM(XBA,XBB,8)),U,8)) D
|
|
...S X=^XTMP("SAN",$J,"DLAST") D R S XBLAST=^XTMP("SAN",$J,"DLAST",X)
|
|
...S X=^XTMP("SAN",$J,"DFIRST") D R S XBFIRST=^XTMP("SAN",$J,"DFIRST",X)
|
|
...S DA=XBB,DIE="9002274.3",DUZ(2)=XBA,DR=".88///"_XBLAST_","_XBFIRST D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","ABM88",DA)="" D ^XBFMK
|
|
..I $L($P($G(^ABMDCLM(XBA,XBB,8)),U,11)) D
|
|
...S DA=XBB,DIE="9002274.3",DUZ(2)=XBA,DR=".885///"_(100000+DA) D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","ABM885",DA)="" D ^XBFMK
|
|
..I $L($P($G(^ABMDCLM(XBA,XBB,9)),U,12)) D
|
|
...S X=^XTMP("SAN",$J,"DLAST") D R S XBLAST=^XTMP("SAN",$J,"DLAST",X)
|
|
...S X=^XTMP("SAN",$J,"DFIRST") D R S XBFIRST=^XTMP("SAN",$J,"DFIRST",X)
|
|
...S DA=XBB,DIE="9002274.3",DUZ(2)=XBA,DR=".912///"_XBLAST_","_XBFIRST D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","ABM912",DA)="" D ^XBFMK
|
|
S ^XTMP("SAN","PROCESS","3P-CLAIM")="FINISHED"
|
|
S XBA=0 F S XBA=$O(^ABMDBILL(XBA)) Q:+XBA=0 D
|
|
.S XBB=0 F S XBB=$O(^ABMDBILL(XBA,XBB)) Q:+XBB=0 D
|
|
..I $L($P($G(^ABMDBILL(XBA,XBB,8)),U,8)) D
|
|
...S X=^XTMP("SAN",$J,"DLAST") D R S XBLAST=^XTMP("SAN",$J,"DLAST",X)
|
|
...S X=^XTMP("SAN",$J,"DFIRST") D R S XBFIRST=^XTMP("SAN",$J,"DFIRST",X)
|
|
...S DA=XBB,DIE="9002274.4",DUZ(2)=XBA,DR=".88///"_XBLAST_","_XBFIRST D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","ABM88",DA)="" D ^XBFMK
|
|
..I $L($P($G(^ABMDBILL(XBA,XBB,8)),U,11)) D
|
|
...S DA=XBB,DIE="9002274.4",DUZ(2)=XBA,DR=".885///"_(200000+DA) D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","ABM885",DA)="" D ^XBFMK
|
|
..I $L($P($G(^ABMDBILL(XBA,XBB,9)),U,12)) D
|
|
...S X=^XTMP("SAN",$J,"DLAST") D R S XBLAST=^XTMP("SAN",$J,"DLAST",X)
|
|
...S X=^XTMP("SAN",$J,"DFIRST") D R S XBFIRST=^XTMP("SAN",$J,"DFIRST",X)
|
|
...S DA=XBB,DIE="9002274.4",DUZ(2)=XBA,DR=".912///"_XBLAST_","_XBFIRST D ^DIE S:$D(Y) ^XTMP("SAN","FAILURE","ABM912",DA)="" D ^XBFMK
|
|
S ^XTMP("SAN","PROCESS","3P-BILL")="FINISHED"
|
|
Q
|
|
LAB ;
|
|
S X=0 F S X=$O(^LR(X)) Q:X'=+X D
|
|
.S Y=0 F S Y=$O(^LR(X,"CH",Y)) Q:Y'=+Y D
|
|
..I $D(^LR(X,"CH",Y,1)) S Z=$P(^LR(X,"CH",Y,1,0),U,1,2) K ^LR(X,"CH",Y,1) S ^LR(X,"CH",Y,1,0)=Z
|
|
.S Y=0 F S Y=$O(^LR(X,"MI",Y)) Q:Y'=+Y D
|
|
..I $D(^LR(X,"MI",Y,4)) S Z=$P(^LR(X,"MI",Y,4,0),U,1,2) K ^LR(X,"MI",Y,4) S ^LR(X,"MI",Y,4,0)=Z
|
|
..I $D(^LR(X,"MI",Y,19)) S Z=$P(^LR(X,"MI",Y,19,0),U,1,2) K ^LR(X,"MI",Y,19) S ^LR(X,"MI",Y,19,0)=Z
|
|
..I $D(^LR(X,"MI",Y,20)) S Z=$P(^LR(X,"MI",Y,20,0),U,1,2) K ^LR(X,"MI",Y,20) S ^LR(X,"MI",Y,20,0)=Z
|
|
..I $D(^LR(X,"MI",Y,21)) S Z=$P(^LR(X,"MI",Y,21,0),U,1,2) K ^LR(X,"MI",Y,21) S ^LR(X,"MI",Y,21,0)=Z
|
|
..I $D(^LR(X,"MI",Y,22)) S Z=$P(^LR(X,"MI",Y,22,0),U,1,2) K ^LR(X,"MI",Y,22) S ^LR(X,"MI",Y,22,0)=Z
|
|
..I $D(^LR(X,"MI",Y,23)) S Z=$P(^LR(X,"MI",Y,23,0),U,1,2) K ^LR(X,"MI",Y,23) S ^LR(X,"MI",Y,23,0)=Z
|
|
..K ^LR(X,"MI",Y,99)
|
|
S X=0 F S X=$O(^LRO(69,X)) Q:X'=+X D
|
|
.I $D(^LRO(69,X,1,"AL")) K ^LRO(69,X,1,"AL")
|
|
.I $D(^LRO(69,X,1,"AP")) K ^LRO(69,X,1,"AP")
|
|
.I $D(^LRO(69,X,1,"AR")) K ^LRO(69,X,1,"AR")
|
|
S X=$P(^BLRTXLOG(0),U,1,2) K ^BLRTXLOG S ^BLRTXLOG(0)=X
|
|
S ^XTMP("SAN","PROCESS","LAB")="FINISHED"
|
|
D ^LROC
|
|
Q
|
|
LISTE ;
|
|
W !,"Listed below are the nodes and number of records that did not"
|
|
W !,"update properly. At the end of the sanitization, the records"
|
|
W !,"for Patient Name failures are rerun. PATNAME2 nodes represent"
|
|
W !,"Patient Names that should be manually changed with fileman."
|
|
W !,"XTMP(""SAN"",""PROCESS"") nodes:"
|
|
W !,"XTMP(""SAN"",""FAILURE"") nodes:"
|
|
S X="" F S X=$O(^XTMP("SAN","FAILURE",X)) Q:X="" D
|
|
.S (Y,Z)=0 F S Y=$O(^XTMP("SAN","FAILURE",X,Y)) Q:+Y=0 D
|
|
..S Z=Z+1
|
|
.W !,"Failure: "_X_" "_Z
|
|
W !,"FINISHED" Q
|
|
LISTD ;
|
|
W !,"Listed below are the processes completed."
|
|
W !,"XTMP(""SAN"",""PROCESS"") nodes:"
|
|
S X="" F S X=$O(^XTMP("SAN","PROCESS",X)) Q:X="" D
|
|
.W !,"Process: "_X
|
|
W !,"FINISHED" Q
|
|
MCDE ;
|
|
S DFN=0 F S DFN=$O(^AUPNMCD("B",DFN)) Q:+DFN=0 D
|
|
.S XBMDFN=0 F S XBMDFN=$O(^AUPNMCD("B",DFN,XBMDFN)) Q:XBMDFN'=+XBMDFN D
|
|
..S X=^XTMP("SAN",$J,"DLAST") D R S XBDLAST=^XTMP("SAN",$J,"DLAST",X)
|
|
..S X=^XTMP("SAN",$J,"DFIRST") D R S XBDFIRST=^XTMP("SAN",$J,"DFIRST",X)
|
|
..S DIE="^AUPNMCD(",DA=XBMDFN,DR=".05///@;.12///@;.13///@" D ^DIE
|
|
..I $D(Y) S ^XTMP("SAN","FAILURE","PATMCDEA",DA)=""
|
|
..D ^XBFMK
|
|
..S XBDNAME=XBDLAST_","_XBDFIRST
|
|
..D SSNR
|
|
..S DIE="^AUPNMCD(",DA=XBMDFN,DR=".03///"_XBSSN_";.14///"_XBDNAME_";2101///"_$P(^DPT(DFN,0),U,1)_";2102///"_$P(^DPT(DFN,0),U,3)_";.05///"_$P(^DPT(DFN,0),U,1) D ^DIE
|
|
..I $D(Y) S ^XTMP("SAN","FAILURE","PATMCDEB",DA)=""
|
|
..D ^XBFMK
|
|
S ^XTMP("SAN","PROCESS","MCD")="FINISHED"
|
|
Q
|
|
MMDEL ;DELETES MAILMAN MESSAGES
|
|
K ^XMB(3.9)
|
|
S ^XMB(3.9,0)="MESSAGE^3.9s^0^0"
|
|
Q
|
|
AUDEL ;DELETES AUDIT FILE
|
|
K ^DIA
|
|
S ^DIA(0)="AUDIT^1.1|"
|
|
Q
|
|
NCDEL ;DELETES NAME COMPONENTS FILE
|
|
K ^VA(20)
|
|
S ^VA(20,0)="NAME COMPONENTS^20IA^^"
|
|
Q
|
|
STU ;SETS STUDENT NAMES
|
|
K ^XTMP("SAN","FAILURE","STU")
|
|
K ^XTMP("SAN","FAILURE","STUA")
|
|
STUA D ^XBFMK
|
|
S XBX=50 F S XBX=$O(^VA(200,XBX)) Q:+XBX>76 D
|
|
.S XBLAST=$E("ABCDEFGHIJKLMNOPQRSTUVWXYZ",XBX-50,XBX-50)_"STUDENT"
|
|
.S XBFIRST="USER"
|
|
.S DA=XBX,DIE=200,DR=".01///"_XBLAST_","_XBFIRST D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","STU",XBX)=""
|
|
.S DA=XBX,DIE=200,DR="1///"_$E(XBLAST,1,2)_"U;13///"_$E(XBLAST,1,8) D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","STUINITIALS",XBX)=""
|
|
.S DA=XBX,DIE=200,DR="201///`29" D ^DIE I $D(Y) S ^XTMP("SAN","FAILURE","STUMENU",XBX)=""
|
|
.D ^XBFMK
|
|
W !,"FINISHED"
|
|
Q
|
|
FJADD1 ;
|
|
S DFN=0 F S DFN=$O(^XTMP("SAN","FAILURE","PATADDRESS",DFN)) Q:+DFN=0 I $P($G(^DPT(DFN,.11)),U,1)]"" D
|
|
.S XBADDR=DFN_" SMITH STREET"
|
|
.S DIE="^DPT(",DR=".111///"_XBADDR,DA=DFN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATADDRESSFJ",DFN)=""
|
|
.D ^XBFMK
|
|
.S $P(^DPT(DFN,.11),U,2)="" ;addr 2nd line
|
|
.S $P(^DPT(DFN,.11),U,3)="" ;addr 3rd line
|
|
Q
|
|
A2213 ;
|
|
I $P($G(^DPT(DFN,.21)),U,3)]"" D
|
|
.S X=^XTMP("SAN",$J,"ADL1") D R S XBADDR=^XTMP("SAN",$J,"ADL1",X)
|
|
.S DIE="^DPT(",DR=".213///"_XBADDR,DA=DFN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATADDRESSL11",DFN)=""
|
|
.D ^XBFMK
|
|
I $P($G(^DPT(DFN,.33)),U,3)]"" D
|
|
.S X=^XTMP("SAN",$J,"ADL1") D R S XBADDR=^XTMP("SAN",$J,"ADL1",X)
|
|
.S DIE="^DPT(",DR=".333.//"_XBADDR,DA=DFN D ^DIE
|
|
.I $D(Y) S ^XTMP("SAN","FAILURE","PATADDRESSL111",DFN)=""
|
|
.D ^XBFMK
|
|
Q
|
|
A2219 ;nok phone
|
|
S DFN=0 F S DFN=$O(^XTMP("SAN","FAILURE","PATPHONE",DFN)) Q:+DFN=0 I $P($G(^DPT(DFN,.21)),U,9)]"" D
|
|
.S $P(^DPT(DFN,.21),U,9)="555-888-"_$E(DFN_"9999",1,4)
|
|
Q
|
|
S DFN=0 F S DFN=$O(^XTMP("SAN","FAILURE","PATPHONE1",DFN)) Q:+DFN=0 I $P($G(^DPT(DFN,.33)),U,9)]"" D
|
|
.S $P(^DPT(DFN,.33),U,9)="555-888-"_$E(DFN_"9999",1,4)
|
|
Q
|