Skip to content

Commit

Permalink
Merge pull request #2 from AudienseCo/remove-request
Browse files Browse the repository at this point in the history
remove request package
  • Loading branch information
Javibu5 authored May 27, 2024
2 parents d5d7484 + 6881703 commit 8b4cc32
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 43 deletions.
82 changes: 41 additions & 41 deletions index.js
Original file line number Diff line number Diff line change
@@ -1,58 +1,58 @@
var FeedParser = require('feedparser');
var request = require('request');
var axios = require('axios');



module.exports = function fetch(url, callback) {
var req = request(url);
var feedparser = new FeedParser();
var items = [];
var errorRaised = false;

req.setHeader('user-agent', 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_8_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36');
req.setHeader('accept', 'text/html,application/xhtml+xml');

req.on('error', _raiseError);
req.on('response', function(res) {
if (res.statusCode != 200) return this.emit('error', new Error('Bad status code'));
var encoding = res.headers['content-encoding'] || 'identity';
var charset = getParams(res.headers['content-type'] || '').charset;
res = maybeDecompress(res, encoding);
res.pipe(feedparser);
});


const feedparser = new FeedParser();
axios.get(url, {
responseType: 'stream',
headers: {
'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_8_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36',
'Accept': 'text/html,application/xhtml+xml'
}
}).then(response => {
if (response.status !== 200) {
throw new Error('Bad status code');
}

feedparser.on('error', _raiseError);
feedparser.on('end', function() { if(!errorRaised) callback(null, items); });
feedparser.on('readable', function() {
var post;
while (post = this.read()) {
items.push(post);
const items = [];
let errorRaised = false;
var encoding = response.headers['Content-Encoding'] || 'identity';
const responseData = response.data
const responseDecompress = maybeDecompress(responseData, encoding)
const responseParsed = responseDecompress.pipe(feedparser)

responseParsed.on('error', _raiseError);

responseParsed.on('end', function() {
if (!errorRaised) callback(null, items);
});
responseParsed.on('data', function(chunck) {
items.push(chunck);
});

function _raiseError(error) {
if (!errorRaised) {
errorRaised = true;
callback(error);
}
}
}).catch(error => {
callback(error);
});

function _raiseError(error) {
if (!errorRaised) callback(error);
errorRaised = true;
}
};


function maybeDecompress (res, encoding) {

var decompress;
if (encoding.match(/\bdeflate\b/)) {
decompress = zlib.createInflate();
} else if (encoding.match(/\bgzip\b/)) {
decompress = zlib.createGunzip();
}
return decompress ? res.pipe(decompress) : res;
}

function getParams(str) {
var params = str.split(';').reduce(function (params, param) {
var parts = param.split('=').map(function (part) { return part.trim(); });
if (parts.length === 2) {
params[parts[0]] = parts[1];
}
return params;
}, {});
return params;
}

}
4 changes: 2 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@
},
"homepage": "https://github.com/AudienseCo/node-parse-rss#readme",
"dependencies": {
"feedparser": "^1.1.4",
"request": "^2.74.0"
"axios": "^1.7.2",
"feedparser": "^1.1.4"
}
}

0 comments on commit 8b4cc32

Please sign in to comment.