summaryrefslogtreecommitdiff
path: root/rt/lib/RT/CustomFieldValue_Overlay.pm
diff options
context:
space:
mode:
authorivan <ivan>2009-12-31 13:16:41 +0000
committerivan <ivan>2009-12-31 13:16:41 +0000
commitb4b0c7e72d7eaee2fbfc7022022c9698323203dd (patch)
treeba4cd21399e412c32fe3737eaa8478e3271509f9 /rt/lib/RT/CustomFieldValue_Overlay.pm
parent2dfda73eeb3eae2d4f894099754794ef07d060dd (diff)
import rt 3.8.7
Diffstat (limited to 'rt/lib/RT/CustomFieldValue_Overlay.pm')
-rw-r--r--rt/lib/RT/CustomFieldValue_Overlay.pm107
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;