# EPG Grabber [![Build Status](https://travis-ci.com/freearhey/epg-grabber.svg?branch=master)](https://travis-ci.com/freearhey/epg-grabber) Node.js CLI tool for grabbing EPG from different websites. ## 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 #### example.com.config.js ```js module.exports = { lang: 'fr', // default language for all programs (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) days: 3, // number of days for which to grab the program (default: 1) request: { // request options (details: https://github.com/axios/axios#request-config) method: 'GET', timeout: 5000, /** * @param {object} date The 'dayjs' instance with the requested date * @param {object} channel Data about the requested channel * * @return {string} The function should return headers for each request (optional) */ headers: function({ date, channel }) { return { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/79.0.3945.130 Safari/537.36 Edg/79.0.309.71' } }, /** * @param {object} date The 'dayjs' instance with the requested date * @param {object} channel Data about the requested channel * * @return {string} The function should return data for each request (optional) */ data: function({ date, channel }) { return { channels: [channel.site_id], dateStart: date.format('YYYY-MM-DDT00:00:00-00:00'), dateEnd: date.add(1, 'd').format('YYYY-MM-DDT00:00:00-00:00') } } }, /** * @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 {object} channel Data about the requested channel * @param {string} content The response received after the request at the above url * * @return {string} The function should return URL of the channel logo (optional) */ logo: function ({ channel, content }) { return `https://example.com/logos/${channel.site_id}.png` }, /** * @param {object} date The 'dayjs' instance with the requested date * @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 ({ date, 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) icon, // program icon (optional) lang // program language (default: 'en') }, ... ] } } ``` Also each function can be asynchronous. ```js module.exports = { site: 'example.com', output: 'example.com.guide.xml', channels: 'example.com.channels.xml', request: { async headers() { return { ... } }, async data() { return { ... } } }, async url() { return '...' }, async logo() { return '...' }, async parser() { return [ ... ] } } ``` #### example.com.channels.xml ```xml CNN ... ``` You can also specify the language and logo for each channel individually, like so: ```xml France 24 ``` ## 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)