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

XMXGRP1.m

Go to the documentation of this file.
  1. XMXGRP1 ;ISC-SF/GMB-Group creation/enrollment (cont.) ;04/17/2002 14:10
  1. ;;8.0;MailMan;;Jun 28, 2002
  1. FAFMSGS(XMDUZ,XMGRP,XMTO,XMINSTR,ZTSK) ; Create task to find and forward messages
  1. ; The following line can be deleted once we enable "A":
  1. S XMINSTR("FLAGS")=$TR($G(XMINSTR("FLAGS")),"A") Q:$G(XMINSTR("FLAGS"))'["F"
  1. N ZTSAVE,ZTDESC,ZTRTN,ZTDTH,ZTIO,I
  1. S ZTDESC=$$EZBLD^DIALOG(38023.8) ; MailMan: Find & Forward mail group messages
  1. S ZTIO="",ZTDTH=$H,ZTRTN="FAFTSK^XMXGRP1"
  1. F I="DUZ","XMDUZ","XMGRP*","XMTO*","XMINSTR(" S ZTSAVE(I)=""
  1. D ^%ZTLOAD
  1. Q
  1. FAFTSK ; Find and add/forward messages
  1. N XMFDATE,XMTDATE,XMGROUP,XMX,XMFIRST,XMABORT
  1. S XMABORT=0
  1. D INIT Q:XMABORT
  1. D PROCESS
  1. D CLEANUP^XMXADDR
  1. K ^TMP("XM",$J,"SAVE")
  1. Q
  1. PROCESS ;
  1. I XMINSTR("FLAGS")["A",XMINSTR("FLAGS")["F" D Q ; Forward some of the messages to the users, and add the users to the rest of the messages.
  1. . D SAVFWD(.XMX)
  1. . I XMFIRST<XMFDATE D
  1. . . D CHKADD(.XMX) Q:'$D(^TMP("XMY",$J))
  1. . . D ADDFWD(XMDUZ,.XMGROUP,"A",XMFIRST,XMFDATE-1,.XMX) ; add
  1. . . M ^TMP("XMY",$J)=^TMP("XM",$J,"SAVE")
  1. . D ADDFWD(XMDUZ,.XMGROUP,"F",XMFDATE,XMTDATE,.XMX) ; forward
  1. . I XMTDATE<DT D
  1. . . I XMX("RESTORE") M ^TMP("XMY",$J)=^TMP("XM",$J,"SAVE") S XMX("RESTORE")=0
  1. . . D CHKADD(.XMX) Q:'$D(^TMP("XMY",$J))
  1. . . D ADDFWD(XMDUZ,.XMGROUP,"A",XMTDATE+.1,DT,.XMX) ; add
  1. I XMINSTR("FLAGS")["F" D Q ; Just forward messages to users
  1. . D SAVFWD(.XMX)
  1. . D ADDFWD(XMDUZ,.XMGROUP,"F",XMFDATE,XMTDATE,.XMX) ; forward
  1. I XMINSTR("FLAGS")["A" D Q ; Just add users to messages
  1. . D CHKADD(.XMX) Q:'$D(^TMP("XMY",$J))
  1. . D ADDFWD(XMDUZ,.XMGROUP,"A",XMFDATE,XMTDATE,.XMX) ; add
  1. Q
  1. INIT ;
  1. N XMPRIVAT,XMGN,XMI
  1. S ZTREQ="@"
  1. S XMPRIVAT=$$EZBLD^DIALOG(39135) ; " [Private Mail Group]"
  1. S XMFIRST=$O(^XMB(3.9,"C",2500000)) ; earliest message date (after 1950!)
  1. S XMFDATE=$G(XMINSTR("FDATE"),XMFIRST)
  1. S XMTDATE=$G(XMINSTR("TDATE"),DT)
  1. D INITAPI^XMVVITAE
  1. D INIT^XMXADDR
  1. D CHKADDR^XMXADDR(XMDUZ,.XMTO)
  1. I '$$GOTADDR^XMXADDR S XMABORT=1 Q
  1. I $G(XMGRP)]"" S XMGRP(XMGRP)=$O(^XMB(3.8,"B",XMGRP,0))
  1. S XMGN=""
  1. F S XMGN=$O(XMGRP(XMGN)) Q:XMGN="" D
  1. . S XMI=XMGRP(XMGN)
  1. . S XMGROUP("G."_XMGN_$S($P($G(^XMB(3.8,XMI,0)),U,2)="PR":XMPRIVAT,1:""))=XMI
  1. K XMGRP
  1. I $D(XMINSTR("SELF BSKT")) S XMX("SELF BSKT")=XMINSTR("SELF BSKT")
  1. Q
  1. SAVFWD(XMX) ;
  1. S XMX("RESTORE")=0
  1. M ^TMP("XM",$J,"SAVE")=^TMP("XMY",$J)
  1. S XMX("ONE")=$O(^TMP("XMY",$J,"")) ; First recipient. Is it the only one?
  1. I $O(^TMP("XMY",$J,XMX("ONE")))'="" S XMX("ONE")=0 ; There's more than one recipient
  1. Q
  1. CHKADD(XMX) ;
  1. S XMX("FWDBY")=XMV("NAME")_$S(XMDUZ=DUZ:"",1:$$EZBLD^DIALOG(38008,XMV("DUZ NAME")))_" "_$$MMDT^XMXUTIL1($$NOW^XLFDT) ; " (Surrogate: _x_)"
  1. S XMI=0 ; Delete any remote addresses - responses won't be forwarded.
  1. F S XMI=$O(^TMP("XMY",$J,XMI)) Q:XMI="" K:+XMI'=XMI ^(XMI)
  1. Q
  1. ADDFWD(XMDUZ,XMGROUP,XMWHAT,XMFDATE,XMTDATE,XMX) ;
  1. N XMZ,XMCRE8,XMGN
  1. S XMZ=0
  1. S XMCRE8=XMFDATE-.1
  1. F S XMCRE8=$O(^XMB(3.9,"C",XMCRE8)) Q:'XMCRE8 Q:XMCRE8>XMTDATE D Q:$G(ZTSTOP)
  1. . I $$S^%ZTLOAD S ZTSTOP=1 Q
  1. . F S XMZ=$O(^XMB(3.9,"C",XMCRE8,XMZ)) Q:'XMZ D
  1. . . Q:$$ZCLOSED^XMXSEC(XMZ) ; Message is closed
  1. . . S XMGN=""
  1. . . F S XMGN=$O(XMGROUP(XMGN)) Q:XMGN="" Q:$S($L(XMGN)<31:$D(^XMB(3.9,XMZ,6,"B",XMGN)),$D(^XMB(3.9,XMZ,6,"B",$E(XMGN,1,30))):(XMGN=$P($G(^XMB(3.9,XMZ,6,+$O(^XMB(3.9,XMZ,6,"B",$E(XMGN,1,30),0)),0)),U,1)),1:0)
  1. . . Q:XMGN="" ; Message is not addressed to any of the groups
  1. . . I XMWHAT="F" D FWD(XMDUZ,XMZ,.XMX) Q
  1. . . D ADD(XMDUZ,XMZ,.XMX)
  1. Q
  1. FWD(XMDUZ,XMZ,XMX) ; Forward the message to the user
  1. N XMINSTR
  1. I $D(XMX("SELF BSKT")) S XMINSTR("SELF BSKT")=XMX("SELF BSKT")
  1. I XMX("ONE")'=0 Q:$D(^XMB(3.9,XMZ,1,"C",XMX("ONE"))) ; User already on msg.
  1. I XMX("ONE")=0 D Q:'$D(^TMP("XMY",$J))
  1. . I XMX("RESTORE") M ^TMP("XMY",$J)=^TMP("XM",$J,"SAVE") S XMX("RESTORE")=0
  1. . N XMI
  1. . S XMI=""
  1. . F S XMI=$O(^TMP("XMY",$J,XMI)) Q:XMI="" D
  1. . . Q:'$D(^XMB(3.9,XMZ,1,"C",XMI)) ; User not yet on msg.
  1. . . K ^TMP("XMY",$J,XMI) ; User on msg - don't forward to user.
  1. . . S XMX("RESTORE")=1
  1. D FWD^XMKP(XMDUZ,XMZ,.XMINSTR)
  1. Q
  1. ADD(XMDUZ,XMZ,XMX) ; Add user(s) to message.
  1. ; XMX("FWDBY")
  1. N XMI,XMFDA,XMIENS,XMPRI
  1. S XMPRI=$$ZPRI^XMXUTIL2(XMZ) ; Is msg priority?
  1. ; Put users into RECIPIENT multiple
  1. S XMI=0
  1. F S XMI=$O(^TMP("XMY",$J,XMI)) Q:'XMI D
  1. . Q:$D(^XMB(3.9,XMZ,1,"C",XMI)) ; User already on msg - don't add.
  1. . D NEW^XMKP(XMZ,XMPRI,XMI,$G(^TMP("XMY",$J,XMI,1)),.XMFDA,.XMIENS) ; New recipient
  1. . S XMFDA(3.91,XMIENS,8)=XMX("FWDBY") ; fwd by name date time
  1. . S XMFDA(3.91,XMIENS,8.01)=XMDUZ ; fwd by duz
  1. . ; Need new field that says 'parked until next reply'.
  1. . D UPDATE^DIE("","XMFDA")
  1. Q
  1. NOTIFY(XMG,XMNEWMBR) ; If the group is restricted in any way,
  1. ; notify the organizer & coordinator of the new members.
  1. N XMREC,XMTO,I
  1. S XMREC=^XMB(3.8,XMG,0)
  1. I $P(XMREC,U,2)="PU",$P(XMREC,U,3)="y" Q
  1. S I=$P($G(^XMB(3.8,XMG,3)),U) S:I XMTO(I)="" ; organizer
  1. S I=$P(XMREC,U,7) S:I XMTO(I)="" ; coordinator
  1. Q:$D(XMTO(DUZ))
  1. N XMPARM,XMTEXT,XMINSTR,XMNAME,J
  1. S I=0 F S I=$O(XMNEWMBR(I)) Q:'I S XMNAME($$NAME^XMXUTIL(I,1))=""
  1. S J="" F I=1:1 S J=$O(XMNAME(J)) Q:J="" S XMTEXT(I)=J
  1. S XMINSTR("FROM")=.5
  1. S XMPARM(1)=$$NAME^XMXUTIL(DUZ),XMPARM(2)=$P(^XMB(3.8,XMG,0),U,1)
  1. D TASKBULL^XMXBULL(DUZ,"XM GROUP EDIT NOTIFY",.XMPARM,"XMTEXT",.XMTO,.XMINSTR)
  1. Q