| 1 | QACI2 ; OAKOIFO/TKW - DATA MIGRATION - BUILD SUPPORTING TABLE AND ROC DATA TO MIGRATE ;1/24/07  17:14 | 
|---|
| 2 | ;;2.0;Patient Representative;**19**;07/25/1995;Build 55 | 
|---|
| 3 | EN ; Main entry point for building both legacy supporting table data | 
|---|
| 4 | ; and ROC data to be migrated. Skip entries that have already | 
|---|
| 5 | ; been migrated. | 
|---|
| 6 | ; | 
|---|
| 7 | I $P($G(^XTMP("QACMIGR","AUTO","C")),"^",2)=1 W !!,"*** CAUTION! Another user is trying to auto-close ROCs. Allow the process to",!,"finish before moving data. ***" | 
|---|
| 8 | ; Make sure list of valid sites has been downloaded from the EMC | 
|---|
| 9 | I '$D(^XTMP("QACMIGR","STDINSTITUTION")) D STAERR Q | 
|---|
| 10 | I '$D(^XTMP("QACMIGR","AUTO","C")) W !!,"** No Contacts were Auto-Closed. **" | 
|---|
| 11 | Q:$$ASK^QACI2A("")'=1 | 
|---|
| 12 | ; If called from ^QACI0 (pre-migration error report), QACI0 will be set to 1. | 
|---|
| 13 | N QACI0 S QACI0=0 | 
|---|
| 14 | ; Kill Taskman task that rolls up data to Austin for VSSC reports, Put Patient Rep menus OUT OF ORDER | 
|---|
| 15 | I '$$EN1^QACI5 Q | 
|---|
| 16 | ; | 
|---|
| 17 | EN0 ; Entry point from ^QACI0 (Just check for errors, don't save data to staging area for migration) | 
|---|
| 18 | ; If called from ^QACI0, QACI0 will be set to 1. | 
|---|
| 19 | ; | 
|---|
| 20 | ; Get QA Site Parameter station number, and VISN Name | 
|---|
| 21 | N PARENT,VISNNAME D PARVISN^QACI2A(.PARENT,.VISNNAME) | 
|---|
| 22 | I VISNNAME="" W !!,"QA Site Parameter Station Number or VISN cannot be found!" Q | 
|---|
| 23 | I $L(PARENT)'=3 W !!,"QA Site Parameter Station Number not 3 digits!" Q | 
|---|
| 24 | ; | 
|---|
| 25 | N TYPE,ROCIEN,ROC0,ROC2,ROC7,ROCNO,OLDROC,CONDATE,DFN,STATION,INFOBY,ENTBY,CC,EMPINV,FSOS,ROCISS,ISSIEN,PATSDT,HL,CE,MOC,MOCSTR,TS,PHONE,PHDESC,PATID,RESDATE,INTAPPL | 
|---|
| 26 | N CURRDT,EDITEBY,EDITIBY,EDITDIV,EDITITXT,EDITRTXT,ITXTCNT,ITXTLN,ELIGSTAT,CATEGORY,CCNAME,PATSDUZ2,DOTCNT,PATSCNT,PATSERR,SRVRSTA,RLUPSTAT,QACDIV,DIK,DA,I,X | 
|---|
| 27 | ; PATSDT will be current date in a format Oracle will recognize | 
|---|
| 28 | S CURRDT=$$DT^XLFDT() | 
|---|
| 29 | S PATSDT=$$FMTE^XLFDT(CURRDT,5) | 
|---|
| 30 | ; Set header node for migration data. Data will be automatically purged in 30 days. | 
|---|
| 31 | S $P(^XTMP("QACMIGR",0),"^",1,2)=$$FMADD^XLFDT(CURRDT,30)_"^"_CURRDT | 
|---|
| 32 | S DOTCNT=199 | 
|---|
| 33 | ; Kill existing lists of data to be migrated and set counters to 0. | 
|---|
| 34 | F TYPE="ROC","HL","USER","PT","CC","EMPINV","FSOS" D | 
|---|
| 35 | . K ^XTMP("QACMIGR",TYPE,"U"),^("E") | 
|---|
| 36 | . S PATSCNT(TYPE)=0 Q | 
|---|
| 37 | ; Retrieve and save station data (IA #1518) | 
|---|
| 38 | D  I SRVRSTA="" W !!,"Server Station Number cannot be found!" Q | 
|---|
| 39 | . S SRVRSTA=$$STA^XUAF4(+$$GET1^DIQ(8989.3,1,217,"I")) Q:SRVRSTA="" | 
|---|
| 40 | . ; load list of divisions from MEDICAL CENTER DIVISION file for error checking | 
|---|
| 41 | . F I=0:0 S I=$O(^DG(40.8,I)) Q:'I  S X=$P($G(^(I,0)),"^",7) S:X QACDIV(X)="" | 
|---|
| 42 | . ; Quit if only running CHK option. | 
|---|
| 43 | . Q:QACI0 | 
|---|
| 44 | . ; Put VISN and Computing facility data from QAC SITE PARAMETERS into output global | 
|---|
| 45 | . ; for ROC and Facility Service or Section. | 
|---|
| 46 | . S ^XTMP("QACMIGR","FSOS","U",0)=VISNNAME | 
|---|
| 47 | . S ^XTMP("QACMIGR","ROC","U",0)=VISNNAME_"^"_PARENT_"^"_SRVRSTA | 
|---|
| 48 | . ; Save computing station number for server in ROC and User nodes | 
|---|
| 49 | . S ^XTMP("QACMIGR","USER","U",0)=SRVRSTA | 
|---|
| 50 | . S ^XTMP("QACMIGR","EMPINV","U",0)=SRVRSTA Q | 
|---|
| 51 | I SRVRSTA'=PARENT W !!,"QA Site Parameter Station Number not the same as Computing Station!" Q | 
|---|
| 52 | ; Build mapping lists for contacting_entity, method_of_contact, treatment_status. | 
|---|
| 53 | D CEMOCTS^QACI2A | 
|---|
| 54 | ; Build temporary list of valid Migrated Issue Codes | 
|---|
| 55 | I '$G(^XTMP("QACMIGR","ISS","D")) D BLDISS^QACI2A | 
|---|
| 56 | ; | 
|---|
| 57 | ; Build Reference Tables Lists for Congressional Contact | 
|---|
| 58 | D BLDCC^QACI2A(PARENT,.PATSCNT) | 
|---|
| 59 | ; | 
|---|
| 60 | ; | 
|---|
| 61 | ; Read through ROCs, check for errors, and if QACI0'=1 move data to staging area. | 
|---|
| 62 | D ^QACI20 | 
|---|
| 63 | ; If not called from ^QACI0, update the counts of migrated data. | 
|---|
| 64 | I 'QACI0 D UPDCNT^QACI2E(.PATSCNT) | 
|---|
| 65 | ; Update the counts of errors. | 
|---|
| 66 | D UPDERRCT^QACI2E | 
|---|
| 67 | ; Print error report | 
|---|
| 68 | D ERRPT^QACI2E(QACI0) | 
|---|
| 69 | Q | 
|---|
| 70 | ; | 
|---|
| 71 | ENLDSTA(PATSBY,QACSLIST) ; Load list of stations from sdsadm.std_institution table | 
|---|
| 72 | ; PATSBY is set to 1 if this runs to completion, to 0 otherwise. | 
|---|
| 73 | ; QACSLIST is an input array of station numbers | 
|---|
| 74 | S PATSBY=0 | 
|---|
| 75 | I $O(QACSLIST(""))="" Q | 
|---|
| 76 | K ^XTMP("QACMIGR","STDINSTITUTION") | 
|---|
| 77 | ; Set header node for migration data. Data will be automatically purged in 30 days. | 
|---|
| 78 | I '$D(^XTMP("QACMIGR")) D | 
|---|
| 79 | . N CURRDT S CURRDT=$$DT^XLFDT() | 
|---|
| 80 | . S $P(^XTMP("QACMIGR",0),"^",1,2)=$$FMADD^XLFDT(CURRDT,30)_"^"_CURRDT | 
|---|
| 81 | . Q | 
|---|
| 82 | N I,QACSTA S I="" | 
|---|
| 83 | F  S I=$O(QACSLIST(I)) Q:I=""  S QACSTA=QACSLIST(I) D:QACSTA]"" | 
|---|
| 84 | . S ^XTMP("QACMIGR","STDINSTITUTION",QACSTA)="" | 
|---|
| 85 | . Q | 
|---|
| 86 | S PATSBY=1 | 
|---|
| 87 | Q | 
|---|
| 88 | ; | 
|---|
| 89 | STAERR ; Display error if national stations not downloaded from EMC | 
|---|
| 90 | W !!,"*** You must first run the option to download the list of nationally ***",! | 
|---|
| 91 | W "*** recognized stations. See the PATS Data Migration Guide. ***" Q | 
|---|
| 92 | ; | 
|---|
| 93 | ; | 
|---|