mirror of https://github.com/muk-it/muk_base
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
87 lines
4.3 KiB
87 lines
4.3 KiB
###################################################################################
|
|
#
|
|
# Copyright (C) 2018 MuK IT GmbH
|
|
#
|
|
# This program is free software: you can redistribute it and/or modify
|
|
# it under the terms of the GNU Affero General Public License as
|
|
# published by the Free Software Foundation, either version 3 of the
|
|
# License, or (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU Affero General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU Affero General Public License
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
###################################################################################
|
|
|
|
import time
|
|
import logging
|
|
import datetime
|
|
import dateutil
|
|
|
|
from odoo import _
|
|
from odoo import models, api, fields
|
|
from odoo.tools.safe_eval import safe_eval
|
|
|
|
_logger = logging.getLogger(__name__)
|
|
|
|
_types = {
|
|
'days': lambda interval: datetime.timedelta(days=interval),
|
|
'years': lambda interval: datetime.timedelta(weeks=interval*52),
|
|
'hours': lambda interval: datetime.timedelta(hours=interval),
|
|
'weeks': lambda interval: datetime.timedelta(weeks=interval),
|
|
'months': lambda interval: datetime.timedelta(days=interval*30),
|
|
'minutes': lambda interval: datetime.timedelta(minutes=interval),
|
|
}
|
|
|
|
class AutoVacuum(models.AbstractModel):
|
|
|
|
_inherit = 'ir.autovacuum'
|
|
|
|
@api.model
|
|
def power_on(self, *args, **kwargs):
|
|
res = super(AutoVacuum, self).power_on(*args, **kwargs)
|
|
rules = self.env['muk_autovacuum.rules'].sudo().search([], order='sequence asc')
|
|
for rule in rules:
|
|
if rule.state in ['time', 'size', 'domain']:
|
|
model = self.env[rule.model.model].sudo()
|
|
records = self.env[rule.model.model]
|
|
if rule.state == 'time':
|
|
computed_time = datetime.datetime.utcnow() - _types[rule.time_type](rule.time)
|
|
domain = [(rule.time_field.name, '<', fields.Datetime.to_string(computed_time))]
|
|
if rule.protect_starred:
|
|
for field in rule.model.field_id:
|
|
if field.name in ['starred', 'favorite', 'is_starred', 'is_favorite']:
|
|
domain.append((field.name, '=', False))
|
|
if rule.only_inactive and "active" in rule.model.field_id.mapped("name"):
|
|
domain.append(('active', '=', False))
|
|
_logger.info(_("GC domain: %s"), domain)
|
|
records = model.with_context({'active_test': False}).search(domain)
|
|
elif rule.state == 'size':
|
|
size = rule.size if rule.size_type == 'fixed' else rule.size_parameter_value
|
|
count = model.with_context({'active_test': False}).search([], count=True)
|
|
if count > size:
|
|
limit = count - size
|
|
_logger.info(_("GC domain: [] order: %s limit: %s"), rule.size_order, limit)
|
|
records = model.with_context({'active_test': False}).search([], order=rule.size_order, limit=limit)
|
|
elif rule.state == 'domain':
|
|
_logger.info(_("GC domain: %s"), rule.domain)
|
|
domain = safe_eval(rule.domain or "[]", rules._get_eval_domain_context())
|
|
records = model.with_context({'active_test': False}).search(domain)
|
|
if rule.only_attachments:
|
|
attachments = self.env['ir.attachment'].sudo().search([
|
|
('res_model', '=', rule.model.model),
|
|
('res_id', 'in', records.mapped('id'))])
|
|
count = len(attachments)
|
|
attachments.unlink()
|
|
_logger.info(_("GC'd %s attachments from %s entries"), count, rule.model.model)
|
|
else:
|
|
count = len(records)
|
|
records.unlink()
|
|
_logger.info(_("GC'd %s %s records"), count, rule.model.model)
|
|
elif rule.state == 'code':
|
|
safe_eval(rule.code.strip(), rules._get_eval_code_context(rule), mode="exec")
|
|
return res
|