diff options
author | ivan <ivan> | 2009-12-31 13:16:41 +0000 |
---|---|---|
committer | ivan <ivan> | 2009-12-31 13:16:41 +0000 |
commit | b4b0c7e72d7eaee2fbfc7022022c9698323203dd (patch) | |
tree | ba4cd21399e412c32fe3737eaa8478e3271509f9 /rt/lib/RT/CustomFieldValue_Overlay.pm | |
parent | 2dfda73eeb3eae2d4f894099754794ef07d060dd (diff) |
import rt 3.8.7
Diffstat (limited to 'rt/lib/RT/CustomFieldValue_Overlay.pm')
-rw-r--r-- | rt/lib/RT/CustomFieldValue_Overlay.pm | 107 |
1 files changed, 93 insertions, 14 deletions
diff --git a/rt/lib/RT/CustomFieldValue_Overlay.pm b/rt/lib/RT/CustomFieldValue_Overlay.pm index be1070d6a..5511e520e 100644 --- a/rt/lib/RT/CustomFieldValue_Overlay.pm +++ b/rt/lib/RT/CustomFieldValue_Overlay.pm @@ -1,8 +1,8 @@ # BEGIN BPS TAGGED BLOCK {{{ # # COPYRIGHT: -# -# This software is Copyright (c) 1996-2009 Best Practical Solutions, LLC +# +# This software is Copyright (c) 1996-2009 Best Practical Solutions, LLC # <jesse@bestpractical.com> # # (Except where explicitly superseded by other copyright notices) @@ -45,6 +45,7 @@ # those contributions and any derivatives thereof. # # END BPS TAGGED BLOCK }}} + use warnings; use strict; @@ -62,36 +63,114 @@ from being integers. sub Create { my $self = shift; - my %args = @_; - (defined $args{$_} or delete $args{$_}) for keys %args; - %args = ((CustomField => '0', - Name => '', - Description => '', - SortOrder => '0', - Category => ''), %args); + my %args = ( + CustomField => 0, + Name => '', + Description => '', + SortOrder => 0, + Category => '', + @_, + ); + + my $cf_id = ref $args{'CustomField'}? $args{'CustomField'}->id: $args{'CustomField'}; + + my $cf = RT::CustomField->new( $self->CurrentUser ); + $cf->Load( $cf_id ); + unless ( $cf->id ) { + return (0, $self->loc("Couldn't load Custom Field #[_1]", $cf_id)); + } + unless ( $cf->CurrentUserHasRight('AdminCustomField') ) { + return (0, $self->loc('Permission Denied')); + } my ($id, $msg) = $self->SUPER::Create( - map {$_ => $args{$_}} qw(CustomField Name Description SortOrder) + CustomField => $cf_id, + map { $_ => $args{$_} } qw(Name Description SortOrder) ); - if ($id and length $args{Category}) { + return ($id, $msg) unless $id; + + if ( defined $args{'Category'} && length $args{'Category'} ) { # $self would be loaded at this stage - $self->SetCategory($args{Category}); + my ($status, $msg) = $self->SetCategory( $args{'Category'} ); + unless ( $status ) { + $RT::Logger->error("Couldn't set category: $msg"); + } } + return ($id, $msg); } +=head2 Category + +Returns the Category assigned to this Value +Returns udef if there is no Category + +=cut + sub Category { my $self = shift; my $attr = $self->FirstAttribute('Category') or return undef; return $attr->Content; } +=head2 SetCategory Category + +Takes a string Category and stores it as an attribute of this CustomFieldValue + +=cut + sub SetCategory { my $self = shift; my $category = shift; - $self->SetAttribute(Name => 'Category', Content => $category); + if ( defined $category && length $category ) { + return $self->SetAttribute( + Name => 'Category', + Content => $category, + ); + } + else { + my ($status, $msg) = $self->DeleteAttribute( 'Category' ); + unless ( $status ) { + $RT::Logger->warning("Couldn't delete atribute: $msg"); + } + # return true even if there was no category + return (1, $self->loc('Category unset')); + } } -sub ValidateName { 1 }; +sub ValidateName { + return defined $_[1] && length $_[1]; +}; + +=head2 DeleteCategory + +Deletes the category associated with this value +Returns -1 if there is no Category + +=cut + +sub DeleteCategory { + my $self = shift; + my $attr = $self->FirstAttribute('Category') or return (-1,'No Category Set'); + return $attr->Delete; +} + +=head2 Delete + +Make sure we delete our Category when we're deleted + +=cut + +sub Delete { + my $self = shift; + + my ($result, $msg) = $self->DeleteCategory; + + unless ($result) { + return ($result, $msg); + } + + return $self->SUPER::Delete(@_); +} 1; |