| 1 | PSO7P274        ;SMT - PSO*7*274 Activity Log Cleanup ; 10/11/07 12:16pm
 | 
|---|
| 2 |         ;;7.0;OUTPATIENT PHARMACY;**274**;APR 2007;Build 8
 | 
|---|
| 3 |         ;
 | 
|---|
| 4 |         ;Cleanup routine, to fix erroneous listings of partials in the
 | 
|---|
| 5 |         ;activity log.
 | 
|---|
| 6 |         ;
 | 
|---|
| 7 |         N NAMSP,PATCH,JOBN,DTOUT,DUOUT,ZTSK,ZTRTN,ZTIO,ZTDTH,ZTDESC,QUIT,Y,ZTQUEUED,ZTREQ,ZTSAVE
 | 
|---|
| 8 |         S NAMSP=$$NAMSP
 | 
|---|
| 9 |         S JOBN="Activity Log Cleanup"
 | 
|---|
| 10 |         S PATCH="PSO*7*274"
 | 
|---|
| 11 |         ;
 | 
|---|
| 12 |         L +^XTMP(NAMSP):$S($G(DILOCKTM)>0:DILOCKTM,1:3) I '$T D  Q
 | 
|---|
| 13 |         . D BMES^XPDUTL(JOBN_" job is already running.  Halting...")
 | 
|---|
| 14 |         . D MES^XPDUTL("")
 | 
|---|
| 15 |         . D QUIT
 | 
|---|
| 16 |         ;
 | 
|---|
| 17 |         I '$D(^XTMP(NAMSP)) D INITXTMP(NAMSP,JOBN_", "_PATCH,90)        ;90 day life
 | 
|---|
| 18 |         S QUIT=0
 | 
|---|
| 19 |         ;
 | 
