iptv/scripts/utils.js

222 lines
4.8 KiB
JavaScript
Raw Normal View History

2020-04-11 03:33:53 +02:00
const fs = require('fs')
2019-07-20 09:03:31 +02:00
const path = require('path')
const axios = require('axios')
2020-04-11 03:33:53 +02:00
const zlib = require('zlib')
const urlParser = require('url')
2019-11-02 10:45:09 +01:00
const escapeStringRegexp = require('escape-string-regexp')
const markdownInclude = require('markdown-include')
2020-04-18 16:16:56 +02:00
const iso6393 = require('iso-639-3')
2019-11-02 10:45:09 +01:00
let helper = {}
2020-05-06 17:01:36 +02:00
helper.code2flag = function (code) {
switch (code) {
case 'uk':
return '🇬🇧'
case 'int':
return '🌎'
2020-09-17 22:30:28 +02:00
case 'unsorted':
return ''
2020-05-06 17:01:36 +02:00
default:
return code
.toUpperCase()
.replace(/./g, char => String.fromCodePoint(char.charCodeAt(0) + 127397))
}
}
2021-01-29 23:58:52 +01:00
helper.code2name = function (code) {
const intlDisplayNames = new Intl.DisplayNames(['en'], {
style: 'long',
type: 'region'
})
try {
return intlDisplayNames.of(code.toUpperCase())
} catch (e) {
return null
}
}
helper.language2code = function (name) {
const lang = iso6393.find(l => l.name === name)
return lang && lang.iso6393 ? lang.iso6393 : null
}
2020-04-11 03:33:53 +02:00
helper.sortBy = function (arr, fields) {
2019-11-02 13:43:41 +01:00
return arr.sort((a, b) => {
2020-04-11 03:33:53 +02:00
for (let field of fields) {
2020-05-04 15:23:03 +02:00
let propA = a[field] ? a[field].toLowerCase() : ''
let propB = b[field] ? b[field].toLowerCase() : ''
if (propA < propB) {
2020-04-11 03:33:53 +02:00
return -1
}
2020-05-04 15:23:03 +02:00
if (propA > propB) {
2020-04-11 03:33:53 +02:00
return 1
}
2019-11-02 13:43:41 +01:00
}
return 0
})
}
2021-01-29 23:58:52 +01:00
helper.loadEPG = function (url) {
2019-08-07 15:51:34 +02:00
return new Promise((resolve, reject) => {
var buffer = []
axios({
method: 'get',
url: url,
2019-11-03 17:00:57 +01:00
responseType: 'stream',
2020-05-04 15:23:03 +02:00
timeout: 60000
2020-04-11 03:33:53 +02:00
})
2020-05-04 15:23:03 +02:00
.then(res => {
2020-04-11 03:33:53 +02:00
let stream
if (/\.gz$/i.test(url)) {
let gunzip = zlib.createGunzip()
res.data.pipe(gunzip)
stream = gunzip
} else {
stream = res.data
}
stream
.on('data', function (data) {
buffer.push(data.toString())
})
.on('end', function () {
resolve(buffer.join(''))
})
.on('error', function (e) {
reject(e)
})
})
2020-05-04 15:23:03 +02:00
.catch(e => {
2019-08-07 15:51:34 +02:00
reject(e)
})
})
2019-07-20 09:03:31 +02:00
}
2021-01-29 23:58:52 +01:00
helper.getBasename = function (filename) {
return path.basename(filename, path.extname(filename))
2019-08-07 15:51:34 +02:00
}
2021-01-29 23:58:52 +01:00
helper.filterPlaylists = function (arr, include = '', exclude = '') {
if (include) {
const included = include.split(',').map(filename => `channels/${filename}.m3u`)
2019-07-20 09:03:31 +02:00
2021-01-29 23:58:52 +01:00
return arr.filter(i => included.indexOf(i.url) > -1)
}
2019-07-20 09:03:31 +02:00
2021-01-29 23:58:52 +01:00
if (exclude) {
const excluded = exclude.split(',').map(filename => `channels/${filename}.m3u`)
2021-01-29 23:58:52 +01:00
return arr.filter(i => excluded.indexOf(i.url) === -1)
}
2021-01-29 23:58:52 +01:00
return arr
}
2020-04-11 03:33:53 +02:00
helper.generateTable = function (data, options) {
let output = '<table>\n'
2019-10-23 08:38:32 +02:00
output += '\t<thead>\n\t\t<tr>'
2019-10-23 08:38:32 +02:00
for (let column of options.columns) {
output += `<th align="${column.align}">${column.name}</th>`
}
output += '</tr>\n\t</thead>\n'
2019-10-23 08:38:32 +02:00
output += '\t<tbody>\n'
2019-10-23 08:38:32 +02:00
for (let item of data) {
output += '\t\t<tr>'
2019-10-23 08:38:32 +02:00
let i = 0
for (let prop in item) {
const column = options.columns[i]
let nowrap = column.nowrap
let align = column.align
output += `<td align="${align}"${nowrap ? ' nowrap' : ''}>${item[prop]}</td>`
i++
}
output += '</tr>\n'
2019-10-23 08:38:32 +02:00
}
output += '\t</tbody>\n'
2019-10-23 08:38:32 +02:00
output += '</table>'
return output
2019-10-09 04:33:52 +02:00
}
2021-01-29 23:58:52 +01:00
helper.createDir = function (dir) {
if (!fs.existsSync(dir)) {
fs.mkdirSync(dir)
}
2019-11-02 15:30:12 +01:00
}
2021-01-29 23:58:52 +01:00
helper.readFile = function (filename) {
return fs.readFileSync(path.resolve(__dirname) + `/../${filename}`, { encoding: 'utf8' })
2019-11-03 18:21:35 +01:00
}
2021-01-29 23:58:52 +01:00
helper.appendToFile = function (filename, data) {
fs.appendFileSync(path.resolve(__dirname) + '/../' + filename, data)
}
2021-01-29 23:58:52 +01:00
helper.compileMarkdown = function (filepath) {
return markdownInclude.compileFiles(path.resolve(__dirname, filepath))
}
2021-01-29 23:58:52 +01:00
helper.escapeStringRegexp = function (scring) {
return escapeStringRegexp(string)
}
2021-01-29 23:58:52 +01:00
helper.createFile = function (filename, data = '') {
fs.writeFileSync(path.resolve(__dirname) + '/../' + filename, data)
}
2021-01-29 23:58:52 +01:00
helper.writeToLog = function (country, msg, url) {
var now = new Date()
var line = `${country}: ${msg} '${url}'`
this.appendToFile('error.log', now.toISOString() + ' ' + line + '\n')
2020-05-04 15:23:03 +02:00
}
2021-01-27 16:54:22 +01:00
helper.filterNSFW = function (arr) {
const sfwCategories = [
'Auto',
'Business',
'Classic',
'Comedy',
'Documentary',
'Education',
'Entertainment',
'Family',
'Fashion',
'Food',
'General',
'Health',
'History',
'Hobby',
'Kids',
'Legislative',
'Lifestyle',
'Local',
'Movies',
'Music',
'News',
'Quiz',
'Religious',
'Sci-Fi',
'Shop',
'Sport',
'Travel',
'Weather'
]
return arr.filter(i => sfwCategories.includes(i.category))
}
2021-01-19 23:02:24 +01:00
helper.sleep = function (ms) {
return function (x) {
return new Promise(resolve => setTimeout(() => resolve(x), ms))
}
}
2020-04-11 03:33:53 +02:00
module.exports = helper