mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-17 03:53:29 +01:00
comply to the latest rate limit stuff (hammerandchisel/discord-api-docs#108)
This commit is contained in:
File diff suppressed because one or more lines are too long
@@ -1,6 +1,16 @@
|
|||||||
const request = require('superagent');
|
const request = require('superagent');
|
||||||
const Constants = require('../../util/Constants');
|
const Constants = require('../../util/Constants');
|
||||||
|
|
||||||
|
function getRoute(url) {
|
||||||
|
let route = url.split('?')[0];
|
||||||
|
if (route.includes('/channels/') || route.includes('/guilds/')) {
|
||||||
|
const startInd = ~route.indexOf('/channels/') ? route.indexOf('/channels/') : route.indexOf('/guilds/');
|
||||||
|
const majorID = route.substring(startInd).split('/')[2];
|
||||||
|
route = route.replace(/(\d{8,})/g, ':id').replace(':id', majorID);
|
||||||
|
}
|
||||||
|
return route;
|
||||||
|
}
|
||||||
|
|
||||||
class APIRequest {
|
class APIRequest {
|
||||||
constructor(rest, method, url, auth, data, file) {
|
constructor(rest, method, url, auth, data, file) {
|
||||||
this.rest = rest;
|
this.rest = rest;
|
||||||
@@ -9,10 +19,7 @@ class APIRequest {
|
|||||||
this.auth = auth;
|
this.auth = auth;
|
||||||
this.data = data;
|
this.data = data;
|
||||||
this.file = file;
|
this.file = file;
|
||||||
}
|
this.route = getRoute(this.url);
|
||||||
|
|
||||||
getEndpoint() {
|
|
||||||
return this.url;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
getAuth() {
|
getAuth() {
|
||||||
|
|||||||
@@ -39,12 +39,12 @@ class RESTManager {
|
|||||||
makeRequest(method, url, auth, data, file) {
|
makeRequest(method, url, auth, data, file) {
|
||||||
const apiRequest = new APIRequest(this, method, url, auth, data, file);
|
const apiRequest = new APIRequest(this, method, url, auth, data, file);
|
||||||
|
|
||||||
if (!this.handlers[apiRequest.getEndpoint()]) {
|
if (!this.handlers[apiRequest.route]) {
|
||||||
const RequestHandlerType = this.getRequestHandler();
|
const RequestHandlerType = this.getRequestHandler();
|
||||||
this.handlers[apiRequest.getEndpoint()] = new RequestHandlerType(this, apiRequest.getEndpoint());
|
this.handlers[apiRequest.route] = new RequestHandlerType(this, apiRequest.route);
|
||||||
}
|
}
|
||||||
|
|
||||||
return this.push(this.handlers[apiRequest.getEndpoint()], apiRequest);
|
return this.push(this.handlers[apiRequest.route], apiRequest);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user