|---|
| 20 |         I $G(^XTMP(NAMSP,0,"LAST"))["COMPLETED" D  Q
 | 
|---|
| 21 |         . W !!,*7,"This job has been run before to completion on "
 | 
|---|
| 22 |         . W $$FMTE^XLFDT($P($G(^XTMP(NAMSP,0,"LAST")),"^",2)),!!
 | 
|---|
| 23 |         . W "If you want to run it again, the global subscript ^XTMP('"_NAMSP_"') must be",!
 | 
|---|
| 24 |         . W "deleted prior to doing so.",!!
 | 
|---|
| 25 |         . D QUIT
 | 
|---|
| 26 |         ;
 | 
|---|
| 27 |         ;ques 2, if running from mumps prompt
 | 
|---|
| 28 |         I '$D(XPDQUES("POS2")) D  I 'ZTDTH D QUIT Q
 | 
|---|
| 29 |         . K DIR
 | 
|---|
| 30 |         . S DIR("A")="  Enter when to Queue the "_JOBN_" job to run in date@time   format "
 | 
|---|
| 31 |         . S DIR("B")="NOW"
 | 
|---|
| 32 |         . S DIR(0)="D^::%DT"
 | 
|---|
| 33 |         . S DIR("?")="Enter when to start the job. The default is Now. You can enter a date and time in the format like this: 021506@3:30p"
 | 
|---|
| 34 |         . D ^DIR I $D(DUOUT) W !,"Halting..." S ZTDTH="" Q
 | 
|---|
| 35 |         . S:$D(DTOUT) Y=$$NOW^XLFDT S ZTDTH=$$FMTH^XLFDT(Y)
 | 
|---|
| 36 |         ;
 | 
|---|
| 37 |         ;ques 2, if running from kids install
 | 
|---|
| 38 |         I $D(XPDQUES("POS2")) S ZTDTH=$$FMTH^XLFDT(XPDQUES("POS2"))
 | 
|---|
| 39 |         ;
 | 
|---|
| 40 |         D BMES^XPDUTL("=============================================================")
 | 
|---|
| 41 |         D MES^XPDUTL("Queuing background job for "_JOBN_"...")
 | 
|---|
| 42 |         D MES^XPDUTL("Start time: "_$$HTE^XLFDT(ZTDTH))
 | 
|---|
| 43 |         D MES^XPDUTL("==============================================================")
 | 
|---|
| 44 |         I ZTDTH="" D BMES^XPDUTL(JOBN_" NOT QUEUED") D QUIT Q
 | 
|---|
| 45 |         ;
 | 
|---|
| 46 |         S:$D(^XTMP(NAMSP,0,"LAST")) ^XTMP(NAMSP,0,"ZAUDIT",$H)="RE-STARTED ON"_"^"_$$NOW^XLFDT_"^"_$P(^XTMP(NAMSP,0,"LAST"),"^",2,5)
 | 
|---|
| 47 |         ;
 | 
|---|
| 48 |         I $P($G(^XTMP(NAMSP,0,"LAST")),"^")="STOP" D
 | 
|---|
| 49 |         . S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="RUN^"_$$NOW^XLFDT
 | 
|---|
| 50 |         E  D
 | 
|---|
| 51 |         . S ^XTMP(NAMSP,0,"LAST")="RUN^"_$$NOW^XLFDT_"^^^"
 | 
|---|
| 52 |         ;
 | 
|---|
| 53 |         S ZTRTN="EN^"_NAMSP,ZTIO=""
 | 
|---|
| 54 |         S ZTDESC="Background job for "_JOBN_" on prescriptions updated via "_PATCH
 | 
|---|
| 55 |         S ZTSAVE("JOBN")=""
 | 
|---|
| 56 |         L -^XTMP(NAMSP)
 | 
|---|
| 57 |         D ^%ZTLOAD
 | 
|---|
| 58 |         D:$D(ZTSK)
 | 
|---|
| 59 |         . D MES^XPDUTL("*** Task #"_ZTSK_" Queued! ***")
 | 
|---|
| 60 |         . D BMES^XPDUTL("")
 | 
|---|
| 61 |         D BMES^XPDUTL("")
 | 
|---|
| 62 |         K XPDQUES
 | 
|---|
| 63 |         Q
 | 
|---|
| 64 | QUIT    ;
 | 
|---|
| 65 |         L -^XTMP(NAMSP)
 | 
|---|
| 66 |         Q
 | 
|---|
| 67 |         ;
 | 
|---|
| 68 | STATUS  ;show status of job running
 | 
|---|
| 69 |         I $$ST D
 | 
|---|
| 70 |         . W !,"Currently processing:"
 | 
|---|
| 71 |         . I $G(^XTMP($$NAMSP,0,"LAST"))["COMPLETED" D
 | 
|---|
| 72 |         . . W !,"COMPLETED ON ",$$FMTE^XLFDT($P($G(^XTMP($$NAMSP,0,"LAST")),"^",2)),!
 | 
|---|
| 73 |         . W !?5,"Date being processed > ",$$FMTE^XLFDT($P(^XTMP($$NAMSP,0,"LAST"),"^",3))
 | 
|---|
| 74 |         . W !?5,"                RX # > ",$P(^XTMP($$NAMSP,0,"LAST"),"^",4)
 | 
|---|
| 75 |         . ;W !?5,"          TOTAL RX's > ",$P(^XTMP($$NAMSP,0,"LAST"),"^",5),!
 | 
|---|
| 76 |         E  D
 | 
|---|
| 77 |         .I $G(^XTMP($$NAMSP,0,"LAST"))["COMPLETED" D
 | 
|---|
| 78 |         .. W !,"COMPLETED ON ",$$FMTE^XLFDT($P($G(^XTMP($$NAMSP,0,"LAST")),"^",2)),!
 | 
|---|
| 79 |         Q
 | 
|---|
| 80 |         ;
 | 
|---|
| 81 | STOP    ;stop job command
 | 
|---|
| 82 |         I $$ST S ^XTMP($$NAMSP,0,"STOP")="" D
 | 
|---|
| 83 |         . W !,"TALLY MISSING EXPIRATION DATES Job - set to STOP Soon"
 | 
|---|
| 84 |         . W !!,"Check Status to be sure it has stopped and is not running..."
 | 
|---|
| 85 |         . W !,"     (D STATUS^PSOTEXP1)"
 | 
|---|
| 86 |         Q
 | 
|---|
| 87 | ST()    ;status
 | 
|---|
| 88 |         L +^XTMP($$NAMSP):3 I $T D  Q 0
 | 
|---|
| 89 |         . L -^XTMP($$NAMSP)
 | 
|---|
| 90 |         . W !,"*** NOT CURRENTLY RUNNING! ***",!
 | 
|---|
| 91 |         Q 1
 | 
|---|
| 92 | INITXTMP(NAMSP,TITLE,LIFE)      ;create ^Xtmp according to SAC std
 | 
|---|
| 93 |         N BEGDT,PURGDT
 | 
|---|
| 94 |         S BEGDT=$$NOW^XLFDT()
 | 
|---|
| 95 |         S PURGDT=$$FMADD^XLFDT(BEGDT,LIFE)
 | 
|---|
| 96 |         S ^XTMP(NAMSP,0)=PURGDT_"^"_BEGDT_"^"_TITLE
 | 
|---|
| 97 |         Q
 | 
|---|
| 98 | NAMSP() ;
 | 
|---|
| 99 |         Q $T(+0)
 | 
|---|
| 100 |         ;
 | 
|---|
| 101 | EN      ;
 | 
|---|
| 102 |         N C,CC,CNT ;Clean erroneous activity log partials
 | 
|---|
| 103 |         S (C,CNT)=0 F  S C=$O(^PSRX(C)),CNT=CNT+1 Q:'C  I $D(^PSRX(C,"A",0)) D
 | 
|---|
| 104 |         .S CC=0 F  S CC=$O(^PSRX(C,"A",CC)) Q:'CC  S:($P(^PSRX(C,"A",CC,0),"^",4)=6)&('$D(^PSRX(C,"P",0))) $P(^PSRX(C,"A",CC,0),"^",4)=7
 | 
|---|
| 105 |         Q
 | 
|---|