1 # BEGIN BPS TAGGED BLOCK {{{
5 # This software is Copyright (c) 1996-2007 Best Practical Solutions, LLC
6 # <jesse@bestpractical.com>
8 # (Except where explicitly superseded by other copyright notices)
13 # This work is made available to you under the terms of Version 2 of
14 # the GNU General Public License. A copy of that license should have
15 # been provided with this software, but in any event can be snarfed
18 # This work is distributed in the hope that it will be useful, but
19 # WITHOUT ANY WARRANTY; without even the implied warranty of
20 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
21 # General Public License for more details.
23 # You should have received a copy of the GNU General Public License
24 # along with this program; if not, write to the Free Software
25 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
26 # 02110-1301 or visit their web page on the internet at
27 # http://www.gnu.org/copyleft/gpl.html.
30 # CONTRIBUTION SUBMISSION POLICY:
32 # (The following paragraph is not intended to limit the rights granted
33 # to you to modify and distribute this software under the terms of
34 # the GNU General Public License and is only of importance to you if
35 # you choose to contribute your changes and enhancements to the
36 # community by submitting them to Best Practical Solutions, LLC.)
38 # By intentionally submitting any modifications, corrections or
39 # derivatives to this work, or any other work intended for use with
40 # Request Tracker, to Best Practical Solutions, LLC, you confirm that
41 # you are the copyright holder for those contributions and you grant
42 # Best Practical Solutions, LLC a nonexclusive, worldwide, irrevocable,
43 # royalty-free, perpetual, license to use, copy, create derivative
44 # works based on those contributions, and sublicense and distribute
45 # those contributions and any derivatives thereof.
47 # END BPS TAGGED BLOCK }}}
48 package RT::URI::fsck_com_rt;
56 @ISA = qw/RT::URI::base/;
63 Returns the prefix for a local URI.
67 use_ok("RT::URI::fsck_com_rt");
68 my $uri = RT::URI::fsck_com_rt->new($RT::SystemUser);
75 ok (UNIVERSAL::isa($uri,RT::URI::fsck_com_rt), "It's an RT::URI::fsck_com_rt");
77 ok ($uri->isa('RT::URI::base'), "It's an RT::URI::base");
78 ok ($uri->isa('RT::Base'), "It's an RT::Base");
80 is ($uri->LocalURIPrefix , 'fsck.com-rt://'.$RT::Organization);
91 my $prefix = $self->Scheme. "://$RT::Organization";
102 my $object = shift || $self->Object;
105 if (ref($object) && (ref($object) ne 'RT::Ticket')) {
106 $type = ref($object);
115 =head2 URIForObject RT::Record
117 Returns the RT URI for a local RT::Record object
121 my $ticket = RT::Ticket->new($RT::SystemUser);
123 my $uri = RT::URI::fsck_com_rt->new($ticket->CurrentUser);
124 is($uri->LocalURIPrefix. "/ticket/1" , $uri->URIForObject($ticket));
133 return ($self->LocalURIPrefix ."/". $self->ObjectType($obj) ."/". $obj->Id);
139 When handed an fsck.com-rt: URI, figures out things like whether its a local record and what its ID is
148 if ( $uri =~ /^\d+$/ ) {
149 my $ticket = RT::Ticket->new( $self->CurrentUser );
150 $ticket->Load( $uri );
151 $self->{'uri'} = $ticket->URI;
152 $self->{'object'} = $ticket;
153 return ($ticket->id);
156 $self->{'uri'} = $uri;
159 #If it's a local URI, load the ticket object and return its URI
160 if ( $self->IsLocal ) {
161 my $local_uri_prefix = $self->LocalURIPrefix;
162 if ( $self->{'uri'} =~ /^\Q$local_uri_prefix\E\/(.*?)\/(\d+)$/i ) {
166 if ( $type eq 'ticket' ) { $type = 'RT::Ticket' }
168 # We can instantiate any RT::Record subtype. but not anything else
170 if ( UNIVERSAL::isa( $type, 'RT::Record' ) ) {
171 my $record = $type->new( $self->CurrentUser );
175 $self->{'object'} = $record;
176 return ( $record->Id );
187 Returns true if this URI is for a local ticket.
188 Returns undef otherwise.
196 my $local_uri_prefix = $self->LocalURIPrefix;
197 if ( $self->{'uri'} =~ /^\Q$local_uri_prefix/i ) {
209 Returns the object for this URI, if it's local. Otherwise returns undef.
215 return ($self->{'object'});
221 Return the URI scheme for RT records
228 return "fsck.com-rt";
233 If this is a local ticket, return an HTTP url to it.
234 Otherwise, return its URI
241 if ($self->IsLocal && $self->Object && ($self->ObjectType eq 'ticket')) {
242 return ( $RT::WebURL . "Ticket/Display.html?id=".$self->Object->Id);
251 Returns either a localized string 'ticket #23' or the full URI if the object is not local
257 if ($self->IsLocal && $self->Object) {
258 return $self->loc("[_1] #[_2]", $self->ObjectType, $self->Object->Id);
265 eval "require RT::URI::fsck_com_rt_Vendor";
266 die $@ if ($@ && $@ !~ qr{^Can't locate RT/URI/fsck_com_rt_Vendor.pm});
267 eval "require RT::URI::fsck_com_rt_Local";
268 die $@ if ($@ && $@ !~ qr{^Can't locate RT/URI/fsck_com_rt_Local.pm});