]> kaliko git repositories - mpd-sima.git/blob - sima/plugins/core/history.py
Fixed bug in history plugin
[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.sdb = daemon.sdb
38         self._last_clean = time()
39
40     def shutdown(self):
41         self.log.info('Cleaning database')
42         self.sdb.purge_history()
43         self.sdb.clean_database()
44
45     def callback_player(self):
46         current = self.player.current
47         last_hist = next(self.sdb.get_history(), None)
48         if last_hist and last_hist[3] == current.file:
49             return
50         if not current:
51             self.log.debug('Cannot add "%s" to history (empty or missing file)', current)
52             return
53         self.log.debug('add history: "%s"', current)
54         self.sdb.add_history(current)
55         if self._last_clean - time() > 86400:
56             self.shutdown()
57             self._last_clean = time()
58
59
60 # VIM MODLINE
61 # vim: ai ts=4 sw=4 sts=4 expandtab