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' } );
17 foreach my $export ( @exports ) {
18 my $icradius_dbh = DBI->connect(
19 map { $export->option($_) } qw( datasrc username password )
20 ) or die $DBI::errstr;
21 for my $table (qw( radcheck radreply usergroup )) {
22 my $sth = $icradius_dbh->prepare("DELETE FROM $table");
23 $sth->execute or die "Can't reset $table table: ". $sth->errstr;
25 $icradius_dbh->disconnect;
28 foreach my $export ( @exports ) {
30 #my @svcparts = map { $_->svcpart } $export->export_svc;
33 map { qsearchs('svc_acct', { 'svcnum' => $_->svcnum } ) }
34 map { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) }
35 grep { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) }
38 foreach my $svc_acct ( @svc_acct ) {
40 #false laziness with FS::svc_acct::insert (like it matters)
41 my $error = $export->export_insert($svc_acct);
48 #die "Usage:\n\n sqlradius_reset user machine\n";
49 die "Usage:\n\n freeside-sqlradius-reset user\n";
54 freeside-sqlradius-reset - Command line interface to reset and recreate RADIUS SQL tables
58 freeside-sqlradius-reset username
62 Deletes the radcheck, radreply and usergroup tables and repopulates them from
63 the Freeside database, for all sqlradius exports.
65 B<username> is a username added by freeside-adduser.
69 L<freeside-reexport>, L<FS::part_export>, L<FS::part_export::sqlradius>