-
-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathDiscordBotsGG.js
145 lines (145 loc) · 5.31 KB
/
DiscordBotsGG.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
"use strict";
var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
return extendStatics(d, b);
};
return function (d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
var Service_1 = require("../Service");
var Util_1 = require("../../Utils/Util");
var Constants_1 = require("../../Utils/Constants");
/**
* Represents the Discord Bots service.
* @see https://discord.bots.gg/docs
*/
var DiscordBotsGG = /** @class */ (function (_super) {
__extends(DiscordBotsGG, _super);
//
/**
* @param token The token/key for the service
* @param userAgent The user agent options of the service. Providing this is highly recommended.
*/
function DiscordBotsGG(token, userAgent) {
var _this = _super.call(this, token) || this;
_this.agent = {
library: (userAgent === null || userAgent === void 0 ? void 0 : userAgent.library) || 'unknown',
clientID: (userAgent === null || userAgent === void 0 ? void 0 : userAgent.clientID) || '000000000000000'
};
return _this;
}
Object.defineProperty(DiscordBotsGG, "aliases", {
/** The values that can be used to select the service. */
get: function () {
return ['discordbotsgg', 'discord.bots.gg'];
},
enumerable: false,
configurable: true
});
Object.defineProperty(DiscordBotsGG, "logoURL", {
/** The logo URL. */
get: function () {
return 'https://pbs.twimg.com/profile_images/1071582837030060032/kKV-I01n_400x400.jpg';
},
enumerable: false,
configurable: true
});
Object.defineProperty(DiscordBotsGG, "serviceName", {
/** Service's name. */
get: function () {
return 'Discord Bots';
},
enumerable: false,
configurable: true
});
Object.defineProperty(DiscordBotsGG, "websiteURL", {
/** The website URL. */
get: function () {
return 'https://discord.bots.gg';
},
enumerable: false,
configurable: true
});
Object.defineProperty(DiscordBotsGG, "baseURL", {
/** The base URL of the service's API. */
get: function () {
return 'https://discord.bots.gg/api/v1';
},
enumerable: false,
configurable: true
});
/**
* Creates a compliant user agent to use for any API calls to Discord Bots.
* @param botID The ID of the bot that the agent will be identified with
* @param library The library the agent is using
*/
DiscordBotsGG.userAgent = function (botID, library) {
if (library === void 0) { library = 'unknown'; }
return "dbots-0000/" + Constants_1.Package.version + " (" + library + "; +https://github.com/dbots-pkg/dbots.js) DBots/" + Util_1.Util.resolveID(botID);
};
/**
* Posts statistics to this service.
* @param options The options of the request
*/
DiscordBotsGG.post = function (options) {
var token = options.token, clientID = options.clientID, serverCount = options.serverCount, shard = options.shard;
return _super._post.call(this, {
method: 'post',
url: "/bots/" + Util_1.Util.resolveID(clientID) + "/stats",
headers: {
Authorization: token,
'User-Agent': DiscordBotsGG.userAgent(clientID)
},
data: shard
? {
guildCount: Util_1.Util.resolveCount(serverCount),
shardId: shard.id,
shardCount: shard.count
}
: { guildCount: Util_1.Util.resolveCount(serverCount) }
});
};
/**
* Gets the bot listed on this service.
* @param id The bot's ID
* @param sanitized Whether to sanitize descriptions
*/
DiscordBotsGG.prototype.getBot = function (id, sanitized) {
if (sanitized === void 0) { sanitized = false; }
return this._request({
url: "/bots/" + Util_1.Util.resolveID(id),
headers: {
Authorization: this.token,
'User-Agent': DiscordBotsGG.userAgent(this.agent.clientID, this.agent.library)
},
params: { sanitized: sanitized }
}, {
requiresToken: true
});
};
/**
* Gets a list of bots on this service.
* @param query The query string that will be used in the request
*/
DiscordBotsGG.prototype.getBots = function (query) {
return this._request({
url: '/bots',
headers: {
Authorization: this.token,
'User-Agent': DiscordBotsGG.userAgent(this.agent.clientID, this.agent.library)
},
params: query
}, {
requiresToken: true
});
};
return DiscordBotsGG;
}(Service_1.Service));
exports.default = DiscordBotsGG;