This repository has been archived by the owner on Aug 6, 2018. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathextract_eduskunta_goodmoodtv.py
executable file
·83 lines (71 loc) · 1.94 KB
/
extract_eduskunta_goodmoodtv.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
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# (c) 2012 Ville Korhonen <[email protected]>
# GPLv3
#
# Lataa lista Goodmoodtv:stä löytyvistä Eduskunta-aiheisista videoista
# tulostaa urlin videon flash-playeriin sekä rtmp-urlin
#
# Itse videon voi ladata esim. rtmpdump -työkalun avulla
# rtmpdump -o output.flv -r rtmpurl
import os
import sys
try:
from urllib2 import unquote, urlopen
except ImportError:
try:
from urllib import unquote, urlopen
except ImportError:
print "urllib not found, exiting"
sys.exit(1)
from xml.dom.minidom import parse, parseString
XML_URL = "http://www.goodmoodtv.com/internettv/application/eduskunta"
POST_BODY = """<request id="105">
<cmp>fi.goodmood.catalog.Channel</cmp>
<cmd>listVisibleVideos</cmd>
<objectid>512698</objectid>
</request>"""
FIELDS = (
'id',
'title',
'subtitle',
'timestamp',
'timestamp2',
'unknown1',
'category',
'unknown2',
'flv_url',
'rtmp_url',
'category2',
'unknown3',
'unknown4',
'unknown5',
'unknown6',
'unknown7',
'url',
)
def main():
if len(sys.argv) == 1:
dom = parseString(urlopen(XML_URL, data=POST_BODY).read())
elif len(sys.argv) == 2:
filename = sys.argv[1]
if not os.path.exists(filename):
print "File not found"
return 1
dom = parse(filename)
else:
print "Invalid arguments."
return 1
data = unquote(dom.getElementsByTagName("data").pop().lastChild.toxml()).split(':')[1].split(',')
for i in range(0, len(data), len(FIELDS)):
t_fields = data[i:i+len(FIELDS)]
d = dict(zip(FIELDS, t_fields))
d['url'] = unquote(d['url'])
d['flv_url'] = unquote(d['flv_url'])
d['rtmp_url'] = unquote(d['rtmp_url'])
print d['title'].replace('+', ' ')
print d['url']
print d['rtmp_url']
print
if __name__ == "__main__":
sys.exit(main())