2015-04-26 02:46:25 +08:00
|
|
|
var SteamCommunity = require('../index.js');
|
2016-03-08 14:23:31 +08:00
|
|
|
var Helpers = require('../components/helpers.js');
|
2015-04-26 02:46:25 +08:00
|
|
|
var SteamID = require('steamid');
|
|
|
|
var xml2js = require('xml2js');
|
|
|
|
|
|
|
|
SteamCommunity.prototype.getSteamUser = function(id, callback) {
|
2016-03-08 14:23:31 +08:00
|
|
|
if(typeof id !== 'string' && !Helpers.isSteamID(id)) {
|
2015-04-26 02:46:25 +08:00
|
|
|
throw new Error("id parameter should be a user URL string or a SteamID object");
|
|
|
|
}
|
|
|
|
|
|
|
|
if(typeof id === 'object' && (id.universe != SteamID.Universe.PUBLIC || id.type != SteamID.Type.INDIVIDUAL)) {
|
|
|
|
throw new Error("SteamID must stand for an individual account in the public universe");
|
|
|
|
}
|
|
|
|
|
|
|
|
var self = this;
|
2016-03-05 07:26:47 +08:00
|
|
|
this.httpRequest("http://steamcommunity.com/" + (typeof id === 'string' ? "id/" + id : "profiles/" + id.toString()) + "/?xml=1", function(err, response, body) {
|
2016-03-05 12:59:49 +08:00
|
|
|
if (err) {
|
|
|
|
callback(err);
|
2015-04-26 02:46:25 +08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
xml2js.parseString(body, function(err, result) {
|
|
|
|
if(err || (!result.response && !result.profile)) {
|
2015-07-18 10:23:20 +08:00
|
|
|
callback(err || new Error("No valid response"));
|
2015-04-26 02:46:25 +08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(result.response && result.response.error && result.response.error.length) {
|
2015-07-18 10:23:20 +08:00
|
|
|
callback(new Error(result.response.error[0]));
|
2015-04-26 02:46:25 +08:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Try and find custom URL from redirect
|
|
|
|
var customurl = null;
|
|
|
|
if(response.request.redirects && response.request.redirects.length) {
|
|
|
|
var match = response.request.redirects[0].redirectUri.match(/https?:\/\/steamcommunity\.com\/id\/([^/])+\/\?xml=1/);
|
|
|
|
if(match) {
|
|
|
|
customurl = match[1];
|
|
|
|
}
|
|
|
|
}
|
2015-09-20 11:35:01 +08:00
|
|
|
|
2015-09-20 12:49:42 +08:00
|
|
|
if(!result.profile.steamID64) {
|
2015-09-20 11:35:01 +08:00
|
|
|
callback(new Error("No valid response"));
|
2015-09-20 12:33:24 +08:00
|
|
|
return;
|
2015-09-20 11:35:01 +08:00
|
|
|
}
|
2015-04-26 02:46:25 +08:00
|
|
|
|
|
|
|
callback(null, new CSteamUser(self, result.profile, customurl));
|
|
|
|
});
|
2016-03-05 08:35:04 +08:00
|
|
|
}, "steamcommunity");
|
2015-04-26 02:46:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
function CSteamUser(community, userData, customurl) {
|
|
|
|
this._community = community;
|
|
|
|
|
|
|
|
this.steamID = new SteamID(userData.steamID64[0]);
|
2015-10-05 07:46:38 +08:00
|
|
|
this.name = processItem('steamID');
|
|
|
|
this.onlineState = processItem('onlineState');
|
|
|
|
this.stateMessage = processItem('stateMessage');
|
|
|
|
this.privacyState = processItem('privacyState', 'uncreated');
|
|
|
|
this.visibilityState = processItem('visibilityState');
|
|
|
|
this.avatarHash = processItem('avatarIcon', '').match(/([0-9a-f]+)\.[a-z]+$/);
|
2015-09-20 12:49:42 +08:00
|
|
|
if(this.avatarHash) {
|
|
|
|
this.avatarHash = this.avatarHash[1];
|
|
|
|
}
|
|
|
|
|
2015-11-27 14:32:12 +08:00
|
|
|
this.vacBanned = processItem('vacBanned', false) == 1;
|
2015-10-05 07:46:38 +08:00
|
|
|
this.tradeBanState = processItem('tradeBanState', 'None');
|
2015-11-27 14:32:12 +08:00
|
|
|
this.isLimitedAccount = processItem('isLimitedAccount') == 1;
|
2015-10-05 07:46:38 +08:00
|
|
|
this.customURL = processItem('customURL', customurl);
|
2015-04-26 02:46:25 +08:00
|
|
|
|
|
|
|
if(this.visibilityState == 3) {
|
2015-10-05 07:46:38 +08:00
|
|
|
this.memberSince = new Date(processItem('memberSince', '0').replace(/(\d{1,2})(st|nd|th)/, "$1"));
|
|
|
|
this.location = processItem('location');
|
|
|
|
this.realName = processItem('realname');
|
|
|
|
this.summary = processItem('summary');
|
2015-04-26 02:46:25 +08:00
|
|
|
} else {
|
|
|
|
this.memberSince = null;
|
|
|
|
this.location = null;
|
|
|
|
this.realName = null;
|
|
|
|
this.summary = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Maybe handle mostPlayedGames?
|
|
|
|
|
|
|
|
this.groups = null;
|
|
|
|
this.primaryGroup = null;
|
|
|
|
|
|
|
|
var self = this;
|
|
|
|
if(userData.groups && userData.groups[0] && userData.groups[0].group) {
|
|
|
|
this.groups = userData.groups[0].group.map(function(group) {
|
2016-01-25 18:35:22 +08:00
|
|
|
if(group['$'] && group['$'].isPrimary === "1") {
|
2015-04-26 02:46:25 +08:00
|
|
|
self.primaryGroup = new SteamID(group.groupID64[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
return new SteamID(group.groupID64[0]);
|
|
|
|
});
|
|
|
|
}
|
2015-09-20 12:49:42 +08:00
|
|
|
|
2015-10-05 07:46:38 +08:00
|
|
|
function processItem(name, defaultVal) {
|
2015-09-20 12:49:42 +08:00
|
|
|
if(!userData[name]) {
|
|
|
|
return defaultVal;
|
|
|
|
}
|
|
|
|
|
|
|
|
return userData[name][0];
|
|
|
|
}
|
2015-04-26 02:46:25 +08:00
|
|
|
}
|
|
|
|
|
2015-06-18 12:41:26 +08:00
|
|
|
CSteamUser.getAvatarURL = function(hash, size, protocol) {
|
2015-04-26 02:46:25 +08:00
|
|
|
size = size || '';
|
|
|
|
protocol = protocol || 'http://';
|
2017-01-04 13:10:11 +08:00
|
|
|
|
|
|
|
hash = hash || "72f78b4c8cc1f62323f8a33f6d53e27db57c2252"; // The default "?" avatar
|
2015-04-26 02:46:25 +08:00
|
|
|
|
2015-06-18 12:41:26 +08:00
|
|
|
var url = protocol + "steamcdn-a.akamaihd.net/steamcommunity/public/images/avatars/" + hash.substring(0, 2) + "/" + hash;
|
2015-04-26 02:46:25 +08:00
|
|
|
if(size == 'full' || size == 'medium') {
|
|
|
|
return url + "_" + size + ".jpg";
|
|
|
|
} else {
|
|
|
|
return url + ".jpg";
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2015-06-18 12:41:26 +08:00
|
|
|
CSteamUser.prototype.getAvatarURL = function(size, protocol) {
|
|
|
|
return CSteamUser.getAvatarURL(this.avatarHash, size, protocol);
|
|
|
|
};
|
|
|
|
|
2015-04-26 02:46:25 +08:00
|
|
|
CSteamUser.prototype.addFriend = function(callback) {
|
2015-08-14 11:57:08 +08:00
|
|
|
this._community.addFriend(this.steamID, callback);
|
2015-04-26 02:46:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
CSteamUser.prototype.acceptFriendRequest = function(callback) {
|
2015-08-14 11:57:08 +08:00
|
|
|
this._community.acceptFriendRequest(this.steamID, callback);
|
2015-04-26 02:46:25 +08:00
|
|
|
};
|
|
|
|
|
2015-04-26 13:16:27 +08:00
|
|
|
CSteamUser.prototype.removeFriend = function(callback) {
|
2015-08-14 11:57:08 +08:00
|
|
|
this._community.removeFriend(this.steamID, callback);
|
|
|
|
|
2015-04-26 13:16:27 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
CSteamUser.prototype.blockCommunication = function(callback) {
|
2015-08-14 11:57:08 +08:00
|
|
|
this._community.blockCommunication(this.steamID, callback);
|
2015-04-26 13:16:27 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
CSteamUser.prototype.unblockCommunication = function(callback) {
|
2015-08-14 11:57:08 +08:00
|
|
|
this._community.unblockCommunication(this.steamID, callback);
|
2015-04-26 13:16:27 +08:00
|
|
|
};
|
|
|
|
|
2015-04-26 02:46:25 +08:00
|
|
|
CSteamUser.prototype.comment = function(message, callback) {
|
2015-08-14 11:57:08 +08:00
|
|
|
this._community.postUserComment(this.steamID, message, callback);
|
2015-04-26 02:46:25 +08:00
|
|
|
};
|
2015-08-14 12:04:43 +08:00
|
|
|
|
|
|
|
CSteamUser.prototype.inviteToGroup = function(groupID, callback) {
|
|
|
|
this._community.inviteUserToGroup(this.steamID, groupID, callback);
|
|
|
|
};
|
2015-09-07 12:01:35 +08:00
|
|
|
|
2016-07-07 07:20:42 +08:00
|
|
|
CSteamUser.prototype.getAliases = function(callback) {
|
|
|
|
this._community.getUserAliases(this.steamID, callback);
|
|
|
|
};
|
|
|
|
|
2015-09-07 12:01:35 +08:00
|
|
|
CSteamUser.prototype.getInventoryContexts = function(callback) {
|
|
|
|
this._community.getUserInventoryContexts(this.steamID, callback);
|
|
|
|
};
|
|
|
|
|
2016-12-13 14:29:23 +08:00
|
|
|
/**
|
|
|
|
* Get the contents of a user's inventory context.
|
|
|
|
* @deprecated Use CSteamUser#getInventoryContents instead
|
|
|
|
* @param {int} appID - The Steam application ID of the game for which you want an inventory
|
|
|
|
* @param {int} contextID - The ID of the "context" within the game you want to retrieve
|
|
|
|
* @param {boolean} tradableOnly - true to get only tradable items and currencies
|
|
|
|
* @param callback
|
|
|
|
*/
|
2015-09-07 12:01:35 +08:00
|
|
|
CSteamUser.prototype.getInventory = function(appID, contextID, tradableOnly, callback) {
|
2015-10-05 05:28:40 +08:00
|
|
|
this._community.getUserInventory(this.steamID, appID, contextID, tradableOnly, callback);
|
2015-09-07 12:01:35 +08:00
|
|
|
};
|
2016-12-13 14:29:23 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the contents of a user's inventory context.
|
|
|
|
* @param {int} appID - The Steam application ID of the game for which you want an inventory
|
|
|
|
* @param {int} contextID - The ID of the "context" within the game you want to retrieve
|
|
|
|
* @param {boolean} tradableOnly - true to get only tradable items and currencies
|
|
|
|
* @param callback
|
|
|
|
*/
|
|
|
|
CSteamUser.prototype.getInventoryContents = function(appID, contextID, tradableOnly, callback) {
|
|
|
|
this._community.getUserInventoryContents(this.steamID, appID, contextID, tradableOnly, callback);
|
|
|
|
};
|