mirror of
https://github.com/iptv-org/database.git
synced 2024-12-28 10:14:33 -05:00
104 lines
2 KiB
JavaScript
104 lines
2 KiB
JavaScript
const csv2json = require('csvtojson')
|
|
const chalk = require('chalk')
|
|
const logger = require('./logger')
|
|
const fs = require('mz/fs')
|
|
const {
|
|
Parser,
|
|
transforms: { flatten },
|
|
formatters: { stringQuoteOnlyIfNecessary }
|
|
} = require('json2csv')
|
|
|
|
const csv2jsonOptions = {
|
|
checkColumn: true,
|
|
trim: true,
|
|
delimiter: ',',
|
|
eol: '\r\n',
|
|
colParser: {
|
|
countries: listParser,
|
|
languages: listParser,
|
|
categories: listParser,
|
|
broadcast_area: listParser,
|
|
is_nsfw: boolParser,
|
|
logo: nullable,
|
|
subdivision: nullable,
|
|
city: nullable,
|
|
network: nullable,
|
|
launched: nullable,
|
|
closed: nullable,
|
|
website: nullable,
|
|
native_name: nullable,
|
|
replaced_by: nullable
|
|
}
|
|
}
|
|
|
|
const json2csv = new Parser({
|
|
transforms: [flattenArray, formatBool],
|
|
formatters: {
|
|
string: stringQuoteOnlyIfNecessary()
|
|
},
|
|
eol: '\r\n'
|
|
})
|
|
|
|
const csv = {}
|
|
|
|
csv.fromFile = async function (filepath) {
|
|
return csv2json(csv2jsonOptions).fromFile(filepath)
|
|
}
|
|
|
|
csv.fromString = async function (filepath) {
|
|
return csv2json(csv2jsonOptions).fromString(filepath)
|
|
}
|
|
|
|
csv.save = async function (filepath, data) {
|
|
const string = json2csv.parse(data)
|
|
|
|
return fs.writeFile(filepath, string)
|
|
}
|
|
|
|
csv.saveSync = function (filepath, data) {
|
|
const string = json2csv.parse(data)
|
|
|
|
return fs.writeFileSync(filepath, string)
|
|
}
|
|
|
|
module.exports = csv
|
|
|
|
function flattenArray(item) {
|
|
for (let prop in item) {
|
|
const value = item[prop]
|
|
item[prop] = Array.isArray(value) ? value.join(';') : value
|
|
}
|
|
|
|
return item
|
|
}
|
|
|
|
function formatBool(item) {
|
|
for (let prop in item) {
|
|
if (item[prop] === false) {
|
|
item[prop] = 'FALSE'
|
|
} else if (item[prop] === true) {
|
|
item[prop] = 'TRUE'
|
|
}
|
|
}
|
|
|
|
return item
|
|
}
|
|
|
|
function listParser(value) {
|
|
return value.split(';').filter(i => i)
|
|
}
|
|
|
|
function boolParser(value) {
|
|
switch (value) {
|
|
case 'TRUE':
|
|
return true
|
|
case 'FALSE':
|
|
return false
|
|
default:
|
|
return value
|
|
}
|
|
}
|
|
|
|
function nullable(value) {
|
|
return value === '' ? null : value
|
|
}
|