freeside/FS/FS export_svc.pm,1.2,1.3 svc_acct.pm,1.158,1.159 part_svc.pm,1.17,1.18
ivan
ivan at pouncequick.420.am
Sat Aug 14 05:27:03 PDT 2004
- Previous message: freeside/FS/FS export_svc.pm,1.1,1.1.4.1 svc_acct.pm,1.109.2.44,1.109.2.45 part_svc.pm,1.13.4.1,1.13.4.2
- Next message: freeside/fs_selfservice/FS-SelfService/cgi passwd.cgi,1.1,1.2 passwd.html,1.2,1.3
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
Update of /home/cvs/cvsroot/freeside/FS/FS
In directory pouncequick:/tmp/cvs-serv25127/FS/FS
Modified Files:
export_svc.pm svc_acct.pm part_svc.pm
Log Message:
first try at duplicate checking on new export associations
Index: export_svc.pm
===================================================================
RCS file: /home/cvs/cvsroot/freeside/FS/FS/export_svc.pm,v
retrieving revision 1.2
retrieving revision 1.3
diff -u -d -r1.2 -r1.3
--- export_svc.pm 5 Aug 2003 00:20:43 -0000 1.2
+++ export_svc.pm 14 Aug 2004 12:26:57 -0000 1.3
@@ -2,7 +2,7 @@
use strict;
use vars qw( @ISA );
-use FS::Record qw( qsearch qsearchs );
+use FS::Record qw( qsearch qsearchs dbh );
use FS::part_export;
use FS::part_svc;
@@ -67,7 +67,102 @@
=cut
-# the insert method can be inherited from FS::Record
+sub insert {
+ my $self = shift;
+ my $error;
+
+ local $SIG{HUP} = 'IGNORE';
+ local $SIG{INT} = 'IGNORE';
+ local $SIG{QUIT} = 'IGNORE';
+ local $SIG{TERM} = 'IGNORE';
+ local $SIG{TSTP} = 'IGNORE';
+ local $SIG{PIPE} = 'IGNORE';
+
+ my $oldAutoCommit = $FS::UID::AutoCommit;
+ local $FS::UID::AutoCommit = 0;
+ my $dbh = dbh;
+
+ $error = $self->check;
+ return $error if $error;
+
+ #check for duplicates!
+
+ my $label = '';
+ my $method = '';
+ my $svcdb = $self->part_svc->svcdb;
+ if ( $svcdb eq 'svc_acct' ) { #XXX AND UID! sheesh @method or %method not $method
+ if ( $self->part_export->nodomain =~ /^Y/i ) {
+ $label = 'usernames';
+ $method = 'username';
+ } else {
+ $label = 'username at domain';
+ $method = 'email';
+ }
+ } elsif ( $svcdb eq 'domain' ) {
+ $label = 'domains';
+ $method = 'domain';
+ } else {
+ warn "WARNING: XXX fill in this warning";
+ }
+
+ if ( $method ) {
+ my @current_svc = $self->part_export->svc_x;
+ my @new_svc = $self->part_svc->svc_x;
+ my %cur_svc = map { $_->$method() => 1 } @current_svc;
+ my @dup_svc = grep { $cur_svc{$_->method()} } @new_svc;
+
+ if ( @dup_svc ) { #aye, that's the rub
+ #error out for now, eventually accept different options of adjustments
+ # to make to allow us to continue forward
+ $dbh->rollback if $oldAutoCommit;
+ return "Can't export ".
+ $self->part_svc->svcpart.':'.$self->part_svc->svc. " service to ".
+ $self->part_export->exportnum.':'.$self->exporttype.
+ ' on '. $self->machine.
+ " : Duplicate $label: ".
+ join(', ', sort map { $_->method() } @dup_svc );
+ #XXX eventually a sort sub so usernames and domains are default alpha, username at domain is domain first then username, and uid is numeric
+ }
+ }
+
+ #end of duplicate check, whew
+
+ $error = $self->SUPER::insert;
+ if ( $error ) {
+ $dbh->rollback if $oldAutoCommit;
+ return $error;
+ }
+
+# if ( $self->part_svc->svcdb eq 'svc_acct' ) {
+#
+# if ( $self->part_export->nodomain =~ /^Y/i ) {
+#
+# select username from svc_acct where svcpart = $svcpart
+# group by username having count(*) > 1;
+#
+# } else {
+#
+# select username, domain
+# from svc_acct
+# join svc_domain on ( svc_acct.domsvc = svc_domain.svcnum )
+# group by username, domain having count(*) > 1;
+#
+# }
+#
+# } elsif ( $self->part_svc->svcdb eq 'svc_domain' ) {
+#
+# #similar but easier domain checking one
+#
+# } #etc.?
+#
+# my @services =
+# map { $_->part_svc }
+# grep { $_->svcpart != $self->svcpart }
+# $self->part_export->export_svc;
+
+ $dbh->commit or die $dbh->errstr if $oldAutoCommit;
+ ''; #no error
+}
=item delete
@@ -107,6 +202,28 @@
|| $self->ut_foreign_key('svcpart', 'part_svc', 'svcpart')
|| $self->SUPER::check
;
+}
+
+=item part_export
+
+Returns the FS::part_export object (see L<FS::part_export>).
+
+=cut
+
+sub part_export {
+ my $self = shift;
+ qsearchs( 'part_export', { 'exportnum' => $self->exportnum } );
+}
+
+=item part_svc
+
+Returns the FS::part_svc object (see L<FS::part_svc>).
+
+=cut
+
+sub part_svc {
+ my $self = shift;
+ qsearchs( 'part_svc', { 'svcpart' => $self->svcpart } );
}
=back
Index: svc_acct.pm
===================================================================
RCS file: /home/cvs/cvsroot/freeside/FS/FS/svc_acct.pm,v
retrieving revision 1.158
retrieving revision 1.159
diff -u -d -r1.158 -r1.159
--- svc_acct.pm 16 Jun 2004 23:59:43 -0000 1.158
+++ svc_acct.pm 14 Aug 2004 12:26:57 -0000 1.159
@@ -245,7 +245,7 @@
$self->svcpart($cust_svc->svcpart);
}
- #new duplicate username checking
+ #new duplicate username/username at domain/uid checking
my $part_svc = qsearchs('part_svc', { 'svcpart' => $self->svcpart } );
unless ( $part_svc ) {
@@ -272,8 +272,7 @@
foreach my $part_export ( $part_svc->part_export ) {
#this will catch to the same exact export
- my @svcparts = map { $_->svcpart }
- qsearch('export_svc', { 'exportnum' => $part_export->exportnum });
+ my @svcparts = map { $_->svcpart } $part_export->export_svc;
#this will catch to exports w/same exporthost+type ???
#my @other_part_export = qsearch('part_export', {
Index: part_svc.pm
===================================================================
RCS file: /home/cvs/cvsroot/freeside/FS/FS/part_svc.pm,v
retrieving revision 1.17
retrieving revision 1.18
diff -u -d -r1.17 -r1.18
--- part_svc.pm 5 Aug 2003 00:20:44 -0000 1.17
+++ part_svc.pm 14 Aug 2004 12:26:57 -0000 1.18
@@ -6,6 +6,7 @@
use FS::part_svc_column;
use FS::part_export;
use FS::export_svc;
+use FS::cust_svc;
@ISA = qw(FS::Record);
@@ -299,6 +300,28 @@
$search{'exporttype'} = shift if @_;
map { qsearchs('part_export', { 'exportnum' => $_->exportnum, %search } ) }
qsearch('export_svc', { 'svcpart' => $self->svcpart } );
+}
+
+=item cust_svc
+
+Returns a list of associated FS::cust_svc records.
+
+=cut
+
+sub cust_svc {
+ my $self = shift;
+ qsearch('cust_svc', { 'svcpart' => $self->svcpart } );
+}
+
+=item svc_x
+
+Returns a list of associated FS::svc_* records.
+
+=cut
+
+sub svc_x {
+ my $self = shift;
+ map { $_->svc_x } $self->cust_svc;
}
=back
- Previous message: freeside/FS/FS export_svc.pm,1.1,1.1.4.1 svc_acct.pm,1.109.2.44,1.109.2.45 part_svc.pm,1.13.4.1,1.13.4.2
- Next message: freeside/fs_selfservice/FS-SelfService/cgi passwd.cgi,1.1,1.2 passwd.html,1.2,1.3
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
More information about the freeside-commits
mailing list