4 use FS::UID qw(adminsuidsetup);
5 use FS::Record qw(qsearch qsearchs);
10 my $user = shift or die &usage;
13 #my $machine = shift or die &usage;
15 my @exports = qsearch('part_export', { exporttype=>'sqlradius' } );
16 push @exports, qsearch('part_export', { exporttype=>'sqlradius_withdomain' } );
19 foreach my $export ( @exports ) {
20 my $icradius_dbh = DBI->connect(
21 map { $export->option($_) } qw( datasrc username password )
22 ) or die $DBI::errstr;
23 for my $table (qw( radcheck radreply usergroup )) {
24 my $sth = $icradius_dbh->prepare("DELETE FROM $table");
25 $sth->execute or die "Can't reset $table table: ". $sth->errstr;
27 $icradius_dbh->disconnect;
30 foreach my $export ( @exports ) {
32 #my @svcparts = map { $_->svcpart } $export->export_svc;
35 map { qsearchs('svc_acct', { 'svcnum' => $_->svcnum } ) }
36 map { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) }
37 grep { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) }
40 foreach my $svc_acct ( @svc_acct ) {
42 #false laziness with FS::svc_acct::insert (like it matters)
43 my $error = $export->export_insert($svc_acct);
50 #die "Usage:\n\n sqlradius_reset user machine\n";
51 die "Usage:\n\n freeside-sqlradius-reset user\n";
56 freeside-sqlradius-reset - Command line interface to reset and recreate RADIUS SQL tables
60 freeside-sqlradius-reset username
64 Deletes the radcheck, radreply and usergroup tables and repopulates them from
65 the Freeside database, for all sqlradius exports.
67 B<username> is a username added by freeside-adduser.
71 L<freeside-reexport>, L<FS::part_export>, L<FS::part_export::sqlradius>