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

XMA30.m

Go to the documentation of this file.
  1. XMA30 ;ISC-SF/GMB-XMCLEAN, XMAUTOPURGE (cont.) ;01/08/2003 10:04
  1. ;;8.0;MailMan;**10,13**;Jun 28, 2002
  1. ; Was (WASH ISC)/CAP
  1. AUDIT ; Lists data from previous purges
  1. N XMLIEN,XMREC,XMSTART,XMEND,XMLEFT,XMPURGE,XMTYPE,XMABORT
  1. S XMABORT=0
  1. W @IOF
  1. D BLD^DIALOG(36432,"","","XMTEXT","F")
  1. D MSG^DIALOG("WM","","","","XMTEXT")
  1. ;It's a good idea to look these over.
  1. ;Look for multiple purges running concurrently and missing purge dates.
  1. ;Check the times the purge ended - do they conflict with user activity?
  1. W !
  1. D AHDR
  1. S XMLIEN=0
  1. F S XMLIEN=$O(^XMB(1,1,.1,XMLIEN)) Q:XMLIEN'>0 D Q:XMABORT
  1. . I $Y+3>IOSL D Q:XMABORT
  1. . . I $E(IOST,1,2)="C-" D PAGE^XMXUTIL(.XMABORT) Q:XMABORT
  1. . . W @IOF D AHDR
  1. . S XMREC=^XMB(1,1,.1,XMLIEN,0)
  1. . S XMSTART=$E($P(XMREC,U),1,12)
  1. . S XMLEFT=$P(XMREC,U,2)
  1. . S XMPURGE=$P(XMREC,U,3)
  1. . S XMTYPE=$P(XMREC,U,6)
  1. . S XMEND=$E($P(XMREC,U,8),1,12)
  1. . I XMTYPE="",'XMEND D ; To handle old data before XM*7.1*37
  1. . . S XMEND=XMSTART
  1. . . K XMSTART
  1. . W !,$$EZBLD^DIALOG($S(+XMTYPE=0:36433,XMTYPE=1:36434,1:36435)) ; "Unref Msg" / "Date" / "Test Date"
  1. . W ?12,$S($D(XMSTART):$J($$FMTE^XLFDT(XMSTART,5),16),1:""),$J($$FMTE^XLFDT(XMEND,5),18)
  1. . I $D(XMSTART),XMEND>XMSTART W $J($$FMDIFF^XLFDT(XMEND,XMSTART,3),10)
  1. . W ?58,$J(XMPURGE,9),$J(XMLEFT,12)
  1. Q
  1. AHDR ;
  1. N XMTEXT
  1. D BLD^DIALOG(36436,"","","XMTEXT","F")
  1. D MSG^DIALOG("WM","",IOM,"","XMTEXT")
  1. W !
  1. ;MailMan Purge History
  1. ;Type Start End Duration Purged Kept
  1. Q
  1. USERSTAT ; Display statistics
  1. N DIR,Y,XMTYPE,ZTSAVE,XMVAR,XMTEXT,XMDIALOG,XMI
  1. W !
  1. S XMVAR(2)=$O(^XMB(3.9,":"),-1) ; highest
  1. S XMVAR(1)=$J($O(^XMB(3.9,0)),$L(XMVAR(2))) ; lowest
  1. S XMVAR(3)=$J($P($G(^XMB(3.9,0)),U,4),$L(XMVAR(2))) ; how many
  1. D BLD^DIALOG(36437,.XMVAR,"","XMTEXT","F")
  1. D MSG^DIALOG("WM","","","","XMTEXT")
  1. ;Lowest numbered message: |1|
  1. ;Highest numbered message: |2|
  1. ;Number of messages: |3|
  1. D BLD^DIALOG(36438,"","","DIR(""A"")") ; Scan Option
  1. ;A:Active Mailboxes;I:Inactive Mailboxes;M:All Mailboxes"
  1. S DIR(0)="S^"
  1. F XMI=36439.1,36439.2,36439.3 D
  1. . S XMDIALOG(XMI)=$$EZBLD^DIALOG(XMI)
  1. . S DIR(0)=DIR(0)_XMDIALOG(XMI)_";"
  1. S DIR(0)=$E(DIR(0),1,$L(DIR(0))-1)
  1. S DIR("B")=$P(XMDIALOG(36439.1),":",2) ; Active Mailboxes
  1. D ^DIR Q:$D(DIRUT)
  1. S XMI=0 F S XMI=$O(XMDIALOG(XMI)) Q:$P(XMDIALOG(XMI),":",1)=Y
  1. S XMTYPE=$S(XMI=36439.1:"A",XMI=36439.2:"I",1:"M")
  1. S XMTYPE("DESC")=$P(XMDIALOG(XMI),":",2)
  1. S ZTSAVE("XMTYPE")="",ZTSAVE("XMTYPE(")=""
  1. D EN^XUTMDEVQ("DOSTATS^XMA30",$$EZBLD^DIALOG(36440),.ZTSAVE) ; MailMan: User Mailbox Statistics
  1. Q
  1. DOSTATS ;
  1. N XMTODAY,XMPAGE,XMABORT,XMDUZ,XMK,XMINCNT,XMZCNT,XMKCNT,XMBOXCNT,XMLMAIL,XMNAME,XMREC,XMSTAT,XMLSIGN,XMINACT
  1. S XMTODAY=$$FMTE^XLFDT(DT,5),(XMPAGE,XMABORT,XMBOXCNT)=0
  1. S:$D(ZTQUEUED) ZTREQ="@"
  1. W:$E(IOST,1,2)="C-" @IOF D SHDR(XMTODAY,.XMPAGE)
  1. S XMNAME="",XMINACT=$$EZBLD^DIALOG(36441) ; "Inactive"
  1. F S XMNAME=$O(^VA(200,"B",XMNAME)) Q:XMNAME="" D Q:XMABORT
  1. . S XMDUZ=0
  1. . F S XMDUZ=$O(^VA(200,"B",XMNAME,XMDUZ)) Q:XMDUZ="" D Q:XMABORT
  1. . . Q:'$D(^XMB(3.7,XMDUZ))
  1. . . S XMREC=$G(^VA(200,XMDUZ,0))
  1. . . I $P(XMREC,U,3)="" Q:XMTYPE="A" S XMSTAT=XMINACT
  1. . . E I XMTYPE="I" Q
  1. . . E S XMSTAT=""
  1. . . I $Y+3>IOSL D Q:XMABORT
  1. . . . I $E(IOST,1,2)="C-" D PAGE^XMXUTIL(.XMABORT) Q:XMABORT
  1. . . . W @IOF D SHDR(XMTODAY,.XMPAGE)
  1. . . S XMBOXCNT=XMBOXCNT+1
  1. . . W !,$E($$NAME^XMXUTIL(XMDUZ),1,30)
  1. . . S XMK=.9,(XMINCNT,XMZCNT)=0
  1. . . F XMKCNT=1:1 S XMK=$O(^XMB(3.7,XMDUZ,2,XMK)) Q:XMK'>0 D
  1. . . . D:'$D(^XMB(3.7,XMDUZ,2,XMK,1,0)) MAKENODE
  1. . . . I XMK=1 S XMINCNT=+$P($G(^XMB(3.7,XMDUZ,2,XMK,1,0)),U,4),XMZCNT=XMINCNT Q
  1. . . . S XMZCNT=XMZCNT+$P($G(^XMB(3.7,XMDUZ,2,XMK,1,0)),U,4)
  1. . . S XMLSIGN=$P($G(^VA(200,XMDUZ,1.1)),U)
  1. . . S XMLSIGN=$S(XMSTAT'="":XMSTAT,'XMLSIGN:$$EZBLD^DIALOG(38002),1:$J($$MMDT^XMXUTIL1($P(XMLSIGN,".")),8)) ; Never
  1. . . S XMLMAIL=$P($G(^XMB(3.7,XMDUZ,"L")),U)
  1. . . S XMLMAIL=$S(XMLMAIL["@":$P(XMLMAIL,"@"),1:$P(XMLMAIL," ",1,3))
  1. . . W ?30,$J(XMKCNT,4),$J(XMZCNT,7),$J(XMINCNT,8),?53,XMLSIGN,?67,$S($L(XMLMAIL):XMLMAIL,1:$$EZBLD^DIALOG(38002)) ; Never
  1. Q:XMABORT
  1. W !!,XMTYPE("DESC"),": ",XMBOXCNT
  1. I $E(IOST,1,2)="C-" D WAIT^XMXUTIL
  1. Q
  1. MAKENODE ; Create the zero node for the message multiple
  1. N XMCNT,XMZ
  1. Q:'$O(^XMB(3.7,XMDUZ,2,XMK,1,0))
  1. S (XMZ,XMCNT)=0
  1. F S XMZ=$O(^XMB(3.7,XMDUZ,2,XMK,1,XMZ)) Q:XMZ'>0 S XMCNT=XMCNT+1
  1. S ^XMB(3.7,XMDUZ,2,XMK,1,0)="^3.702P^"_+$O(^XMB(3.7,XMDUZ,2,XMK,1,"C"),-1)_U_XMCNT
  1. Q
  1. SHDR(XMTODAY,XMPAGE) ; Header for Mailbox Statistics Report
  1. S XMPAGE=XMPAGE+1
  1. W XMTYPE("DESC"),", ",XMTODAY,?65,$J($$EZBLD^DIALOG(34542,XMPAGE),15) ; Page |1|
  1. D BLD^DIALOG(36443,"","","XMTEXT","F")
  1. D MSG^DIALOG("WM","",IOM,"","XMTEXT")
  1. W !
  1. ;User Bskts Msgs IN Bskt Last Sign on Last Mail Use"
  1. Q
  1. DONTPURG ; Find all messages which might not be in someone's mailbox,
  1. ; but which shouldn't be purged anyway.
  1. N XMDUZ,XMZ,XMZR,XMQ,XMT,XMD,XMINST,XMG
  1. K ^TMP("XM",$J)
  1. ;
  1. ; DON'T PURGE LOCAL MESSAGES AND REPLIES WHICH ARE ABOUT TO BE DELIVERED
  1. ;
  1. S (XMT,XMG,XMZ)="" ; new messages, forwarded messages, and replies
  1. F S XMT=$O(^XMBPOST("BOX",XMT)) Q:XMT="" D
  1. . F S XMG=$O(^XMBPOST("BOX",XMT,XMG)) Q:XMG="" D
  1. . . F S XMZ=$O(^XMBPOST("BOX",XMT,XMG,XMZ)) Q:XMZ="" S ^TMP("XM",$J,"NOP",+XMZ)="" I XMG="R" S ^TMP("XM",$J,"NOP",$P(XMZ,U,2))=""
  1. ;
  1. ; new messages, forwarded messages
  1. S (XMQ,XMT,XMZ)="" ; Queue number, Timestamp, Message IEN
  1. F S XMQ=$O(^XMBPOST("M",XMQ)) Q:XMQ="" D
  1. . F S XMT=$O(^XMBPOST("M",XMQ,XMT)) Q:XMT="" D
  1. . . F S XMZ=$O(^XMBPOST("M",XMQ,XMT,XMZ)) Q:XMZ="" S ^TMP("XM",$J,"NOP",+XMZ)=""
  1. ;
  1. ; replies
  1. S (XMQ,XMZ,XMZR)="" ; Queue number, Message IEN, Reply IEN
  1. F S XMQ=$O(^XMBPOST("R",XMQ)) Q:XMQ="" D
  1. . S XMT="" ; Timestamp
  1. . F S XMT=$O(^XMBPOST("R",XMQ,XMT)) Q:XMT'>0 D
  1. . . F S XMZ=$O(^XMBPOST("R",XMQ,XMT,XMZ)) Q:XMZ="" D
  1. . . . S ^TMP("XM",$J,"NOP",XMZ)="" ; Original msg to new replies
  1. . . . F S XMZR=$O(^XMBPOST("R",XMQ,XMT,XMZ,XMZR)) Q:XMZR="" S ^TMP("XM",$J,"NOP",XMZR)="" ; Reply
  1. ;
  1. ; DON'T PURGE MESSAGES QUEUED TO BE DELIVERED REMOTELY
  1. S XMINST=999 ; Institution
  1. F S XMINST=$O(^XMB(3.7,.5,2,XMINST)) Q:XMINST'>0 D
  1. . S XMZ=0
  1. . F S XMZ=$O(^XMB(3.7,.5,2,XMINST,1,XMZ)) Q:XMZ'>0 S ^TMP("XM",$J,"NOP",XMZ)=""
  1. ;
  1. ; DON'T PURGE LATER'D MESSAGES
  1. S XMD=0 ; Date to be later'd
  1. F S XMD=$O(^XMB(3.73,XMD)) Q:XMD'>0 D
  1. . S XMZ=$P(^XMB(3.73,XMD,0),U,3)
  1. . S:XMZ ^TMP("XM",$J,"NOP",XMZ)="" ; Msg to be later'd
  1. ;
  1. ; DON'T PURGE MESSAGES WHICH ARE BEING EDITED
  1. S (XMDUZ,XMZ)=""
  1. F S XMDUZ=$O(^XMB(3.7,"AD",XMDUZ)) Q:XMDUZ="" D
  1. . F S XMZ=$O(^XMB(3.7,"AD",XMDUZ,XMZ)) Q:XMZ="" S ^TMP("XM",$J,"NOP",XMZ)=""
  1. ;
  1. ; DON'T PURGE MESSAGES WHICH ARE TO BE DELIVERED LATER TO CERTAIN RECIPIENTS
  1. S (XMD,XMZ)=""
  1. F S XMD=$O(^XMB(3.9,"AL",XMD)) Q:XMD="" D
  1. . F S XMZ=$O(^XMB(3.9,"AL",XMD,XMZ)) Q:XMZ="" S ^TMP("XM",$J,"NOP",XMZ)=""
  1. Q