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

BPSOSK.m

Go to the documentation of this file.
  1. BPSOSK ;BHAM ISC/FCS/DRS/DLF - Winnow ECME data ;06/01/2004
  1. ;;1.0;E CLAIMS MGMT ENGINE;**1,5**;JUN 2004;Build 45
  1. ;;Per VHA Directive 2004-038, this routine should not be modified.
  1. Q
  1. ;
  1. ; MAIN
  1. MAIN ;
  1. ; Set lock so only one job is running at a time
  1. L +^TMP($T(+0)):0 Q:'$T
  1. ;
  1. ; New the common variables
  1. N SLOT,TESTING
  1. ;
  1. ; Initialize the log and store slot in BPS Setup
  1. ; Also keep previous two logs.
  1. S SLOT=DT+.5
  1. D LOG^BPSOSL(SLOT,"Start Purge","DT")
  1. ;
  1. S TESTING=$$GET1^DIQ(9002313.99,1,2341.01,"I")
  1. I TESTING D LOG^BPSOSL(SLOT,"Test Mode - no data will be deleted")
  1. I 'TESTING D LOG^BPSOSL(SLOT,"Purge Mode - data may be deleted")
  1. ;
  1. ; Delete the log file
  1. N FILE,AGE,IEN,UPDT,IENS,MSG,FDA,ENDDT
  1. S FILE=9002313.12
  1. ;
  1. ; Log start message
  1. D LOG^BPSOSL(SLOT,"Winnowing file BPS LOG")
  1. ;
  1. ; Get number of days to keep on the system
  1. S AGE=$$GET1^DIQ(9002313.99,1,2341.03)
  1. I 'AGE D
  1. . S AGE=365
  1. . I '$D(^BPS(9002313.99,1)) Q
  1. . N DIE,DA,DR,DTOUT
  1. . S DIE=9002313.99,DA=1,DR="2341.03///"_AGE
  1. . D ^DIE
  1. ;
  1. ; Calculate end date of purge
  1. N X,X1,X2
  1. S X1=DT,X2=(AGE*-1) D C^%DTC
  1. S ENDDT=X
  1. D LOG^BPSOSL(SLOT,"AGE is "_AGE_". End Date is "_ENDDT)
  1. ;
  1. ; Loop through data and delete it
  1. S UPDT="" F S UPDT=$O(^BPS(FILE,"AC",UPDT)) Q:UPDT'<ENDDT!(UPDT="") D
  1. . S IEN="" F S IEN=$O(^BPS(FILE,"AC",UPDT,IEN)) Q:'IEN D
  1. .. S IENS=IEN_","
  1. .. ;
  1. .. ; Never delete the highest entry in a file
  1. .. ; This will prevent the re-use of IENs.
  1. .. I '$O(^BPS(FILE,IEN)) Q
  1. .. ;
  1. .. ; Log the message
  1. .. S MSG=$S(TESTING:" We would delete",1:" Deleting")
  1. .. S MSG=MSG_" record "_IEN_" - "_$P($G(^BPS(FILE,IEN,0)),U,1)
  1. .. D LOG^BPSOSL(SLOT,MSG)
  1. .. ;
  1. .. ; Quit if testing mode
  1. .. I TESTING Q
  1. .. ;
  1. .. ; Do the delete
  1. .. K FDA,MSG
  1. .. S FDA(FILE,IENS,.01)=""
  1. .. D FILE^DIE(,"FDA","MSG")
  1. .. I $D(MSG) D
  1. ... D LOG^BPSOSL(SLOT,"Deletion failed - MSG array returned:")
  1. ... D LOGARRAY^BPSOSL(SLOT,"MSG")
  1. .. ;
  1. .. ; Make sure the deletion worked: fetch the .01 field
  1. .. I $$GET1^DIQ(FILE,IENS,.01)]"" D LOG^BPSOSL(SLOT,"Deletion failed-record still defined")
  1. ;
  1. ; Log ending message
  1. D LOG^BPSOSL(SLOT,"Done with file BPS LOG")
  1. ;
  1. ; Unlock the job
  1. L -^TMP($T(+0))
  1. Q