2021-03-13 13:48:58 +01:00
# EPG Grabber
2021-03-13 15:31:16 +01:00
Node.js CLI tool for grabbing EPG from different websites.
2021-03-13 13:48:58 +01:00
## Installation
```sh
npm install -g epg-grabber
```
## Usage
```sh
epg-grabber --config=example.com.config.js
```
Arguments:
- `-c, --config` : path to config file
- `-d, --debug` : enable debug mode
2021-03-13 15:29:54 +01:00
**example.com.config.js**
```js
module.exports = {
lang: 'fr', // program language (default: 'en')
site: 'example.com', // site domain name (required)
output: 'example.com.guide.xml', // path to output file (default: 'guide.xml')
channels: 'example.com.channels.xml', // path to channels.xml file (required)
/**
* @param {object} date The 'dayjs' instance with the requested date
* @param {object} channel Data about the requested channel
*
* @return {string} The function should return URL of the program page for the channel
*/
url: function ({ date, channel }) {
return `https://example.com/${date.format('YYYY-MM-DD')}/channel/${channel.site_id}.html`
},
/**
* @param {string} content The response received after the request at the above url
*
* @return {array} The function should return an array of programs with their descriptions
*/
parser: function ({ content }) {
// content parsing...
return [
{
title, // program title (required)
start, // program start time (required)
stop, // program end time (optional)
description, // program description (optional)
category // program category (optional)
},
...
]
}
}
```
**example.com.channels.xml**
```xml
<?xml version="1.0"?>
< site site = "example.com" >
< channels >
< channel site_id = "cnn-23" xmltv_id = "CNN.us" > CNN< / channel >
...
< / channels >
< / site >
```
2021-03-13 13:48:58 +01:00
## Contribution
If you find a bug or want to contribute to the code or documentation, you can help by submitting an [issue ](https://github.com/freearhey/epg-grabber/issues ) or a [pull request ](https://github.com/freearhey/epg-grabber/pulls ).
## License
[MIT ](http://opensource.org/licenses/MIT )