diff options
author | Ivan Kohler <ivan@freeside.biz> | 2012-04-24 11:35:56 -0700 |
---|---|---|
committer | Ivan Kohler <ivan@freeside.biz> | 2012-04-24 11:35:56 -0700 |
commit | 6587f6ba7d047ddc1686c080090afe7d53365bd4 (patch) | |
tree | ec77342668e8865aca669c9b4736e84e3077b523 /rt/lib/RT/URI/fsck_com_article.pm | |
parent | 47153aae5c2fc00316654e7277fccd45f72ff611 (diff) |
first pass RT4 merge, RT#13852
Diffstat (limited to 'rt/lib/RT/URI/fsck_com_article.pm')
-rw-r--r-- | rt/lib/RT/URI/fsck_com_article.pm | 216 |
1 files changed, 216 insertions, 0 deletions
diff --git a/rt/lib/RT/URI/fsck_com_article.pm b/rt/lib/RT/URI/fsck_com_article.pm new file mode 100644 index 000000000..503434a1c --- /dev/null +++ b/rt/lib/RT/URI/fsck_com_article.pm @@ -0,0 +1,216 @@ +# BEGIN BPS TAGGED BLOCK {{{ +# +# COPYRIGHT: +# +# This software is Copyright (c) 1996-2012 Best Practical Solutions, LLC +# <sales@bestpractical.com> +# +# (Except where explicitly superseded by other copyright notices) +# +# +# LICENSE: +# +# This work is made available to you under the terms of Version 2 of +# the GNU General Public License. A copy of that license should have +# been provided with this software, but in any event can be snarfed +# from www.gnu.org. +# +# This work 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. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA +# 02110-1301 or visit their web page on the internet at +# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html. +# +# +# CONTRIBUTION SUBMISSION POLICY: +# +# (The following paragraph is not intended to limit the rights granted +# to you to modify and distribute this software under the terms of +# the GNU General Public License and is only of importance to you if +# you choose to contribute your changes and enhancements to the +# community by submitting them to Best Practical Solutions, LLC.) +# +# By intentionally submitting any modifications, corrections or +# derivatives to this work, or any other work intended for use with +# Request Tracker, to Best Practical Solutions, LLC, you confirm that +# you are the copyright holder for those contributions and you grant +# Best Practical Solutions, LLC a nonexclusive, worldwide, irrevocable, +# royalty-free, perpetual, license to use, copy, create derivative +# works based on those contributions, and sublicense and distribute +# those contributions and any derivatives thereof. +# +# END BPS TAGGED BLOCK }}} + +package RT::URI::fsck_com_article; + +use strict; +use warnings; +no warnings 'redefine'; + +use RT::Article; +use base qw/RT::URI::base/; + +=head2 LocalURIPrefix + +Returns the prefix for a local article URI + +=cut + +sub LocalURIPrefix { + my $self = shift; + my $prefix = $self->Scheme. "://". RT->Config->Get('Organization') + . "/article/"; + return ($prefix); +} + +=head2 URIForObject RT::article + +Returns the RT URI for a local RT::article object + +=cut + +sub URIForObject { + + my $self = shift; + + my $obj = shift; + return ($self->LocalURIPrefix. $obj->Id); +} + + +=head2 ParseObject $ArticleObj + +When handed an L<RT::Article> object, figure out its URI + +=cut + +=head2 ParseURI URI + +When handed an fsck.com-article URI, figures out things like whether its a local article +and what its ID is + +=cut + +sub ParseURI { + my $self = shift; + my $uri = shift; + + my $article; + + if ($uri =~ /^(\d+)$/) { + $article = RT::Article->new($self->CurrentUser); + $article->Load($uri); + $self->{'uri'} = $article->URI; + } + else { + $self->{'uri'} = $uri; + } + + #If it's a local URI, load the article object and return its URI + if ( $self->IsLocal) { + + my $local_uri_prefix = $self->LocalURIPrefix; + if ($self->{'uri'} =~ /^$local_uri_prefix(\d+)$/) { + my $id = $1; + + + $article = RT::Article->new( $self->CurrentUser ); + $article->Load($id); + + #If we couldn't find a article, return undef. + unless ( defined $article->Id ) { + return undef; + } + } else { + return undef; + } + } + + $self->{'object'} = $article; + return ($article->Id); +} + +=head2 IsLocal + +Returns true if this URI is for a local article. +Returns undef otherwise. + +=cut + +sub IsLocal { + my $self = shift; + my $local_uri_prefix = $self->LocalURIPrefix; + if ($self->{'uri'} =~ /^$local_uri_prefix/) { + return 1; + } + else { + return undef; + } +} + + + +=head2 Object + +Returns the object for this URI, if it's local. Otherwise returns undef. + +=cut + +sub Object { + my $self = shift; + return ($self->{'object'}); + +} + +=head2 Scheme + +Return the URI scheme for RT articles + +=cut + +sub Scheme { + my $self = shift; + return "fsck.com-article"; +} + +=head2 HREF + +If this is a local article, return an HTTP url to it. +Otherwise, return its URI + +=cut + +sub HREF { + my $self = shift; + if ($self->IsLocal && $self->Object) { + return ( RT->Config->Get('WebURL') . "/Articles/Article/Display.html?id=".$self->Object->Id); + } + else { + return ($self->URI); + } +} + +=head2 AsString + +Return "Article 23" + +=cut + +sub AsString { + my $self = shift; + if ($self->IsLocal && $self->Object) { + return $self->loc('Article [_1]', $self->Object->id); + + } else { + return $self->SUPER::AsString(@_); + } + +} + + +1; |