s/icradius/sqlradius/
authorivan <ivan>
Sun, 24 Mar 2002 23:16:56 +0000 (23:16 +0000)
committerivan <ivan>
Sun, 24 Mar 2002 23:16:56 +0000 (23:16 +0000)
bin/icradius_reset [deleted file]
bin/sqlradius_reset [new file with mode: 0644]

diff --git a/bin/icradius_reset b/bin/icradius_reset
deleted file mode 100644 (file)
index 58663ee..0000000
+++ /dev/null
@@ -1,7 +0,0 @@
-
-  my $sth = $icradius_dbh->prepare("DELETE FROM radcheck");
-  $sth->execute or die "Can't reset radcheck table: ". $sth->errstr;
-  my $sth2 = $icradius_dbh->prepare("DELETE FROM radreply");
-  $sth2->execute or die "Can't reset radreply table: ". $sth2->errstr;
-
-
diff --git a/bin/sqlradius_reset b/bin/sqlradius_reset
new file mode 100644 (file)
index 0000000..fe31d67
--- /dev/null
@@ -0,0 +1,46 @@
+#!/usr/bin/perl -Tw
+
+use strict;
+use FS::UID qw(adminsuidsetup);
+use FS::part_export;
+
+my $user = shift or die &usage;
+adminsuidsetup $user;
+
+#my $machine = shift or die &usage;
+
+my @exports = qsearch('part_export', { 'exporttype' => 'sqlradius' } );
+
+foreach my $export ( @exports ) {
+  my $icradius_dbh = DBI->connect(
+    map { $export->option($_) } qw( datasrc username password )
+  ) or die $DBI::errstr;
+  for my $table (qw( radcheck radreply usergroup )) {
+    my $sth = $icradius_dbh->prepare("DELETE FROM $table");
+    $sth->execute or die "Can't reset $table table: ". $sth->errstr;
+  }
+}
+
+foreach my $export ( @exports ) {
+  my @svc_acct =
+    map { qsearchs{'svc_acct', { 'svcnum' => $_->svcnum } ) }
+      qsearch('cust_svc', { 'svcpart' => $export->part_svc->svcpart } );
+  foreach my $svc_acct ( @svc_acct ) {
+
+    #flase laziness with FS::svc_acct::insert (like it matters)
+    my $error = $part_export->export_insert($self);
+    if ( $error ) {
+      $dbh->rollback if $oldAutoCommit;
+      return "exporting to ". $part_export->exporttype.
+             " (transaction rolled back): $error";
+    }
+
+  }
+}
+
+sub usage {
+  #die "Usage:\n\n  icradius_reset user machine\n";
+  die "Usage:\n\n  icradius_reset user\n";
+}
+
+