]> kaliko git repositories - mpd-sima.git/blob - sima/plugins/core/history.py
Fixed bug in history plugin (24h db cleanup not fired)
[mpd-sima.git] / sima / plugins / core / history.py
1 # -*- coding: utf-8 -*-
2 # Copyright (c) 2013, 2014, 2020 kaliko <kaliko@azylum.org>
3 #
4 #  This file is part of sima
5 #
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.
10 #
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.
15 #
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/>.
18 #
19 #
20 """Add playing tracks to history
21 """
22
23 # standard library import
24 from time import time
25
26 # third parties components
27
28 # local import
29 from ...lib.plugin import Plugin
30
31 class History(Plugin):
32     """
33     History management
34     """
35     def __init__(self, daemon):
36         Plugin.__init__(self, daemon)
37         self._last_clean = time()
38
39     def shutdown(self):
40         self.log.info('Cleaning database')
41         self.sdb.purge_history()
42         self.sdb.clean_database()
43
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:
48             return
49         if not current:
50             self.log.debug('Cannot add "%s" to history (empty or missing file)', current)
51             return
52         self.log.debug('add history: "%s"', current)
53         self.sdb.add_history(current)
54         if time() - self._last_clean > 86400:
55             self.shutdown()
56             self._last_clean = time()
57
58
59 # VIM MODLINE
60 # vim: ai ts=4 sw=4 sts=4 expandtab