wiki-archive/twiki/lib/TWiki/Contrib/MailerContrib/Change.pm

184 lines
5.1 KiB
Perl
Raw Normal View History

# Module of TWiki Enterprise Collaboration Platform, http://TWiki.org/
#
# Copyright (C) 2004 Wind River Systems Inc.
# Copyright (C) 1999-2006 TWiki Contributors.
# All Rights Reserved. TWiki Contributors
# are listed in the AUTHORS file in the root of this distribution.
# NOTE: Please extend that file, not this notice.
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version. For
# more details read LICENSE in the root of this distribution.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
#
# As per the GPL, removal of this notice is prohibited.
use strict;
=pod
---
---+ package TWiki::Contrib::MailerContrib::Change
Object that represents a change to a topic.
=cut
package TWiki::Contrib::MailerContrib::Change;
use TWiki;
use URI::Escape;
use Assert;
=pod
---++ ClassMethod new($web)
* =$web= - Web name
* =$topic= - Topic name
* =$author= - String author of change
* =$time= - String time of change
* =$rev= - Revision identifier
Construct a new change object.
=cut
sub new {
my ( $class, $session, $web, $topic, $author, $time, $rev ) = @_;
my $this = bless( {}, $class );
$this->{SESSION} = $session;
$this->{WEB} = $web;
$this->{TOPIC} = $topic;
my $user = $session->{users}->findUser( $author, undef, 1 );
$this->{AUTHOR} = $user ? $user->wikiName() : $author;
$this->{TIME} = $time;
ASSERT($rev) if DEBUG;
# rev at this change
$this->{CURR_REV} = $rev;
# previous rev
$this->{BASE_REV} = $rev - 1;
return $this;
}
=pod
---++ ObjectMethod merge($change)
* =$change= - Change record to merge
Merge another change record with this one, so that the combined
record is a reflection of both changes.
=cut
sub merge {
my( $this, $other ) = @_;
ASSERT($this->isa( 'TWiki::Contrib::MailerContrib::Change' )) if DEBUG;
ASSERT($other->isa( 'TWiki::Contrib::MailerContrib::Change' )) if DEBUG;
if( $other->{CURR_REV} > $this->{CURR_REV} ) {
$this->{CURR_REV} = $other->{CURR_REV};
$this->{AUTHOR} = $other->{AUTHOR};
$this->{TIME} = $other->{TIME};
}
$this->{BASE_REV} = $other->{BASE_REV}
if($other->{BASE_REV} < $this->{BASE_REV});
}
=pod
---++ ObjectMethod expandHTML($html) -> string
* =$html= - Template to expand keys within
Expand an HTML template using the values in this change. The following
keys are expanded: %<nop>TOPICNAME%, %<nop>AUTHOR%, %<nop>TIME%,
%<nop>REVISION%, %<nop>TEXTHEAD%.
Returns the expanded template.
=cut
sub expandHTML {
my ( $this, $html ) = @_;
unless( defined $this->{HTML_SUMMARY} ) {
$this->{HTML_SUMMARY} =
$this->{SESSION}->{renderer}->summariseChanges
( undef, $this->{WEB}, $this->{TOPIC}, $this->{BASE_REV},
$this->{CURR_REV}, 1 );
}
$html =~ s/%TOPICNAME%/$this->{TOPIC}/g;
$html =~ s/%AUTHOR%/$this->{AUTHOR}/g;
my $tim = TWiki::Time::formatTime( $this->{TIME} );
$html =~ s/%TIME%/$tim/go;
my $frev = '';
if( $this->{CURR_REV} ) {
if( $this->{CURR_REV} > 1 ) {
$frev = 'r'.$this->{BASE_REV}.'-&gt;r'.$this->{CURR_REV};
} else {
# new _since the last notification_
$frev = CGI::span( { class=>'twikiNew' }, 'NEW' );
}
}
$html =~ s/%REVISION%/$frev/g;
$html = $this->{SESSION}->handleCommonTags(
$html, $this->{WEB}, $this->{TOPIC} );
$html = $this->{SESSION}->{renderer}->getRenderedVersion( $html );
$html =~ s/%TEXTHEAD%/$this->{HTML_SUMMARY}/g;
return $html;
}
=pod
---++ ObjectMethod expandPlain() -> string
Generate a plaintext version of this change.
=cut
sub expandPlain {
my ( $this, $template ) = @_;
unless( defined $this->{TEXT_SUMMARY} ) {
my $s =
$this->{SESSION}->{renderer}->summariseChanges
( undef, $this->{WEB}, $this->{TOPIC}, $this->{BASE_REV},
$this->{CURR_REV}, 0 );
$s =~ s/\n/\n /gs;
$s = " $s";
$this->{TEXT_SUMMARY} = $s;
}
# URL-encode topic names for use of I18N topic names in plain text
my $scriptUrl =
$this->{SESSION}->getScriptUrl(
1, 'view',
URI::Escape::uri_escape( $this->{WEB} ),
URI::Escape::uri_escape( $this->{TOPIC}));
my $tim = TWiki::Time::formatTime( $this->{TIME} );
$template =~ s/%TOPICNAME%/$this->{TOPIC}/g;
$template =~ s/%AUTHOR%/$this->{AUTHOR}/g;
$template =~ s/%TIME%/$tim/g;
my $frev = '';
if( $this->{CURR_REV} ) {
if( $this->{CURR_REV} > 1 ) {
$frev = 'r'.$this->{BASE_REV}.'->r'.$this->{CURR_REV};
} else {
# new _since the last notification_
$frev = 'NEW';
}
}
$template =~ s/%REVISION%/$frev/g;
$template =~ s/%URL%/$scriptUrl/g;
$template =~ s/%TEXTHEAD%/$this->{TEXT_SUMMARY}/g;
return $template;
}
1;