package FS::reason; use strict; use vars qw( @ISA $DEBUG $me ); use DBIx::DBSchema; use DBIx::DBSchema::Table; use DBIx::DBSchema::Column; use FS::Record qw( qsearch qsearchs dbh dbdef ); use FS::reason_type; @ISA = qw(FS::Record); $DEBUG = 0; $me = '[FS::reason]'; =head1 NAME FS::reason - Object methods for reason records =head1 SYNOPSIS use FS::reason; $record = new FS::reason \%hash; $record = new FS::reason { 'column' => 'value' }; $error = $record->insert; $error = $new_record->replace($old_record); $error = $record->delete; $error = $record->check; =head1 DESCRIPTION An FS::reason object represents a reason message. FS::reason inherits from FS::Record. The following fields are currently supported: =over 4 =item reasonnum - primary key =item reason_type - index into FS::reason_type =item reason - text of the reason =item disabled - 'Y' or '' =item unsuspend_pkgpart - for suspension reasons only, the pkgpart (see L) of a package to be ordered when the package is unsuspended. Typically this will be some kind of reactivation fee. Attaching it to a suspension reason allows the reactivation fee to be charged for some suspensions but not others. =item unsuspend_hold - 'Y' or ''. If unsuspend_pkgpart is set, this tells whether to bill the unsuspend package immediately ('') or to wait until the customer's next invoice ('Y'). =back =head1 METHODS =over 4 =item new HASHREF Creates a new reason. To add the example to the database, see L<"insert">. Note that this stores the hash reference, not a distinct copy of the hash it points to. You can ask the object for a copy with the I method. =cut sub table { 'reason'; } =item insert Adds this record to the database. If there is an error, returns the error, otherwise returns false. =cut =item delete Delete this record from the database. =cut =item replace OLD_RECORD Replaces the OLD_RECORD with this one in the database. If there is an error, returns the error, otherwise returns false. =cut =item check Checks all fields to make sure this is a valid reason. If there is an error, returns the error, otherwise returns false. Called by the insert and replace methods. =cut sub check { my $self = shift; my $error = $self->ut_numbern('reasonnum') || $self->ut_number('reason_type') || $self->ut_foreign_key('reason_type', 'reason_type', 'typenum') || $self->ut_text('reason') || $self->ut_flag('disabled') ; return $error if $error; if ( $self->reasontype->class eq 'S' ) { $error = $self->ut_numbern('unsuspend_pkgpart') || $self->ut_foreign_keyn('unsuspend_pkgpart', 'part_pkg', 'pkgpart') || $self->ut_flag('unsuspend_hold') ; return $error if $error; } else { $self->set('unsuspend_pkgpart' => ''); $self->set('unsuspend_hold' => ''); } $self->SUPER::check; } =item reasontype Returns the reason_type (see L) associated with this reason. =cut sub reasontype { qsearchs( 'reason_type', { 'typenum' => shift->reason_type } ); } =back =head1 BUGS Here by termintes. Don't use on wooden computers. =head1 SEE ALSO L, schema.html from the base documentation. =cut 1;