From 47e2114b26353295cfddbd1a78daee20bd1d7179 Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Fri, 19 Nov 2021 16:23:54 +0300 Subject: [PATCH 1/4] Create jquery.md5.js --- sites/tv2go.t-2.net/jquery.md5.js | 264 ++++++++++++++++++++++++++++++ 1 file changed, 264 insertions(+) create mode 100644 sites/tv2go.t-2.net/jquery.md5.js diff --git a/sites/tv2go.t-2.net/jquery.md5.js b/sites/tv2go.t-2.net/jquery.md5.js new file mode 100644 index 00000000..43518dc6 --- /dev/null +++ b/sites/tv2go.t-2.net/jquery.md5.js @@ -0,0 +1,264 @@ +/* + * jQuery MD5 Plugin 1.2.1 + * https://github.com/blueimp/jQuery-MD5 + * + * Copyright 2010, Sebastian Tschan + * https://blueimp.net + * + * Licensed under the MIT license: + * http://creativecommons.org/licenses/MIT/ + * + * Based on + * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message + * Digest Algorithm, as defined in RFC 1321. + * Version 2.2 Copyright (C) Paul Johnston 1999 - 2009 + * Other contributors: Greg Holt, Andrew Kepert, Ydnar, Lostinet + * Distributed under the BSD License + * See http://pajhome.org.uk/crypt/md5 for more info. + */ + +/* + * Add integers, wrapping at 2^32. This uses 16-bit operations internally + * to work around bugs in some JS interpreters. + */ +function safe_add(x, y) { + var lsw = (x & 0xffff) + (y & 0xffff), + msw = (x >> 16) + (y >> 16) + (lsw >> 16) + return (msw << 16) | (lsw & 0xffff) +} + +/* + * Bitwise rotate a 32-bit number to the left. + */ +function bit_rol(num, cnt) { + return (num << cnt) | (num >>> (32 - cnt)) +} + +/* + * These functions implement the four basic operations the algorithm uses. + */ +function md5_cmn(q, a, b, x, s, t) { + return safe_add(bit_rol(safe_add(safe_add(a, q), safe_add(x, t)), s), b) +} +function md5_ff(a, b, c, d, x, s, t) { + return md5_cmn((b & c) | (~b & d), a, b, x, s, t) +} +function md5_gg(a, b, c, d, x, s, t) { + return md5_cmn((b & d) | (c & ~d), a, b, x, s, t) +} +function md5_hh(a, b, c, d, x, s, t) { + return md5_cmn(b ^ c ^ d, a, b, x, s, t) +} +function md5_ii(a, b, c, d, x, s, t) { + return md5_cmn(c ^ (b | ~d), a, b, x, s, t) +} + +/* + * Calculate the MD5 of an array of little-endian words, and a bit length. + */ +function binl_md5(x, len) { + /* append padding */ + x[len >> 5] |= 0x80 << len % 32 + x[(((len + 64) >>> 9) << 4) + 14] = len + + var i, + olda, + oldb, + oldc, + oldd, + a = 1732584193, + b = -271733879, + c = -1732584194, + d = 271733878 + + for (i = 0; i < x.length; i += 16) { + olda = a + oldb = b + oldc = c + oldd = d + + a = md5_ff(a, b, c, d, x[i], 7, -680876936) + d = md5_ff(d, a, b, c, x[i + 1], 12, -389564586) + c = md5_ff(c, d, a, b, x[i + 2], 17, 606105819) + b = md5_ff(b, c, d, a, x[i + 3], 22, -1044525330) + a = md5_ff(a, b, c, d, x[i + 4], 7, -176418897) + d = md5_ff(d, a, b, c, x[i + 5], 12, 1200080426) + c = md5_ff(c, d, a, b, x[i + 6], 17, -1473231341) + b = md5_ff(b, c, d, a, x[i + 7], 22, -45705983) + a = md5_ff(a, b, c, d, x[i + 8], 7, 1770035416) + d = md5_ff(d, a, b, c, x[i + 9], 12, -1958414417) + c = md5_ff(c, d, a, b, x[i + 10], 17, -42063) + b = md5_ff(b, c, d, a, x[i + 11], 22, -1990404162) + a = md5_ff(a, b, c, d, x[i + 12], 7, 1804603682) + d = md5_ff(d, a, b, c, x[i + 13], 12, -40341101) + c = md5_ff(c, d, a, b, x[i + 14], 17, -1502002290) + b = md5_ff(b, c, d, a, x[i + 15], 22, 1236535329) + + a = md5_gg(a, b, c, d, x[i + 1], 5, -165796510) + d = md5_gg(d, a, b, c, x[i + 6], 9, -1069501632) + c = md5_gg(c, d, a, b, x[i + 11], 14, 643717713) + b = md5_gg(b, c, d, a, x[i], 20, -373897302) + a = md5_gg(a, b, c, d, x[i + 5], 5, -701558691) + d = md5_gg(d, a, b, c, x[i + 10], 9, 38016083) + c = md5_gg(c, d, a, b, x[i + 15], 14, -660478335) + b = md5_gg(b, c, d, a, x[i + 4], 20, -405537848) + a = md5_gg(a, b, c, d, x[i + 9], 5, 568446438) + d = md5_gg(d, a, b, c, x[i + 14], 9, -1019803690) + c = md5_gg(c, d, a, b, x[i + 3], 14, -187363961) + b = md5_gg(b, c, d, a, x[i + 8], 20, 1163531501) + a = md5_gg(a, b, c, d, x[i + 13], 5, -1444681467) + d = md5_gg(d, a, b, c, x[i + 2], 9, -51403784) + c = md5_gg(c, d, a, b, x[i + 7], 14, 1735328473) + b = md5_gg(b, c, d, a, x[i + 12], 20, -1926607734) + + a = md5_hh(a, b, c, d, x[i + 5], 4, -378558) + d = md5_hh(d, a, b, c, x[i + 8], 11, -2022574463) + c = md5_hh(c, d, a, b, x[i + 11], 16, 1839030562) + b = md5_hh(b, c, d, a, x[i + 14], 23, -35309556) + a = md5_hh(a, b, c, d, x[i + 1], 4, -1530992060) + d = md5_hh(d, a, b, c, x[i + 4], 11, 1272893353) + c = md5_hh(c, d, a, b, x[i + 7], 16, -155497632) + b = md5_hh(b, c, d, a, x[i + 10], 23, -1094730640) + a = md5_hh(a, b, c, d, x[i + 13], 4, 681279174) + d = md5_hh(d, a, b, c, x[i], 11, -358537222) + c = md5_hh(c, d, a, b, x[i + 3], 16, -722521979) + b = md5_hh(b, c, d, a, x[i + 6], 23, 76029189) + a = md5_hh(a, b, c, d, x[i + 9], 4, -640364487) + d = md5_hh(d, a, b, c, x[i + 12], 11, -421815835) + c = md5_hh(c, d, a, b, x[i + 15], 16, 530742520) + b = md5_hh(b, c, d, a, x[i + 2], 23, -995338651) + + a = md5_ii(a, b, c, d, x[i], 6, -198630844) + d = md5_ii(d, a, b, c, x[i + 7], 10, 1126891415) + c = md5_ii(c, d, a, b, x[i + 14], 15, -1416354905) + b = md5_ii(b, c, d, a, x[i + 5], 21, -57434055) + a = md5_ii(a, b, c, d, x[i + 12], 6, 1700485571) + d = md5_ii(d, a, b, c, x[i + 3], 10, -1894986606) + c = md5_ii(c, d, a, b, x[i + 10], 15, -1051523) + b = md5_ii(b, c, d, a, x[i + 1], 21, -2054922799) + a = md5_ii(a, b, c, d, x[i + 8], 6, 1873313359) + d = md5_ii(d, a, b, c, x[i + 15], 10, -30611744) + c = md5_ii(c, d, a, b, x[i + 6], 15, -1560198380) + b = md5_ii(b, c, d, a, x[i + 13], 21, 1309151649) + a = md5_ii(a, b, c, d, x[i + 4], 6, -145523070) + d = md5_ii(d, a, b, c, x[i + 11], 10, -1120210379) + c = md5_ii(c, d, a, b, x[i + 2], 15, 718787259) + b = md5_ii(b, c, d, a, x[i + 9], 21, -343485551) + + a = safe_add(a, olda) + b = safe_add(b, oldb) + c = safe_add(c, oldc) + d = safe_add(d, oldd) + } + return [a, b, c, d] +} + +/* + * Convert an array of little-endian words to a string + */ +function binl2rstr(input) { + var i, + output = '' + for (i = 0; i < input.length * 32; i += 8) { + output += String.fromCharCode((input[i >> 5] >>> i % 32) & 0xff) + } + return output +} + +/* + * Convert a raw string to an array of little-endian words + * Characters >255 have their high-byte silently ignored. + */ +function rstr2binl(input) { + var i, + output = [] + output[(input.length >> 2) - 1] = undefined + for (i = 0; i < output.length; i += 1) { + output[i] = 0 + } + for (i = 0; i < input.length * 8; i += 8) { + output[i >> 5] |= (input.charCodeAt(i / 8) & 0xff) << i % 32 + } + return output +} + +/* + * Calculate the MD5 of a raw string + */ +function rstr_md5(s) { + return binl2rstr(binl_md5(rstr2binl(s), s.length * 8)) +} + +/* + * Calculate the HMAC-MD5, of a key and some data (raw strings) + */ +function rstr_hmac_md5(key, data) { + var i, + bkey = rstr2binl(key), + ipad = [], + opad = [], + hash + ipad[15] = opad[15] = undefined + if (bkey.length > 16) { + bkey = binl_md5(bkey, key.length * 8) + } + for (i = 0; i < 16; i += 1) { + ipad[i] = bkey[i] ^ 0x36363636 + opad[i] = bkey[i] ^ 0x5c5c5c5c + } + hash = binl_md5(ipad.concat(rstr2binl(data)), 512 + data.length * 8) + return binl2rstr(binl_md5(opad.concat(hash), 512 + 128)) +} + +/* + * Convert a raw string to a hex string + */ +function rstr2hex(input) { + var hex_tab = '0123456789abcdef', + output = '', + x, + i + for (i = 0; i < input.length; i += 1) { + x = input.charCodeAt(i) + output += hex_tab.charAt((x >>> 4) & 0x0f) + hex_tab.charAt(x & 0x0f) + } + return output +} + +/* + * Encode a string as utf-8 + */ +function str2rstr_utf8(input) { + return unescape(encodeURIComponent(input)) +} + +/* + * Take string arguments and return either raw or hex encoded strings + */ +function raw_md5(s) { + return rstr_md5(str2rstr_utf8(s)) +} +function hex_md5(s) { + return rstr2hex(raw_md5(s)) +} +function raw_hmac_md5(k, d) { + return rstr_hmac_md5(str2rstr_utf8(k), str2rstr_utf8(d)) +} +function hex_hmac_md5(k, d) { + return rstr2hex(raw_hmac_md5(k, d)) +} + +module.exports = function (string, key, raw) { + if (!key) { + if (!raw) { + return hex_md5(string) + } else { + return raw_md5(string) + } + } + if (!raw) { + return hex_hmac_md5(key, string) + } else { + return raw_hmac_md5(key, string) + } +} From b6356e3789332818380d5c30d7ed0904f5a49a48 Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sat, 20 Nov 2021 15:36:44 +0300 Subject: [PATCH 2/4] Create tv2go.t-2.net.test.js --- sites/tv2go.t-2.net/tv2go.t-2.net.test.js | 75 +++++++++++++++++++++++ 1 file changed, 75 insertions(+) create mode 100644 sites/tv2go.t-2.net/tv2go.t-2.net.test.js diff --git a/sites/tv2go.t-2.net/tv2go.t-2.net.test.js b/sites/tv2go.t-2.net/tv2go.t-2.net.test.js new file mode 100644 index 00000000..c4323051 --- /dev/null +++ b/sites/tv2go.t-2.net/tv2go.t-2.net.test.js @@ -0,0 +1,75 @@ +// node ./scripts/channels.js --config=./sites/tv2go.t-2.net/tv2go.t-2.net.config.js --output=./sites/tv2go.t-2.net/tv2go.t-2.net_si.channels.xml +// npx epg-grabber --config=sites/tv2go.t-2.net/tv2go.t-2.net.config.js --channels=sites/tv2go.t-2.net/tv2go.t-2.net_si.channels.xml --output=.gh-pages/guides/si/tv2go.t-2.net.epg.xml --days=2 + +const { parser, url, request, logo } = require('./tv2go.t-2.net.config.js') +const dayjs = require('dayjs') +const utc = require('dayjs/plugin/utc') +const customParseFormat = require('dayjs/plugin/customParseFormat') +dayjs.extend(customParseFormat) +dayjs.extend(utc) + +const date = dayjs.utc('2021-11-19', 'YYYY-MM-DD').startOf('d') +const channel = { + site_id: '1000259', + xmltv_id: 'TVSlovenija1.si', + logo: 'https://tv2go.t-2.net/static/media/img/channels/dark/ios/small/retina/145597.png' +} + +it('can generate valid url', () => { + expect(url({ date, channel })).toBe( + 'https://tv2go.t-2.net/Catherine/api/9.4/json/464830403846070/d79cf4dc84f2131689f426956b8d40de/client/tv/getEpg' + ) +}) + +it('can generate valid request headers', () => { + expect(request.headers).toMatchObject({ + 'Content-Type': 'application/json' + }) +}) + +it('can generate valid request data', () => { + expect(request.data({ date, channel })).toMatchObject({ + locale: 'sl-SI', + channelId: [1000259], + startTime: 1637280000000, + endTime: 1637366400000, + imageInfo: [{ height: 500, width: 1100 }], + includeBookmarks: false, + includeShow: true + }) +}) + +it('can generate valid logo url', () => { + expect(logo({ channel })).toBe( + 'https://tv2go.t-2.net/static/media/img/channels/dark/ios/small/retina/145597.png' + ) +}) + +it('can parse response', () => { + const content = `{"entries":[{"channelId":1000259,"startTimestamp":"1637283000000","endTimestamp":"1637284500000","name":"Dnevnik Slovencev v Italiji","nameSingleLine":"Dnevnik Slovencev v Italiji","description":"Informativni","images":[{"url":"/static/media/img/epg/max_crop/EPG_IMG_2927405.jpg","width":1008,"height":720,"averageColor":[143,147,161]}],"show":{"id":51991133,"title":"Dnevnik Slovencev v Italiji","originalTitle":"Dnevnik Slovencev v Italiji","shortDescription":"Dnevnik Slovencev v Italiji je informativna oddaja, v kateri novinarji poročajo predvsem o dnevnih dogodkih med Slovenci v Italiji.","longDescription":"Pomembno ogledalo vsakdana, v katerem opozarjajo na težave, s katerimi se soočajo, predstavljajo pa tudi pestro kulturno, športno in družbeno življenje slovenske narodne skupnosti. V oddajo so vključene tudi novice iz matične domovine.","type":{"id":10,"name":"Show"},"productionFrom":"1609502400000","countries":[{"id":"SI","name":"Slovenija"}],"languages":[{"languageId":2,"name":"Slovenščina"}],"genres":[{"id":1000002,"name":"Informativni"}]}}]}` + const result = parser({ content, channel }).map(p => { + p.start = p.start.toJSON() + p.stop = p.stop.toJSON() + return p + }) + + expect(result).toMatchObject([ + { + start: '2021-11-19T00:50:00.000Z', + stop: '2021-11-19T01:15:00.000Z', + title: `Dnevnik Slovencev v Italiji`, + category: ['Informativni'], + description: `Dnevnik Slovencev v Italiji je informativna oddaja, v kateri novinarji poročajo predvsem o dnevnih dogodkih med Slovenci v Italiji.`, + icon: 'https://tv2go.t-2.net/static/media/img/epg/max_crop/EPG_IMG_2927405.jpg' + } + ]) +}) + +it('can handle empty guide', () => { + const result = parser({ + date, + channel, + content: `Invalid API client identifier` + }) + expect(result).toMatchObject([]) +}) From 3e783359ffeeaff0f11d5c9cb91590ba3507aa20 Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sat, 20 Nov 2021 15:36:49 +0300 Subject: [PATCH 3/4] Create tv2go.t-2.net.config.js --- sites/tv2go.t-2.net/tv2go.t-2.net.config.js | 129 ++++++++++++++++++++ 1 file changed, 129 insertions(+) create mode 100644 sites/tv2go.t-2.net/tv2go.t-2.net.config.js diff --git a/sites/tv2go.t-2.net/tv2go.t-2.net.config.js b/sites/tv2go.t-2.net/tv2go.t-2.net.config.js new file mode 100644 index 00000000..c5bd3585 --- /dev/null +++ b/sites/tv2go.t-2.net/tv2go.t-2.net.config.js @@ -0,0 +1,129 @@ +const axios = require('axios') +const dayjs = require('dayjs') +const md5 = require('./jquery.md5') + +const API = { + locale: 'sl-SI', + version: '9.4', + format: 'json', + uuid: '464830403846070', + token: '6dace810-55d5-11e3-949a-0800200c9a66' +} + +const config = { + site: 'tv2go.t-2.net', + url({ date, channel }) { + const data = config.request.data({ date, channel }) + const endpoint = 'client/tv/getEpg' + const hash = generateHash(data, endpoint) + + return `https://tv2go.t-2.net/Catherine/api/${API.version}/${API.format}/${API.uuid}/${hash}/${endpoint}` + }, + request: { + method: 'POST', + headers: { + 'Content-Type': 'application/json' + }, + data({ date, channel }) { + const channelId = parseInt(channel.site_id) + + return { + locale: API.locale, + channelId: [channelId], + startTime: date.valueOf(), + endTime: date.add(1, 'd').valueOf(), + imageInfo: [{ height: 500, width: 1100 }], + includeBookmarks: false, + includeShow: true + } + } + }, + logo({ channel }) { + return channel.logo + }, + parser({ content }) { + let programs = [] + const items = parseItems(content) + items.forEach(item => { + programs.push({ + title: item.name, + category: parseCategory(item), + description: parseDescription(item), + icon: parseIcon(item), + start: parseStart(item), + stop: parseStop(item) + }) + }) + + return programs + }, + async channels() { + const data = { + locale: API.locale, + type: 'TV', + imageInfo: [{ type: 'DARK', height: 70, width: 98 }] + } + const endpoint = 'client/channels/list' + const hash = generateHash(data, endpoint) + const response = await axios + .post( + `https://tv2go.t-2.net/Catherine/api/${API.version}/${API.format}/${API.uuid}/${hash}/${endpoint}`, + data, + { + headers: { + 'Content-Type': 'application/json' + } + } + ) + .catch(console.log) + + return response.data.channels.map(item => { + return { + lang: 'sl', + site_id: item.id, + name: item.name, + logo: item.images[0] ? `https://tv2go.t-2.net${item.images[0].url}` : null + } + }) + } +} + +function parseStart(item) { + return dayjs(parseInt(item.startTimestamp)) +} + +function parseStop(item) { + return dayjs(parseInt(item.endTimestamp)) +} + +function parseIcon(item) { + return item.images && item.images[0] ? `https://tv2go.t-2.net${item.images[0].url}` : null +} + +function parseCategory(item) { + return item.show && Array.isArray(item.show.genres) ? item.show.genres.map(c => c.name) : [] +} + +function parseDescription(item) { + return item.show ? item.show.shortDescription : null +} + +function parseItems(content) { + let data + try { + data = JSON.parse(content) + } catch (e) { + return [] + } + if (!data || !Array.isArray(data.entries)) return [] + + return data.entries +} + +function generateHash(data, endpoint) { + const salt = `${API.token}${API.version}${API.format}${API.uuid}` + + return md5(salt + endpoint + JSON.stringify(data)) +} + +module.exports = config From e8ca8c2fc21a3c73a850551bf4abd664b815630e Mon Sep 17 00:00:00 2001 From: Aleksandr Statciuk Date: Sat, 20 Nov 2021 15:36:56 +0300 Subject: [PATCH 4/4] Create tv2go.t-2.net_si.channels.xml --- .../tv2go.t-2.net_si.channels.xml | 282 ++++++++++++++++++ 1 file changed, 282 insertions(+) create mode 100644 sites/tv2go.t-2.net/tv2go.t-2.net_si.channels.xml diff --git a/sites/tv2go.t-2.net/tv2go.t-2.net_si.channels.xml b/sites/tv2go.t-2.net/tv2go.t-2.net_si.channels.xml new file mode 100644 index 00000000..951c4cf5 --- /dev/null +++ b/sites/tv2go.t-2.net/tv2go.t-2.net_si.channels.xml @@ -0,0 +1,282 @@ + + + + 3sat + 24 Kitchen Adria + 360 Tune Box + A1 TV + Agro TV + Aljazeera Balkans + Alsat-M + AMC Balkan + Animal Planet Europe + Anixe HD Serie + Arena Esport + Arena Fight + Arena Sport 1 + Arena Sport 2 + Arena Sport 3 + Arena Sport 4 + ARTE Français + ATM TV + B92 + Baby TV Europe + Balkanika Music TV + Balkan Trip + Barely Legal TV + BBC Earth Romania + BBC First Polska + BHT 1 + BK TV + BN 2 + BN Music + Boomerang Central & Eastern Europe + Boom TV + Brio + Cartoon Network Central & Eastern Europe + CBS Reality Europe + CGTN + Cinemax 2 Central Europe + Cinemax Central Europe + CineStar TV 1 Srbija + CineStar TV Action Srbija + CineStar TV Comedy + CineStar TV Fantasy + CineStar TV Premiere 1 + CineStar TV Premiere 2 + Club MTV + CMC TV + CNN International Europe + Crime + Investigation UK + Das Erste + Da Vinci + Discovery Channel Srbija + Discovery Science + Disney Channel Polska + Disney Junior Romania & Bulgaria + Diva Adria + DM Sat + DocuBox HD + Dom Kino International + Dorcel XXX + Dr. Fit + DTX East Europe + Duna TV + Duna World + Dusk + E! Europe + Elta 2 + Elta TV + Epic Drama + ePosavje TV + Erox HD + Eroxxx HD + ETV + EuroNews English + Eurosport 1 + Eurosport 1 Germany + Eurosport 2 + Eurosport 4K + EWTN Europe + Exodus TV + Extreme Sports Channel + FashionBox HD + FashionTV Europe + Fast & FunBox HD + Federalna TV + Fen Folk + Fen TV + FightBox HD + FilmBox Arthouse Worldwide + FilmBox Extra HD Adria + FilmBox Premium Adria + FilmBox Stars Adria + Fox Crime Srbija + Fox Life Srbija + Fox Movies Slovenija + Fox Srbija + France 2 + France 24 English + France 24 Français + FunBox UHD + Gametoon + Gea TV + Gold TV + Golica TV + Happy + Hayat + Hayat Folk + HBO 2 Central Europe + HBO 3 Central Europe + HBO Adria + Hema TV + HGTV Pan Regional + History 2 Polska + History Europe + HRT 1 + HRT 2 + Hustler HD Europe + Hustler TV Europe + Investigation Discovery Europe + JimJam Europe + Jugoton TV + Kabel Eins Deutschland + Kanal 5 + Kanal A + Kanali 7 + Karusel International + K CN 1 + K CN 2 + K CN 3 + Kino + Klasik TV + Koroška TV + Ljubljana TV + M1 + M2 + M5 + Mezzo + Mezzo Live HD + Minimax Serbia + Mreža TV + MRT 1 + MRT 2 + MTV 00s + MTV 80s + MTV 90s + MTV Global + MTV Hits Europe + MTV Live + Muzika Pervogo International + MyZen TV + MyZen TV 4K + Narodna TV + National Geographic Channel HD Europe + National Geographic Wild Europe + Net TV + NHK World Japan + Nickelodeon Europe + Nick Jr Central & Eastern Europe + Nova 24 TV + Nova 24 TV 2 + NTV IC Kakanj + OBN + O Kanal + ORF 1 + ORF 2 Europe + Oron TV + Oto + OTV + OTV Valentino + Perviy kanal Europa + PeTV + Pink Extra + Pink Film + Pink Folk 1 + Pink Hits + Pink Music + Pink Plus + Pink Reality + Pink SI + Pink World + Pink Zabava + Planet Earth + Planet Eva + Planet TV + Planet TV 2 + Pop TV + ProSieben Deutschland + Prva Srpska TV + Rai 1 + Rai 2 + Rai 3 + RTK 1 + RTL 2 Hrvatska + RTL Deutschland + RTL Hrvatska + RTL II + RTL Kockica + RTL Living Deutschland + RT News + RTRS TV + RTS 1 + RTS 2 + RTS Klasika + RTVi Europe + RTV Vikom + Sat. 1 Deutschland + Scifi Srbija + Servus TV Österreich + Sexation TV + SIP TV + Sitel TV + Sky News International + Sport 1 + Sport TV 1 + Sport TV 2 + Sport TV 3 + Stingray Festival 4K + S-TV Skledar + SuperOne HD + Super RTL Deutschland + T-2 Info + Telecafé International + Telma + TLC Balkan + Tlnovelas Europa + TNT Comedy + TNT Music + Top TV + Toxic TV + Trace Sport Stars + Trace Urban + Travel Channel Europe + Travelxp 4K Europe + Travelxp HD Europe + Tring Action + Tring Shqip + Tring Tring + Tržič TV + TV 3 + TV 8 + TV 24 + TV 1000 Balkan + TV Arena + TV AS + TV Celje + TV Centr International + TVCG Sat + TV Duga + + TVE Internacional Europa + TV Galeja + TV IDEA + TV Jadran + TV Komenda + TV Koper-Capodistria + TV Maribor + TV Miklavž + TVSA + TV Slon Extra + TV Slovenija 1 + TV Slovenija 2 + TV Slovenija 3 + TV Vijesti + Vaš Kanal + Veseljak TV + Viasat Explore East + Viasat History HD + Viasat Nature East + Vitel + Vizion Plus + Vox Deutschland + Vremya International + VTV + vŽIVO.si + Welt + Woman + Z1 + ZDF + Zdrava TV + Zdrava TV 7 Hrvatska + + \ No newline at end of file