mirror of
https://github.com/iptv-org/database.git
synced 2024-12-22 07:50:23 -05:00
Merge pull request #14600 from iptv-org/freearhey-patch1
Patch 2024.12.1
This commit is contained in:
commit
f8bce428fa
24 changed files with 1964 additions and 1951 deletions
|
@ -1,39 +0,0 @@
|
||||||
{
|
|
||||||
"env": {
|
|
||||||
"node": true,
|
|
||||||
"es2021": true,
|
|
||||||
"jest": true
|
|
||||||
},
|
|
||||||
"extends": [
|
|
||||||
"eslint:recommended",
|
|
||||||
"plugin:@typescript-eslint/recommended",
|
|
||||||
"prettier"
|
|
||||||
],
|
|
||||||
"parser": "@typescript-eslint/parser",
|
|
||||||
"parserOptions": {
|
|
||||||
"ecmaVersion": "latest",
|
|
||||||
"sourceType": "module"
|
|
||||||
},
|
|
||||||
"plugins": [
|
|
||||||
"@typescript-eslint"
|
|
||||||
],
|
|
||||||
"rules": {
|
|
||||||
"@typescript-eslint/no-var-requires": "off",
|
|
||||||
"no-case-declarations": "off",
|
|
||||||
"linebreak-style": [
|
|
||||||
"error",
|
|
||||||
"unix"
|
|
||||||
],
|
|
||||||
"quotes": [
|
|
||||||
"error",
|
|
||||||
"single",
|
|
||||||
{
|
|
||||||
"avoidEscape": true
|
|
||||||
}
|
|
||||||
],
|
|
||||||
"semi": [
|
|
||||||
"error",
|
|
||||||
"never"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
2
.github/workflows/check.yml
vendored
2
.github/workflows/check.yml
vendored
|
@ -13,7 +13,7 @@ jobs:
|
||||||
- uses: actions/setup-node@v3
|
- uses: actions/setup-node@v3
|
||||||
if: ${{ !env.ACT }}
|
if: ${{ !env.ACT }}
|
||||||
with:
|
with:
|
||||||
node-version: '18.18.2'
|
node-version: '22.12.0'
|
||||||
cache: 'npm'
|
cache: 'npm'
|
||||||
- uses: tj-actions/changed-files@v35
|
- uses: tj-actions/changed-files@v35
|
||||||
id: files
|
id: files
|
||||||
|
|
2
.github/workflows/deploy.yml
vendored
2
.github/workflows/deploy.yml
vendored
|
@ -12,7 +12,7 @@ jobs:
|
||||||
- uses: actions/setup-node@v3
|
- uses: actions/setup-node@v3
|
||||||
if: ${{ !env.ACT }}
|
if: ${{ !env.ACT }}
|
||||||
with:
|
with:
|
||||||
node-version: '18.18.2'
|
node-version: '22.12.0'
|
||||||
cache: 'npm'
|
cache: 'npm'
|
||||||
- name: install dependencies
|
- name: install dependencies
|
||||||
run: npm install
|
run: npm install
|
||||||
|
|
2
.github/workflows/update.yml
vendored
2
.github/workflows/update.yml
vendored
|
@ -21,7 +21,7 @@ jobs:
|
||||||
- uses: actions/setup-node@v3
|
- uses: actions/setup-node@v3
|
||||||
if: ${{ !env.ACT }}
|
if: ${{ !env.ACT }}
|
||||||
with:
|
with:
|
||||||
node-version: '18.18.2'
|
node-version: '22.12.0'
|
||||||
cache: 'npm'
|
cache: 'npm'
|
||||||
- name: install dependencies
|
- name: install dependencies
|
||||||
run: npm install
|
run: npm install
|
||||||
|
|
51
eslint.config.mjs
Normal file
51
eslint.config.mjs
Normal file
|
@ -0,0 +1,51 @@
|
||||||
|
import typescriptEslint from '@typescript-eslint/eslint-plugin'
|
||||||
|
import globals from 'globals'
|
||||||
|
import tsParser from '@typescript-eslint/parser'
|
||||||
|
import path from 'node:path'
|
||||||
|
import { fileURLToPath } from 'node:url'
|
||||||
|
import js from '@eslint/js'
|
||||||
|
import { FlatCompat } from '@eslint/eslintrc'
|
||||||
|
|
||||||
|
const __filename = fileURLToPath(import.meta.url)
|
||||||
|
const __dirname = path.dirname(__filename)
|
||||||
|
const compat = new FlatCompat({
|
||||||
|
baseDirectory: __dirname,
|
||||||
|
recommendedConfig: js.configs.recommended,
|
||||||
|
allConfig: js.configs.all
|
||||||
|
})
|
||||||
|
|
||||||
|
export default [
|
||||||
|
...compat.extends('eslint:recommended', 'plugin:@typescript-eslint/recommended', 'prettier'),
|
||||||
|
{
|
||||||
|
plugins: {
|
||||||
|
'@typescript-eslint': typescriptEslint
|
||||||
|
},
|
||||||
|
|
||||||
|
languageOptions: {
|
||||||
|
globals: {
|
||||||
|
...globals.node,
|
||||||
|
...globals.jest
|
||||||
|
},
|
||||||
|
|
||||||
|
parser: tsParser,
|
||||||
|
ecmaVersion: 'latest',
|
||||||
|
sourceType: 'module'
|
||||||
|
},
|
||||||
|
|
||||||
|
rules: {
|
||||||
|
'@typescript-eslint/no-var-requires': 'off',
|
||||||
|
'no-case-declarations': 'off',
|
||||||
|
'linebreak-style': ['error', 'unix'],
|
||||||
|
|
||||||
|
quotes: [
|
||||||
|
'error',
|
||||||
|
'single',
|
||||||
|
{
|
||||||
|
avoidEscape: true
|
||||||
|
}
|
||||||
|
],
|
||||||
|
|
||||||
|
semi: ['error', 'never']
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
2797
package-lock.json
generated
2797
package-lock.json
generated
File diff suppressed because it is too large
Load diff
15
package.json
15
package.json
|
@ -11,7 +11,7 @@
|
||||||
"test": "jest --runInBand"
|
"test": "jest --runInBand"
|
||||||
},
|
},
|
||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=18.0.0 <18.19.0"
|
"node": ">=18.0.0 <=22.12.0"
|
||||||
},
|
},
|
||||||
"pre-commit": [
|
"pre-commit": [
|
||||||
"db:validate"
|
"db:validate"
|
||||||
|
@ -34,18 +34,23 @@
|
||||||
"@octokit/plugin-paginate-rest": "^6.0.0",
|
"@octokit/plugin-paginate-rest": "^6.0.0",
|
||||||
"@octokit/plugin-rest-endpoint-methods": "^7.1.3",
|
"@octokit/plugin-rest-endpoint-methods": "^7.1.3",
|
||||||
"@types/jest": "^29.5.5",
|
"@types/jest": "^29.5.5",
|
||||||
"@typescript-eslint/eslint-plugin": "^6.7.4",
|
"@typescript-eslint/eslint-plugin": "^8.17.0",
|
||||||
"chalk": "^4.1.2",
|
"chalk": "^4.1.2",
|
||||||
"commander": "^9.0.0",
|
"commander": "^9.0.0",
|
||||||
"csvtojson": "^2.0.10",
|
"csvtojson": "^2.0.10",
|
||||||
"eslint": "^8.50.0",
|
"eslint": "^9.16.0",
|
||||||
"eslint-config-prettier": "^9.0.0",
|
"eslint-config-prettier": "^9.0.0",
|
||||||
|
"fs-extra": "^11.2.0",
|
||||||
"jest": "^29.7.0",
|
"jest": "^29.7.0",
|
||||||
"joi": "^17.6.0",
|
"joi": "^17.13.3",
|
||||||
"ts-jest": "^29.1.1",
|
"ts-jest": "^29.1.1",
|
||||||
"tsx": "^4.10.5"
|
"tsx": "^4.10.5"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"pre-commit": "^1.2.2"
|
"@eslint/eslintrc": "^3.2.0",
|
||||||
|
"@eslint/js": "^9.16.0",
|
||||||
|
"@types/joi": "^17.2.3",
|
||||||
|
"globals": "^15.13.0",
|
||||||
|
"pre-commit": "^1.0.10"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -15,19 +15,24 @@ export class IssueLoader {
|
||||||
if (TESTING) {
|
if (TESTING) {
|
||||||
switch (labels) {
|
switch (labels) {
|
||||||
case 'channels:add,approved':
|
case 'channels:add,approved':
|
||||||
issues = require('../../tests/__data__/input/issues/channels_add_approved.js')
|
issues = (await import('../../tests/__data__/input/issues/channels_add_approved.js'))
|
||||||
|
.default
|
||||||
break
|
break
|
||||||
case 'channels:edit,approved':
|
case 'channels:edit,approved':
|
||||||
issues = require('../../tests/__data__/input/issues/channels_edit_approved.js')
|
issues = (await import('../../tests/__data__/input/issues/channels_edit_approved.js'))
|
||||||
|
.default
|
||||||
break
|
break
|
||||||
case 'channels:remove,approved':
|
case 'channels:remove,approved':
|
||||||
issues = require('../../tests/__data__/input/issues/channels_remove_approved.js')
|
issues = (await import('../../tests/__data__/input/issues/channels_remove_approved.js'))
|
||||||
|
.default
|
||||||
break
|
break
|
||||||
case 'blocklist:add,approved':
|
case 'blocklist:add,approved':
|
||||||
issues = require('../../tests/__data__/input/issues/blocklist_add_approved.js')
|
issues = (await import('../../tests/__data__/input/issues/blocklist_add_approved.js'))
|
||||||
|
.default
|
||||||
break
|
break
|
||||||
case 'blocklist:remove,approved':
|
case 'blocklist:remove,approved':
|
||||||
issues = require('../../tests/__data__/input/issues/blocklist_remove_approved.js')
|
issues = (await import('../../tests/__data__/input/issues/blocklist_remove_approved.js'))
|
||||||
|
.default
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
import { Collection, Storage, File, Dictionary, Logger } from '@freearhey/core'
|
import { Collection, Storage, File, Dictionary, Logger } from '@freearhey/core'
|
||||||
import { DATA_DIR } from '../constants'
|
import { DATA_DIR } from '../constants'
|
||||||
|
import schemesData from '../schemes'
|
||||||
import { program } from 'commander'
|
import { program } from 'commander'
|
||||||
import Joi from 'joi'
|
import Joi from 'joi'
|
||||||
import { CSVParser, IDCreator } from '../core'
|
import { CSVParser, IDCreator } from '../core'
|
||||||
|
@ -10,7 +11,7 @@ program.argument('[filepath]', 'Path to file to validate').parse(process.argv)
|
||||||
const logger = new Logger()
|
const logger = new Logger()
|
||||||
const buffer = new Dictionary()
|
const buffer = new Dictionary()
|
||||||
const files = new Dictionary()
|
const files = new Dictionary()
|
||||||
const schemes: { [key: string]: object } = require('../schemes')
|
const schemes: { [key: string]: object } = schemesData
|
||||||
|
|
||||||
async function main() {
|
async function main() {
|
||||||
const dataStorage = new Storage(DATA_DIR)
|
const dataStorage = new Storage(DATA_DIR)
|
||||||
|
|
|
@ -1,8 +0,0 @@
|
||||||
const Joi = require('joi')
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
channel: Joi.string()
|
|
||||||
.regex(/^[A-Za-z0-9]+\.[a-z]{2}$/)
|
|
||||||
.required(),
|
|
||||||
ref: Joi.string().uri().required()
|
|
||||||
}
|
|
8
scripts/schemes/blocklist.ts
Normal file
8
scripts/schemes/blocklist.ts
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
import Joi from 'joi'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
channel: Joi.string()
|
||||||
|
.regex(/^[A-Za-z0-9]+\.[a-z]{2}$/)
|
||||||
|
.required(),
|
||||||
|
ref: Joi.string().uri().required()
|
||||||
|
}
|
|
@ -1,10 +0,0 @@
|
||||||
const Joi = require('joi')
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
id: Joi.string()
|
|
||||||
.regex(/^[a-z]+$/)
|
|
||||||
.required(),
|
|
||||||
name: Joi.string()
|
|
||||||
.regex(/^[A-Z]+$/i)
|
|
||||||
.required()
|
|
||||||
}
|
|
10
scripts/schemes/categories.ts
Normal file
10
scripts/schemes/categories.ts
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
import Joi from 'joi'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
id: Joi.string()
|
||||||
|
.regex(/^[a-z]+$/)
|
||||||
|
.required(),
|
||||||
|
name: Joi.string()
|
||||||
|
.regex(/^[A-Z]+$/i)
|
||||||
|
.required()
|
||||||
|
}
|
|
@ -1,8 +1,11 @@
|
||||||
const Joi = require('joi').extend(require('@joi/date'))
|
import BaseJoi from 'joi'
|
||||||
const path = require('path')
|
import JoiDate from '@joi/date'
|
||||||
const url = require('url')
|
import path from 'path'
|
||||||
|
import url from 'url'
|
||||||
|
|
||||||
module.exports = {
|
const Joi = BaseJoi.extend(JoiDate)
|
||||||
|
|
||||||
|
export default {
|
||||||
id: Joi.string()
|
id: Joi.string()
|
||||||
.regex(/^[A-Za-z0-9]+\.[a-z]{2}$/)
|
.regex(/^[A-Za-z0-9]+\.[a-z]{2}$/)
|
||||||
.required(),
|
.required(),
|
|
@ -1,18 +0,0 @@
|
||||||
const Joi = require('joi')
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
name: Joi.string()
|
|
||||||
.regex(/^[\sA-Z\u00C0-\u00FF().-]+$/i)
|
|
||||||
.required(),
|
|
||||||
code: Joi.string()
|
|
||||||
.regex(/^[A-Z]{2}$/)
|
|
||||||
.required(),
|
|
||||||
languages: Joi.array().items(
|
|
||||||
Joi.string()
|
|
||||||
.regex(/^[a-z]{3}$/)
|
|
||||||
.required()
|
|
||||||
),
|
|
||||||
flag: Joi.string()
|
|
||||||
.regex(/^[\uD83C][\uDDE6-\uDDFF][\uD83C][\uDDE6-\uDDFF]$/)
|
|
||||||
.required()
|
|
||||||
}
|
|
18
scripts/schemes/countries.ts
Normal file
18
scripts/schemes/countries.ts
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
import Joi from 'joi'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: Joi.string()
|
||||||
|
.regex(/^[\sA-Z\u00C0-\u00FF().-]+$/i)
|
||||||
|
.required(),
|
||||||
|
code: Joi.string()
|
||||||
|
.regex(/^[A-Z]{2}$/)
|
||||||
|
.required(),
|
||||||
|
languages: Joi.array().items(
|
||||||
|
Joi.string()
|
||||||
|
.regex(/^[a-z]{3}$/)
|
||||||
|
.required()
|
||||||
|
),
|
||||||
|
flag: Joi.string()
|
||||||
|
.regex(/^[\uD83C][\uDDE6-\uDDFF][\uD83C][\uDDE6-\uDDFF]$/)
|
||||||
|
.required()
|
||||||
|
}
|
|
@ -1,7 +0,0 @@
|
||||||
exports.channels = require('./channels')
|
|
||||||
exports.categories = require('./categories')
|
|
||||||
exports.countries = require('./countries')
|
|
||||||
exports.languages = require('./languages')
|
|
||||||
exports.regions = require('./regions')
|
|
||||||
exports.subdivisions = require('./subdivisions')
|
|
||||||
exports.blocklist = require('./blocklist')
|
|
17
scripts/schemes/index.ts
Normal file
17
scripts/schemes/index.ts
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
import { default as channels } from './channels'
|
||||||
|
import { default as categories } from './categories'
|
||||||
|
import { default as countries } from './countries'
|
||||||
|
import { default as languages } from './languages'
|
||||||
|
import { default as regions } from './regions'
|
||||||
|
import { default as subdivisions } from './subdivisions'
|
||||||
|
import { default as blocklist } from './blocklist'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
channels,
|
||||||
|
categories,
|
||||||
|
countries,
|
||||||
|
languages,
|
||||||
|
regions,
|
||||||
|
subdivisions,
|
||||||
|
blocklist
|
||||||
|
}
|
|
@ -1,8 +0,0 @@
|
||||||
const Joi = require('joi')
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
code: Joi.string()
|
|
||||||
.regex(/^[a-z]{3}$/)
|
|
||||||
.required(),
|
|
||||||
name: Joi.string().required()
|
|
||||||
}
|
|
8
scripts/schemes/languages.ts
Normal file
8
scripts/schemes/languages.ts
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
import Joi from 'joi'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
code: Joi.string()
|
||||||
|
.regex(/^[a-z]{3}$/)
|
||||||
|
.required(),
|
||||||
|
name: Joi.string().required()
|
||||||
|
}
|
|
@ -1,6 +1,6 @@
|
||||||
const Joi = require('joi')
|
import Joi from 'joi'
|
||||||
|
|
||||||
module.exports = {
|
export default {
|
||||||
name: Joi.string()
|
name: Joi.string()
|
||||||
.regex(/^[\sA-Z\u00C0-\u00FF().,-]+$/i)
|
.regex(/^[\sA-Z\u00C0-\u00FF().,-]+$/i)
|
||||||
.required(),
|
.required(),
|
|
@ -1,11 +0,0 @@
|
||||||
const Joi = require('joi')
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
country: Joi.string()
|
|
||||||
.regex(/^[A-Z]{2}$/)
|
|
||||||
.required(),
|
|
||||||
name: Joi.string().required(),
|
|
||||||
code: Joi.string()
|
|
||||||
.regex(/^[A-Z]{2}-[A-Z0-9]{1,3}$/)
|
|
||||||
.required()
|
|
||||||
}
|
|
11
scripts/schemes/subdivisions.ts
Normal file
11
scripts/schemes/subdivisions.ts
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
import Joi from 'joi'
|
||||||
|
|
||||||
|
export default {
|
||||||
|
country: Joi.string()
|
||||||
|
.regex(/^[A-Z]{2}$/)
|
||||||
|
.required(),
|
||||||
|
name: Joi.string().required(),
|
||||||
|
code: Joi.string()
|
||||||
|
.regex(/^[A-Z]{2}-[A-Z0-9]{1,3}$/)
|
||||||
|
.required()
|
||||||
|
}
|
Loading…
Reference in a new issue