2014-12-17 14:48:17 +08:00
|
|
|
var SteamCommunity = require('../index.js');
|
2016-03-08 14:23:31 +08:00
|
|
|
var Helpers = require('../components/helpers.js');
|
2014-12-17 14:48:17 +08:00
|
|
|
var SteamID = require('steamid');
|
|
|
|
var xml2js = require('xml2js');
|
|
|
|
|
|
|
|
SteamCommunity.prototype.getSteamGroup = function(id, callback) {
|
2016-03-08 14:23:31 +08:00
|
|
|
if(typeof id !== 'string' && !Helpers.isSteamID(id)) {
|
2014-12-17 14:48:17 +08:00
|
|
|
throw new Error("id parameter should be a group URL string or a SteamID object");
|
|
|
|
}
|
2016-06-15 10:29:11 +08:00
|
|
|
|
2014-12-17 14:48:17 +08:00
|
|
|
if(typeof id === 'object' && (id.universe != SteamID.Universe.PUBLIC || id.type != SteamID.Type.CLAN)) {
|
|
|
|
throw new Error("SteamID must stand for a clan account in the public universe");
|
|
|
|
}
|
2016-06-15 10:29:11 +08:00
|
|
|
|
2014-12-17 14:48:17 +08:00
|
|
|
var self = this;
|
2016-03-05 07:26:47 +08:00
|
|
|
this.httpRequest("https://steamcommunity.com/" + (typeof id === 'string' ? "groups/" + id : "gid/" + id.toString()) + "/memberslistxml/?xml=1", function(err, response, body) {
|
2016-03-05 12:59:49 +08:00
|
|
|
if (err) {
|
|
|
|
callback(err);
|
2014-12-17 14:48:17 +08:00
|
|
|
return;
|
|
|
|
}
|
2016-06-15 10:29:11 +08:00
|
|
|
|
2014-12-17 14:48:17 +08:00
|
|
|
xml2js.parseString(body, function(err, result) {
|
|
|
|
if(err) {
|
|
|
|
callback(err);
|
|
|
|
return;
|
|
|
|
}
|
2016-06-15 10:29:11 +08:00
|
|
|
|
2014-12-17 14:48:17 +08:00
|
|
|
callback(null, new CSteamGroup(self, result.memberList));
|
|
|
|
});
|
2016-03-05 08:35:04 +08:00
|
|
|
}, "steamcommunity");
|
2014-12-17 14:48:17 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
function CSteamGroup(community, groupData) {
|
|
|
|
this._community = community;
|
2016-06-15 10:29:11 +08:00
|
|
|
|
2014-12-17 14:48:17 +08:00
|
|
|
this.steamID = new SteamID(groupData.groupID64[0]);
|
|
|
|
this.name = groupData.groupDetails[0].groupName[0];
|
|
|
|
this.url = groupData.groupDetails[0].groupURL[0];
|
|
|
|
this.headline = groupData.groupDetails[0].headline[0];
|
|
|
|
this.summary = groupData.groupDetails[0].summary[0];
|
|
|
|
this.avatarHash = groupData.groupDetails[0].avatarIcon[0].match(/([0-9a-f]+)\.jpg$/)[1];
|
|
|
|
this.members = parseInt(groupData.groupDetails[0].memberCount[0], 10);
|
|
|
|
this.membersInChat = parseInt(groupData.groupDetails[0].membersInChat[0], 10);
|
|
|
|
this.membersInGame = parseInt(groupData.groupDetails[0].membersInGame[0], 10);
|
|
|
|
this.membersOnline = parseInt(groupData.groupDetails[0].membersOnline[0], 10);
|
|
|
|
}
|
|
|
|
|
|
|
|
CSteamGroup.prototype.getAvatarURL = function(size, protocol) {
|
|
|
|
size = size || '';
|
|
|
|
protocol = protocol || 'http://';
|
2016-06-15 10:29:11 +08:00
|
|
|
|
2014-12-17 14:48:17 +08:00
|
|
|
var url = protocol + "steamcdn-a.akamaihd.net/steamcommunity/public/images/avatars/" + this.avatarHash.substring(0, 2) + "/" + this.avatarHash;
|
|
|
|
if(size == 'full' || size == 'medium') {
|
|
|
|
return url + "_" + size + ".jpg";
|
|
|
|
} else {
|
|
|
|
return url + ".jpg";
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2015-08-05 11:40:10 +08:00
|
|
|
CSteamGroup.prototype.getMembers = function(addresses, callback) {
|
|
|
|
if(typeof addresses === 'function') {
|
|
|
|
callback = addresses;
|
|
|
|
addresses = null;
|
|
|
|
}
|
2016-06-15 10:29:11 +08:00
|
|
|
|
2015-08-05 11:40:10 +08:00
|
|
|
this._community.getGroupMembers(this.steamID, callback, null, null, addresses, 0);
|
2014-12-17 14:48:17 +08:00
|
|
|
};
|
2014-12-17 14:59:21 +08:00
|
|
|
|
2014-12-17 15:49:51 +08:00
|
|
|
CSteamGroup.prototype.join = function(callback) {
|
2015-08-05 11:37:16 +08:00
|
|
|
this._community.joinGroup(this.steamID, callback);
|
2014-12-17 15:49:51 +08:00
|
|
|
};
|
|
|
|
|
2014-12-17 16:07:59 +08:00
|
|
|
CSteamGroup.prototype.leave = function(callback) {
|
2015-08-05 11:37:16 +08:00
|
|
|
this._community.leaveGroup(this.steamID, callback);
|
2014-12-17 16:07:59 +08:00
|
|
|
};
|
|
|
|
|
2016-01-16 08:06:42 +08:00
|
|
|
CSteamGroup.prototype.getAllAnnouncements = function(time, callback) {
|
2016-01-17 02:39:04 +08:00
|
|
|
this._community.getAllGroupAnnouncements(this.steamID, time, callback);
|
2016-01-16 08:06:42 +08:00
|
|
|
};
|
|
|
|
|
2014-12-17 14:59:21 +08:00
|
|
|
CSteamGroup.prototype.postAnnouncement = function(headline, content, callback) {
|
2015-08-05 11:37:16 +08:00
|
|
|
this._community.postGroupAnnouncement(this.steamID, headline, content, callback);
|
2014-12-17 14:59:21 +08:00
|
|
|
};
|
2014-12-17 15:29:58 +08:00
|
|
|
|
2016-01-16 01:48:57 +08:00
|
|
|
CSteamGroup.prototype.editAnnouncement = function(annoucementID, headline, content, callback) {
|
|
|
|
this._community.editGroupAnnouncement(this.steamID, annoucementID, headline, content, callback)
|
|
|
|
};
|
|
|
|
|
2016-01-18 08:19:04 +08:00
|
|
|
CSteamGroup.prototype.deleteAnnouncement = function(annoucementID, callback) {
|
|
|
|
this._community.deleteGroupAnnouncement(this.steamID, annoucementID, callback)
|
2016-01-17 10:27:11 +08:00
|
|
|
};
|
|
|
|
|
2014-12-17 15:29:58 +08:00
|
|
|
CSteamGroup.prototype.scheduleEvent = function(name, type, description, time, server, callback) {
|
2015-08-05 11:37:16 +08:00
|
|
|
this._community.scheduleGroupEvent(this.steamID, name, type, description, time, server, callback);
|
2014-12-17 15:29:58 +08:00
|
|
|
};
|
2014-12-17 15:39:53 +08:00
|
|
|
|
2016-06-15 10:29:11 +08:00
|
|
|
CSteamGroup.prototype.editEvent = function(id, name, type, description, time, server, callback) {
|
|
|
|
this._community.editGroupEvent(this.steamID, id, name, type, description, time, server, callback);
|
|
|
|
};
|
|
|
|
|
2016-06-22 10:39:23 +08:00
|
|
|
CSteamGroup.prototype.deleteEvent = function (id, callback) {
|
|
|
|
this._community.deleteGroupEvent(this.steamID, id, callback);
|
|
|
|
};
|
|
|
|
|
2014-12-17 15:39:53 +08:00
|
|
|
CSteamGroup.prototype.setPlayerOfTheWeek = function(steamID, callback) {
|
2015-08-05 11:37:16 +08:00
|
|
|
this._community.setGroupPlayerOfTheWeek(this.steamID, steamID, callback);
|
2014-12-17 15:39:53 +08:00
|
|
|
};
|
2014-12-17 15:42:15 +08:00
|
|
|
|
|
|
|
CSteamGroup.prototype.kick = function(steamID, callback) {
|
2015-08-05 11:37:16 +08:00
|
|
|
this._community.kickGroupMember(this.steamID, steamID, callback);
|
2014-12-17 15:42:15 +08:00
|
|
|
};
|
2015-08-05 12:13:32 +08:00
|
|
|
|
|
|
|
CSteamGroup.prototype.getHistory = function(page, callback) {
|
|
|
|
this._community.getGroupHistory(this.steamID, page, callback);
|
|
|
|
};
|
2017-08-07 07:11:21 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get requests to join this restricted group.
|
|
|
|
* @param {function} callback - First argument is null/Error, second is array of SteamID objects
|
|
|
|
*/
|
|
|
|
CSteamGroup.prototype.getJoinRequests = function(callback) {
|
|
|
|
this._community.getGroupJoinRequests(this.steamID, callback);
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Respond to one or more join requests to this restricted group.
|
|
|
|
* @param {SteamID|string|SteamID[]|string[]} steamIDs - The SteamIDs of the users you want to approve or deny membership for (or a single value)
|
|
|
|
* @param {boolean} approve - True to put them in the group, false to deny their membership
|
|
|
|
* @param {function} callback - Takes only an Error object/null as the first argument
|
|
|
|
*/
|
|
|
|
CSteamGroup.prototype.respondToJoinRequests = function(steamIDs, approve, callback) {
|
|
|
|
this._community.respondToGroupJoinRequests(this.steamID, steamIDs, approve, callback);
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Respond to *ALL* pending group-join requests for this group.
|
|
|
|
* @param {boolean} approve - True to allow everyone who requested into the group, false to not
|
|
|
|
* @param {function} callback - Takes only an Error object/null as the first argument
|
|
|
|
*/
|
|
|
|
CSteamGroup.prototype.respondToAllJoinRequests = function(approve, callback) {
|
|
|
|
this._community.respondToAllGroupJoinRequests(this.steamID, approve, callback);
|
|
|
|
};
|