2017-10-10 14:13:35 +03:00
|
|
|
""" Module for parsing bouquets """
|
2018-07-13 12:28:13 +03:00
|
|
|
import re
|
|
|
|
|
|
2018-04-04 16:52:58 +03:00
|
|
|
from app.eparser.ecommons import BqServiceType, BouquetService, Bouquets, Bouquet, BqType
|
2017-10-10 14:13:35 +03:00
|
|
|
|
2017-10-26 01:23:05 +03:00
|
|
|
_TV_ROOT_FILE_NAME = "bouquets.tv"
|
|
|
|
|
_RADIO_ROOT_FILE_NAME = "bouquets.radio"
|
2017-10-10 14:13:35 +03:00
|
|
|
|
2017-12-19 22:57:04 +03:00
|
|
|
|
2017-10-10 14:13:35 +03:00
|
|
|
def get_bouquets(path):
|
2018-04-04 16:52:58 +03:00
|
|
|
return parse_bouquets(path, "bouquets.tv", BqType.TV.value), parse_bouquets(path, "bouquets.radio",
|
|
|
|
|
BqType.RADIO.value)
|
2017-10-10 14:13:35 +03:00
|
|
|
|
|
|
|
|
|
2018-01-01 23:42:40 +03:00
|
|
|
def write_bouquets(path, bouquets):
|
2017-10-26 01:23:05 +03:00
|
|
|
srv_line = '#SERVICE 1:7:1:0:0:0:0:0:0:0:FROM BOUQUET "userbouquet.{}.{}" ORDER BY bouquet\n'
|
|
|
|
|
line = []
|
2018-07-13 12:28:13 +03:00
|
|
|
pattern = re.compile("[^\w_()]+")
|
2017-10-26 01:23:05 +03:00
|
|
|
|
|
|
|
|
for bqs in bouquets:
|
|
|
|
|
line.clear()
|
|
|
|
|
line.append("#NAME {}\n".format(bqs.name))
|
|
|
|
|
|
|
|
|
|
for bq in bqs.bouquets:
|
2018-07-13 12:28:13 +03:00
|
|
|
bq_name = re.sub(pattern, "_", bq.name)
|
|
|
|
|
line.append(srv_line.format(bq_name, bq.type))
|
|
|
|
|
write_bouquet(path + "userbouquet.{}.{}".format(bq_name, bq.type), bq.name, bq.services)
|
2017-10-26 01:23:05 +03:00
|
|
|
|
2018-02-10 15:49:44 +03:00
|
|
|
with open(path + "bouquets.{}".format(bqs.type), "w", encoding="utf-8") as file:
|
2017-10-26 01:23:05 +03:00
|
|
|
file.writelines(line)
|
|
|
|
|
|
|
|
|
|
|
2018-07-13 12:28:13 +03:00
|
|
|
def write_bouquet(path, name, channels):
|
2017-10-24 00:09:11 +03:00
|
|
|
bouquet = ["#NAME {}\n".format(name)]
|
2017-10-26 01:23:05 +03:00
|
|
|
|
2017-10-24 00:09:11 +03:00
|
|
|
for ch in channels:
|
2017-11-25 15:55:24 +03:00
|
|
|
if not ch: # if was duplicate
|
|
|
|
|
continue
|
2017-12-19 22:57:04 +03:00
|
|
|
if ch.service_type == BqServiceType.IPTV.name or ch.service_type == BqServiceType.MARKER.name:
|
2017-12-20 10:54:45 +03:00
|
|
|
bouquet.append("#SERVICE {}\n".format(ch.fav_id.strip()))
|
2017-12-08 23:48:20 +03:00
|
|
|
else:
|
|
|
|
|
bouquet.append("#SERVICE {}\n".format(to_bouquet_id(ch)))
|
2017-10-26 01:23:05 +03:00
|
|
|
|
2018-07-13 12:28:13 +03:00
|
|
|
with open(path, "w", encoding="utf-8") as file:
|
2017-10-24 00:09:11 +03:00
|
|
|
file.writelines(bouquet)
|
2017-10-20 19:03:22 +03:00
|
|
|
|
|
|
|
|
|
2017-11-26 20:40:22 +03:00
|
|
|
def to_bouquet_id(ch):
|
|
|
|
|
""" Creates bouquet channel id """
|
2017-12-16 10:29:51 +03:00
|
|
|
data_type = ch.data_id
|
2018-02-05 22:17:06 +03:00
|
|
|
if data_type and len(data_type) > 4:
|
|
|
|
|
data_type = int(ch.data_id.split(":")[4])
|
2018-01-28 23:10:54 +03:00
|
|
|
|
2018-02-05 22:17:06 +03:00
|
|
|
return "{}:0:{:X}:{}:0:0:0:".format(1, data_type, ch.fav_id)
|
2017-11-26 20:40:22 +03:00
|
|
|
|
|
|
|
|
|
2017-10-24 00:09:11 +03:00
|
|
|
def get_bouquet(path, name, bq_type):
|
|
|
|
|
""" Parsing services ids from bouquet file """
|
2018-02-19 23:18:01 +03:00
|
|
|
with open(path + "userbouquet.{}.{}".format(name, bq_type), encoding="utf-8", errors="replace") as file:
|
2017-10-11 23:22:30 +03:00
|
|
|
chs_list = file.read()
|
2017-12-19 22:57:04 +03:00
|
|
|
services = []
|
2018-02-03 16:45:54 +03:00
|
|
|
srvs = list(filter(None, chs_list.split("\n#SERVICE"))) # filtering ['']
|
|
|
|
|
for ch in srvs[1:]:
|
2017-12-16 19:28:57 +03:00
|
|
|
ch_data = ch.strip().split(":")
|
|
|
|
|
if ch_data[1] == "64":
|
2017-12-20 10:54:45 +03:00
|
|
|
services.append(BouquetService(ch_data[-1].split("\n")[0], BqServiceType.MARKER, ch, ch_data[2]))
|
2017-12-16 19:28:57 +03:00
|
|
|
elif "http" in ch:
|
2017-12-20 10:54:45 +03:00
|
|
|
services.append(BouquetService(ch_data[-1].split("\n")[0], BqServiceType.IPTV, ch, 0))
|
2017-12-08 18:32:28 +03:00
|
|
|
else:
|
2018-02-03 16:45:54 +03:00
|
|
|
fav_id = "{}:{}:{}:{}".format(ch_data[3], ch_data[4], ch_data[5], ch_data[6])
|
2018-09-09 23:38:00 +03:00
|
|
|
name = None
|
|
|
|
|
if len(ch_data) == 12:
|
|
|
|
|
name, desc = str(ch_data[-1]).split("\n#DESCRIPTION")
|
|
|
|
|
services.append(BouquetService(name, BqServiceType.DEFAULT, fav_id, 0))
|
2018-02-05 22:17:06 +03:00
|
|
|
|
2018-02-03 16:45:54 +03:00
|
|
|
return srvs[0].strip("#NAME").strip(), services
|
2017-10-10 14:13:35 +03:00
|
|
|
|
|
|
|
|
|
2017-10-24 00:09:11 +03:00
|
|
|
def parse_bouquets(path, bq_name, bq_type):
|
2018-02-19 23:18:01 +03:00
|
|
|
with open(path + bq_name, encoding="utf-8", errors="replace") as file:
|
2017-10-10 14:13:35 +03:00
|
|
|
lines = file.readlines()
|
|
|
|
|
bouquets = None
|
|
|
|
|
nm_sep = "#NAME"
|
2017-10-26 01:23:05 +03:00
|
|
|
|
2017-10-10 14:13:35 +03:00
|
|
|
for line in lines:
|
|
|
|
|
if nm_sep in line:
|
|
|
|
|
_, _, name = line.partition(nm_sep)
|
2017-10-26 01:23:05 +03:00
|
|
|
bouquets = Bouquets(name.strip(), bq_type, [])
|
2017-10-24 00:09:11 +03:00
|
|
|
if bouquets and "#SERVICE" in line:
|
2018-02-03 16:45:54 +03:00
|
|
|
b_name, services = get_bouquet(path, line.split(".")[1], bq_type)
|
|
|
|
|
bouquets[2].append(Bouquet(name=b_name,
|
2018-01-05 14:32:14 +03:00
|
|
|
type=bq_type,
|
2018-02-03 16:45:54 +03:00
|
|
|
services=services,
|
2018-01-05 14:32:14 +03:00
|
|
|
locked=None,
|
|
|
|
|
hidden=None))
|
2018-02-05 22:17:06 +03:00
|
|
|
|
2017-10-10 14:13:35 +03:00
|
|
|
return bouquets
|
|
|
|
|
|
|
|
|
|
|
2017-10-07 17:33:40 +03:00
|
|
|
if __name__ == "__main__":
|
|
|
|
|
pass
|