Catching HTTP errors properly

Specifying the Group in getAllGroupAnnouncements
Removing unnecessary comments
Made the callback for getAllGroupAnnouncements mandatory
This commit is contained in:
Shaun Barratt 2016-01-16 18:39:04 +00:00
parent ac02f6cb49
commit 4223d88fd1
2 changed files with 9 additions and 17 deletions

View File

@ -77,7 +77,7 @@ CSteamGroup.prototype.leave = function(callback) {
}; };
CSteamGroup.prototype.getAllAnnouncements = function(time, callback) { CSteamGroup.prototype.getAllAnnouncements = function(time, callback) {
this._community.getAllAnnouncements(this.steamID, time, callback); this._community.getAllGroupAnnouncements(this.steamID, time, callback);
}; };
CSteamGroup.prototype.postAnnouncement = function(headline, content, callback) { CSteamGroup.prototype.postAnnouncement = function(headline, content, callback) {

View File

@ -125,7 +125,7 @@ SteamCommunity.prototype.leaveGroup = function(gid, callback) {
}); });
}; };
SteamCommunity.prototype.getAllAnnouncements = function(gid, time, callback) { SteamCommunity.prototype.getAllGroupAnnouncements = function(gid, time, callback) {
if(typeof gid === 'string') { if(typeof gid === 'string') {
gid = new SteamID(gid); gid = new SteamID(gid);
} }
@ -136,15 +136,11 @@ SteamCommunity.prototype.getAllAnnouncements = function(gid, time, callback) {
} }
var self = this; var self = this;
this.request({ this.request({
"uri": "https://steamcommunity.com/gid/" + gid.getSteamID64() + "/rss/" "uri": "https://steamcommunity.com/gid/" + gid.getSteamID64() + "/rss/"
}, function(err, response, body) { }, function(err, response, body) {
if(!callback) {
return;
}
if(err || response.statusCode >= 400) { if(self._checkHttpError(err, response, callback)) {
callback(err || new Error("HTTP error " + response.statusCode));
return; return;
} }
@ -167,12 +163,10 @@ SteamCommunity.prototype.getAllAnnouncements = function(gid, time, callback) {
headline: announcement.title[0], headline: announcement.title[0],
content: announcement.description[0], content: announcement.description[0],
date: new Date(announcement.pubDate[0]), date: new Date(announcement.pubDate[0]),
author: announcement.author[0], // Unfortunately, the RSS feed likes to give us personanames not steamid's author: announcement.author[0],
aid: splitLink[splitLink.length - 1] // The ID after the last / aid: splitLink[splitLink.length - 1]
// Note this is marked as guid (gid?) in the rss feed but can also be obtained from link
// and is actually a unique ID (or it seems that way)
} }
}).filter(function(announcement) { // Only show the ones they wanted }).filter(function(announcement) {
return (announcement.date > time); return (announcement.date > time);
}); });
@ -202,8 +196,7 @@ SteamCommunity.prototype.postGroupAnnouncement = function(gid, headline, content
return; return;
} }
if(err || response.statusCode >= 400) { if(self._checkHttpError(err, response, callback)) {
callback(err || new Error("HTTP error " + response.statusCode));
return; return;
} }
@ -241,8 +234,7 @@ SteamCommunity.prototype.editGroupAnnouncement = function(gid, aid, headline, co
return; return;
} }
if(err || response.statusCode >= 400) { if(self._checkHttpError(err, response, callback)) {
callback(err || new Error("HTTP error " + response.statusCode));
return; return;
} }