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