1 # -*- coding: utf-8 -*-
2 # Copyright (c) 2013, 2014, 2020 kaliko <kaliko@azylum.org>
4 # This file is part of sima
6 # sima is free software: you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation, either version 3 of the License, or
9 # (at your option) any later version.
11 # sima is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License
17 # along with sima. If not, see <http://www.gnu.org/licenses/>.
20 """Add playing tracks to history
23 # standard library import
26 # third parties components
29 from ...lib.plugin import Plugin
31 class History(Plugin):
35 def __init__(self, daemon):
36 Plugin.__init__(self, daemon)
37 self._last_clean = time()
40 self.log.info('Cleaning database')
41 self.sdb.purge_history()
42 self.sdb.clean_database()
44 def callback_player(self):
45 current = self.player.current
46 last_hist = next(self.sdb.get_history(), None)
47 if last_hist and last_hist[3] == current.file:
50 self.log.debug('Cannot add "%s" to history (empty or missing file)', current)
52 self.log.debug('add history: "%s"', current)
53 self.sdb.add_history(current)
54 if time() - self._last_clean > 86400:
56 self._last_clean = time()
60 # vim: ai ts=4 sw=4 sts=4 expandtab