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

PSO7P274.m

Go to the documentation of this file.
  1. PSO7P274 ;SMT - PSO*7*274 Activity Log Cleanup ; 10/11/07 12:16pm
  1. ;;7.0;OUTPATIENT PHARMACY;**274**;APR 2007;Build 8
  1. ;
  1. ;Cleanup routine, to fix erroneous listings of partials in the
  1. ;activity log.
  1. ;
  1. N NAMSP,PATCH,JOBN,DTOUT,DUOUT,ZTSK,ZTRTN,ZTIO,ZTDTH,ZTDESC,QUIT,Y,ZTQUEUED,ZTREQ,ZTSAVE
  1. S NAMSP=$$NAMSP
  1. S JOBN="Activity Log Cleanup"
  1. S PATCH="PSO*7*274"
  1. ;
  1. L +^XTMP(NAMSP):$S($G(DILOCKTM)>0:DILOCKTM,1:3) I '$T D Q
  1. . D BMES^XPDUTL(JOBN_" job is already running. Halting...")
  1. . D MES^XPDUTL("")
  1. . D QUIT
  1. ;
  1. I '$D(^XTMP(NAMSP)) D INITXTMP(NAMSP,JOBN_", "_PATCH,90) ;90 day life
  1. S QUIT=0
  1. ;
  1. I $G(^XTMP(NAMSP,0,"LAST"))["COMPLETED" D Q
  1. . W !!,*7,"This job has been run before to completion on "
  1. . W $$FMTE^XLFDT($P($G(^XTMP(NAMSP,0,"LAST")),"^",2)),!!
  1. . W "If you want to run it again, the global subscript ^XTMP('"_NAMSP_"') must be",!
  1. . W "deleted prior to doing so.",!!
  1. . D QUIT
  1. ;
  1. ;ques 2, if running from mumps prompt
  1. I '$D(XPDQUES("POS2")) D I 'ZTDTH D QUIT Q
  1. . K DIR
  1. . S DIR("A")=" Enter when to Queue the "_JOBN_" job to run in date@time format "
  1. . S DIR("B")="NOW"
  1. . S DIR(0)="D^::%DT"
  1. . 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"
  1. . D ^DIR I $D(DUOUT) W !,"Halting..." S ZTDTH="" Q
  1. . S:$D(DTOUT) Y=$$NOW^XLFDT S ZTDTH=$$FMTH^XLFDT(Y)
  1. ;
  1. ;ques 2, if running from kids install
  1. I $D(XPDQUES("POS2")) S ZTDTH=$$FMTH^XLFDT(XPDQUES("POS2"))
  1. ;
  1. D BMES^XPDUTL("=============================================================")
  1. D MES^XPDUTL("Queuing background job for "_JOBN_"...")
  1. D MES^XPDUTL("Start time: "_$$HTE^XLFDT(ZTDTH))
  1. D MES^XPDUTL("==============================================================")
  1. I ZTDTH="" D BMES^XPDUTL(JOBN_" NOT QUEUED") D QUIT Q
  1. ;
  1. S:$D(^XTMP(NAMSP,0,"LAST")) ^XTMP(NAMSP,0,"ZAUDIT",$H)="RE-STARTED ON"_"^"_$$NOW^XLFDT_"^"_$P(^XTMP(NAMSP,0,"LAST"),"^",2,5)
  1. ;
  1. I $P($G(^XTMP(NAMSP,0,"LAST")),"^")="STOP" D
  1. . S $P(^XTMP(NAMSP,0,"LAST"),"^",1,2)="RUN^"_$$NOW^XLFDT
  1. E D
  1. . S ^XTMP(NAMSP,0,"LAST")="RUN^"_$$NOW^XLFDT_"^^^"
  1. ;
  1. S ZTRTN="EN^"_NAMSP,ZTIO=""
  1. S ZTDESC="Background job for "_JOBN_" on prescriptions updated via "_PATCH
  1. S ZTSAVE("JOBN")=""
  1. L -^XTMP(NAMSP)
  1. D ^%ZTLOAD
  1. D:$D(ZTSK)
  1. . D MES^XPDUTL("*** Task #"_ZTSK_" Queued! ***")
  1. . D BMES^XPDUTL("")
  1. D BMES^XPDUTL("")
  1. K XPDQUES
  1. Q
  1. QUIT ;
  1. L -^XTMP(NAMSP)
  1. Q
  1. ;
  1. STATUS ;show status of job running
  1. I $$ST D
  1. . W !,"Currently processing:"
  1. . I $G(^XTMP($$NAMSP,0,"LAST"))["COMPLETED" D
  1. . . W !,"COMPLETED ON ",$$FMTE^XLFDT($P($G(^XTMP($$NAMSP,0,"LAST")),"^",2)),!
  1. . W !?5,"Date being processed > ",$$FMTE^XLFDT($P(^XTMP($$NAMSP,0,"LAST"),"^",3))
  1. . W !?5," RX # > ",$P(^XTMP($$NAMSP,0,"LAST"),"^",4)
  1. . ;W !?5," TOTAL RX's > ",$P(^XTMP($$NAMSP,0,"LAST"),"^",5),!
  1. E D
  1. .I $G(^XTMP($$NAMSP,0,"LAST"))["COMPLETED" D
  1. .. W !,"COMPLETED ON ",$$FMTE^XLFDT($P($G(^XTMP($$NAMSP,0,"LAST")),"^",2)),!
  1. Q
  1. ;
  1. STOP ;stop job command
  1. I $$ST S ^XTMP($$NAMSP,0,"STOP")="" D
  1. . W !,"TALLY MISSING EXPIRATION DATES Job - set to STOP Soon"
  1. . W !!,"Check Status to be sure it has stopped and is not running..."
  1. . W !," (D STATUS^PSOTEXP1)"
  1. Q
  1. ST() ;status
  1. L +^XTMP($$NAMSP):3 I $T D Q 0
  1. . L -^XTMP($$NAMSP)
  1. . W !,"*** NOT CURRENTLY RUNNING! ***",!
  1. Q 1
  1. INITXTMP(NAMSP,TITLE,LIFE) ;create ^Xtmp according to SAC std
  1. N BEGDT,PURGDT
  1. S BEGDT=$$NOW^XLFDT()
  1. S PURGDT=$$FMADD^XLFDT(BEGDT,LIFE)
  1. S ^XTMP(NAMSP,0)=PURGDT_"^"_BEGDT_"^"_TITLE
  1. Q
  1. NAMSP() ;
  1. Q $T(+0)
  1. ;
  1. EN ;
  1. N C,CC,CNT ;Clean erroneous activity log partials
  1. S (C,CNT)=0 F S C=$O(^PSRX(C)),CNT=CNT+1 Q:'C I $D(^PSRX(C,"A",0)) D
  1. .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
  1. Q