-
Notifications
You must be signed in to change notification settings - Fork 11
/
afkstreamer.py
103 lines (86 loc) · 3.03 KB
/
afkstreamer.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
import logging
import threading
import audio
import util
import manager
import bootstrap
import datetime
logger = logging.getLogger('afkstreamer')
class Streamer(object):
"""
Top wrapper of the AFK Streamer. This gives out filenames and metadata
to the underlying :mod:`audio` module.
"""
def __init__(self, attributes):
super(Streamer, self).__init__()
self.instance = None
self.icecast_config = attributes
self.np_thread = None
self.instance = audio.Manager(self.icecast_config, self.supply_song)
self.close_at_end = threading.Event()
@property
def connected(self):
"""
Returns True if the audio modules :mod:`audio.icecast` is
currently connected. Else returns False.
"""
try:
return self.instance.connected()
except (AttributeError):
return False
def start(self):
"""Starts the audio pipeline and connects to icecast."""
self.queue = manager.Queue()
self.close_at_end.clear()
self.instance.start()
def close(self, force=False):
"""Stop the audio pipeline and disconnects from icecast."""
if force:
self.instance.close()
logger.info("Closed audio manager.")
else:
self.close_at_end.set()
logger.info("Set close at end of song flag.")
def supply_song(self):
"""Returns a tuple of (filename, metadata) to be played next."""
# check if we got asked to shut down at end of track.
print datetime.datetime.now(), "supply song start"
if (self.close_at_end.is_set()):
self.shutdown(force=True)
else:
try:
print datetime.datetime.now(), "queue pop"
song = self.queue.pop()
except manager.QueueError:
self.queue.clear_pops()
return self.supply_song()
else:
if (song.id == 0):
self.queue.clear()
song = self.queue.pop()
self.queue.clear_pops()
# update now playing
print datetime.datetime.now(), "np change"
if self.np_thread is not None:
self.np_thread.join(0.0)
self.np_thread = threading.Thread(target=manager.NP.change, args=(song,))
self.np_thread.daemon = False
self.np_thread.start()
print datetime.datetime.now(), "np change done"
return (song.filename, song.metadata)
return (None, None)
def connect(self, *args, **kwargs):
"""
.. deprecated:: 1.2
use :meth:`start`: instead.
"""
self.start(*args, **kwargs)
def shutdown(self, *args, **kwargs):
"""
.. deprecated:: 1.2
use :meth:`close`: instead.
"""
self.close(*args, **kwargs)
class StreamManager(util.BaseManager):
socket = '/tmp/hanyuu_stream'
StreamManager.register("Streamer", Streamer)