92 lines
3.2 KiB
Perl
92 lines
3.2 KiB
Perl
package App::Netdisco::Worker::Plugin::Expire;
|
|
|
|
use Dancer ':syntax';
|
|
use App::Netdisco::Worker::Plugin;
|
|
use aliased 'App::Netdisco::Worker::Status';
|
|
|
|
use Dancer::Plugin::DBIC 'schema';
|
|
use App::Netdisco::Util::Statistics 'update_stats';
|
|
use App::Netdisco::DB::ExplicitLocking ':modes';
|
|
|
|
register_worker({ phase => 'main' }, sub {
|
|
my ($job, $workerconf) = @_;
|
|
|
|
if (setting('expire_devices') and setting('expire_devices') > 0) {
|
|
schema('netdisco')->txn_do(sub {
|
|
schema('netdisco')->resultset('Device')->search({
|
|
-or => [ 'vendor' => undef, 'vendor' => { '!=' => 'netdisco' }],
|
|
last_discover => \[q/< (LOCALTIMESTAMP - ?::interval)/,
|
|
(setting('expire_devices') * 86400)],
|
|
})->delete();
|
|
});
|
|
}
|
|
|
|
if (setting('expire_nodes') and setting('expire_nodes') > 0) {
|
|
schema('netdisco')->txn_do(sub {
|
|
my $freshness = ((defined setting('expire_nodeip_freshness'))
|
|
? setting('expire_nodeip_freshness') : setting('expire_nodes'));
|
|
if ($freshness) {
|
|
schema('netdisco')->resultset('NodeIp')->search({
|
|
time_last => \[q/< (LOCALTIMESTAMP - ?::interval)/, ($freshness * 86400)],
|
|
})->delete();
|
|
}
|
|
|
|
schema('netdisco')->resultset('Node')->search({
|
|
time_last => \[q/< (LOCALTIMESTAMP - ?::interval)/,
|
|
(setting('expire_nodes') * 86400)],
|
|
})->delete();
|
|
});
|
|
}
|
|
|
|
if (setting('expire_nodes_archive') and setting('expire_nodes_archive') > 0) {
|
|
schema('netdisco')->txn_do(sub {
|
|
my $freshness = ((defined setting('expire_nodeip_freshness'))
|
|
? setting('expire_nodeip_freshness') : setting('expire_nodes_archive'));
|
|
if ($freshness) {
|
|
schema('netdisco')->resultset('NodeIp')->search({
|
|
time_last => \[q/< (LOCALTIMESTAMP - ?::interval)/, ($freshness * 86400)],
|
|
})->delete();
|
|
}
|
|
|
|
schema('netdisco')->resultset('Node')->search({
|
|
-not_bool => 'active',
|
|
time_last => \[q/< (LOCALTIMESTAMP - ?::interval)/,
|
|
(setting('expire_nodes_archive') * 86400)],
|
|
})->delete();
|
|
});
|
|
}
|
|
|
|
# also have to clean up node_ip that have no correspoding node
|
|
schema('netdisco')->resultset('NodeIp')->search({
|
|
mac => { -in => schema('netdisco')->resultset('NodeIp')->search(
|
|
{ port => undef },
|
|
{ join => 'nodes', select => [{ distinct => 'me.mac' }], }
|
|
)->as_query },
|
|
})->delete;
|
|
|
|
if (setting('expire_jobs') and setting('expire_jobs') > 0) {
|
|
schema('netdisco')->txn_do_locked('admin', 'EXCLUSIVE', sub {
|
|
schema('netdisco')->resultset('Admin')->search({
|
|
entered => \[q/< (LOCALTIMESTAMP - ?::interval)/,
|
|
(setting('expire_jobs') * 86400)],
|
|
})->delete();
|
|
});
|
|
}
|
|
|
|
if (setting('expire_userlog') and setting('expire_userlog') > 0) {
|
|
schema('netdisco')->txn_do_locked('admin', 'EXCLUSIVE', sub {
|
|
schema('netdisco')->resultset('UserLog')->search({
|
|
creation => \[q/< (LOCALTIMESTAMP - ?::interval)/,
|
|
(setting('expire_userlog') * 86400)],
|
|
})->delete();
|
|
});
|
|
}
|
|
|
|
# now update stats
|
|
update_stats();
|
|
|
|
return Status->done('Checked expiry and updated stats');
|
|
});
|
|
|
|
true;
|