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;
27 foreach my $export ( @exports ) {
29 #my @svcparts = map { $_->svcpart } $export->export_svc;
32 map { qsearchs('svc_acct', { 'svcnum' => $_->svcnum } ) }
33 map { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) }
34 grep { qsearch('cust_svc', { 'svcpart' => $_->svcpart } ) }
37 foreach my $svc_acct ( @svc_acct ) {
39 #false laziness with FS::svc_acct::insert (like it matters)
40 my $error = $export->export_insert($svc_acct);
47 #die "Usage:\n\n sqlradius_reset user machine\n";
48 die "Usage:\n\n sqlradius_reset user\n";
53 freeside-sqlradius-reset - Command line interface to reset and recreate RADIUS SQL tables
57 freeside-sqlradius-reset username
61 Deletes the radcheck, radreply and usergroup tables and repopulates them from
62 the Freeside database, for all sqlradius exports.
64 B<username> is a username added by freeside-adduser.
68 <FS::part_export>, L<FS::part_export::sqlradius>