use vars qw( @ISA $conf $DEBUG $me );
use FS::Record qw( qsearch qsearchs );
use FS::svc_Common;
+use FS::dsl_note;
+use FS::qual;
@ISA = qw( FS::svc_Common );
$DEBUG = 0;
=item circuitnum - Circuit #
+=item vpi
+
+=item vci
+
=item rate_band - Rate Band
=item isp_chg
=item last_pull - time of last data pull from vendor/telco
-=item notes
-
-DSL order notes placed by staff or vendor/telco on the vendor/telco order
-
=back
'rate_band' => { label => 'Rate Band',
disable_inventory => 1,
},
+ 'vpi' => { label => 'VPI', disable_inventory => 1 },
+ 'vci' => { label => 'VCI', disable_inventory => 1 },
'isp_chg' => { label => 'ISP Changing?',
type => 'checkbox', %dis2 },
'isp_prev' => { label => 'Current or Previous ISP',
'monitored' => { label => 'Monitored',
type => 'checkbox', %dis2 },
'last_pull' => { label => 'Last Pull', type => 'disabled' },
- 'notes' => { label => 'Order Notes', %dis1 },
},
};
}
return $self->svcnum;
}
+=item notes
+
+Returns the set of FS::dsl_notes associated with this service
+
+=cut
+sub notes {
+ my $self = shift;
+ qsearch( 'dsl_note', { 'svcnum' => $self->svcnum } );
+}
+
=item insert
Adds this record to the database. If there is an error, returns the error,
my $error =
$self->ut_numbern('svcnum')
|| $self->ut_numbern('pushed')
- || $self->ut_number('desired_due_date')
+ || $self->ut_numbern('desired_due_date')
|| $self->ut_numbern('due_date')
|| $self->ut_textn('vendor_order_id')
|| $self->ut_textn('vendor_qual_id')
- || $self->ut_alpha('vendor_order_type')
+ || $self->ut_alphan('vendor_order_type')
|| $self->ut_alphan('vendor_order_status')
|| $self->ut_text('first')
|| $self->ut_text('last')
|| $self->ut_textn('local_voice_provider')
|| $self->ut_textn('circuitnum')
|| $self->ut_textn('rate_band')
+ || $self->ut_numbern('vpi')
+ || $self->ut_numbern('vci')
|| $self->ut_alphan('isp_chg')
|| $self->ut_textn('isp_prev')
|| $self->ut_textn('username')
|| $self->ut_textn('staticips')
|| $self->ut_enum('monitored', [ '', 'Y' ])
|| $self->ut_numbern('last_pull')
- || $self->ut_textn('notes')
;
return $error if $error;
$self->SUPER::check;
}
+sub predelete_hook_first {
+ my $self = shift;
+ my @exports = $self->part_svc->part_export_dsl_pull;
+ return 'More than one DSL-pulling export attached' if scalar(@exports) > 1;
+ if ( scalar(@exports) == 1 ) {
+ my $export = $exports[0];
+ return $export->dsl_pull($self);
+ }
+ '';
+}
+
+sub predelete_hook {
+ my $self = shift;
+ my @notes = $self->notes;
+ foreach my $note ( @notes ) {
+ my $error = $note->delete;
+ return $error if $error;
+ }
+ '';
+}
+
=back
=head1 SEE ALSO