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
|
---|