mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-09 16:13:31 +01:00
34
README.md
34
README.md
@@ -55,6 +55,40 @@ Here is a list of other Discord APIs:
|
||||
|
||||
---
|
||||
|
||||
### Changes in 3.1.4
|
||||
|
||||
No, not π. But instead, pseduo-synchronous messaging was added! This means that
|
||||
you can tell your Client to make a queue of "actions" per channel, and it will
|
||||
work through them one by one. This is a really useful tool if you need to send
|
||||
messages in a specific order without callback hell.
|
||||
|
||||
It also allows you to store responses - such as created messages - in the returned
|
||||
promise - named action. Example:
|
||||
|
||||
```js
|
||||
var mybot = new Discord.Client({
|
||||
queue : true //enable queueing, disabled by default
|
||||
});
|
||||
|
||||
mybot.on("message", function(msg){
|
||||
|
||||
mybot.sendMessage(msg.channel, "this is message 1");
|
||||
var action = mybot.sendMessage(msg.channel, "this is message 2");
|
||||
mybot.sendMessage(msg.channel, "this is message 3").then(rmv);
|
||||
|
||||
function rmv(){
|
||||
if(!action.error){
|
||||
mybot.deleteMessage(action.message);
|
||||
}
|
||||
}
|
||||
|
||||
});
|
||||
```
|
||||
|
||||
This is still in development, and will see many more enhancements in future.
|
||||
|
||||
---
|
||||
|
||||
### Links
|
||||
**[Documentation](https://github.com/discord-js/discord.js/wiki/Documentation)**
|
||||
|
||||
|
||||
41
examples/avatar.js
Normal file
41
examples/avatar.js
Normal file
@@ -0,0 +1,41 @@
|
||||
/*
|
||||
this bot is an avatar bot, and will give a user their avatar's URL
|
||||
*/
|
||||
|
||||
var Discord = require("../");
|
||||
|
||||
// Get the email and password
|
||||
var AuthDetails = require("./auth.json");
|
||||
|
||||
var bot = new Discord.Client();
|
||||
|
||||
bot.on("ready", function () {
|
||||
console.log("Ready to begin! Serving in " + bot.channels.length + " channels");
|
||||
});
|
||||
|
||||
bot.on("disconnected", function () {
|
||||
|
||||
console.log("Disconnected!");
|
||||
process.exit(1); //exit node.js with an error
|
||||
|
||||
});
|
||||
|
||||
bot.on("message", function (msg) {
|
||||
if (msg.content === "$avatar") {
|
||||
|
||||
//see if the user has an avatar
|
||||
if( msg.sender.avatarURL ){
|
||||
bot.reply(msg, msg.sender.avatarURL);
|
||||
}else{
|
||||
//using reply with a message automatically does:
|
||||
// '@sender, ' for you!
|
||||
bot.reply(msg, "you don't have an avatar!");
|
||||
}
|
||||
|
||||
//alert the console
|
||||
console.log("served " + msg.sender.username);
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
bot.login(AuthDetails.email, AuthDetails.password);
|
||||
36
examples/catapi.js
Normal file
36
examples/catapi.js
Normal file
@@ -0,0 +1,36 @@
|
||||
/*
|
||||
this bot will send an image of a cat to a channel.
|
||||
may be slow depending on your internet connection.
|
||||
*/
|
||||
|
||||
var Discord = require("../");
|
||||
|
||||
// Get the email and password
|
||||
var AuthDetails = require("./auth.json");
|
||||
|
||||
var bot = new Discord.Client();
|
||||
|
||||
bot.on("ready", function () {
|
||||
console.log("Ready to begin! Serving in " + bot.channels.length + " channels");
|
||||
});
|
||||
|
||||
bot.on("disconnected", function () {
|
||||
|
||||
console.log("Disconnected!");
|
||||
process.exit(1); //exit node.js with an error
|
||||
|
||||
});
|
||||
|
||||
bot.on("message", function (msg) {
|
||||
if (msg.content === "$cat") {
|
||||
|
||||
//send a message to the channel the ping message was sent in.
|
||||
bot.sendMessage(msg.channel, "pong!");
|
||||
|
||||
//alert the console
|
||||
console.log("pong-ed " + msg.sender.username);
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
bot.login(AuthDetails.email, AuthDetails.password);
|
||||
@@ -11,23 +11,26 @@ var AuthDetails = require("./auth.json");
|
||||
|
||||
var bot = new Discord.Client();
|
||||
|
||||
bot.on("ready", function(){
|
||||
bot.on("ready", function () {
|
||||
console.log("Ready to begin! Serving in " + bot.channels.length + " channels");
|
||||
});
|
||||
|
||||
bot.on("disconnected", function(){
|
||||
|
||||
bot.on("disconnected", function () {
|
||||
|
||||
console.log("Disconnected!");
|
||||
process.exit(1); //exit node.js with an error
|
||||
|
||||
});
|
||||
|
||||
bot.on("message", function(msg){
|
||||
if(msg.content.substring(0,4) === "ping"){
|
||||
bot.on("message", function (msg) {
|
||||
if (msg.content.substring(0, 4) === "ping") {
|
||||
|
||||
//send a message to the channel the ping message was sent in.
|
||||
bot.sendMessage( msg.channel, "pong!" );
|
||||
bot.sendMessage(msg.channel, "pong!");
|
||||
|
||||
//alert the console
|
||||
console.log("pong-ed " + msg.sender.username);
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
249
lib/Client.js
249
lib/Client.js
@@ -19,7 +19,7 @@ var WebSocket = require("ws");
|
||||
var fs = require("fs");
|
||||
|
||||
var defaultOptions = {
|
||||
queue: []
|
||||
queue: false
|
||||
};
|
||||
|
||||
var Client = (function () {
|
||||
@@ -35,7 +35,7 @@ var Client = (function () {
|
||||
further efforts will be made to connect.
|
||||
*/
|
||||
this.options = options;
|
||||
this.options.queue = this.options.queue || [];
|
||||
this.options.queue = this.options.queue;
|
||||
this.token = token;
|
||||
this.state = 0;
|
||||
this.websocket = null;
|
||||
@@ -62,7 +62,7 @@ var Client = (function () {
|
||||
this.pmChannelCache = [];
|
||||
this.readyTime = null;
|
||||
this.checkingQueue = {};
|
||||
this.messageQueue = {};
|
||||
this.queue = {};
|
||||
}
|
||||
|
||||
_createClass(Client, [{
|
||||
@@ -339,7 +339,7 @@ var Client = (function () {
|
||||
|
||||
var self = this;
|
||||
|
||||
return new Promise(function (resolve, reject) {
|
||||
var prom = new Promise(function (resolve, reject) {
|
||||
if (timeout) {
|
||||
setTimeout(remove, timeout);
|
||||
} else {
|
||||
@@ -347,17 +347,37 @@ var Client = (function () {
|
||||
}
|
||||
|
||||
function remove() {
|
||||
request.del(Endpoints.CHANNELS + "/" + message.channel.id + "/messages/" + message.id).set("authorization", self.token).end(function (err, res) {
|
||||
if (err) {
|
||||
callback(err);
|
||||
reject(err);
|
||||
} else {
|
||||
callback(null);
|
||||
resolve();
|
||||
if (self.options.queue) {
|
||||
if (!self.queue[message.channel.id]) {
|
||||
self.queue[message.channel.id] = [];
|
||||
}
|
||||
});
|
||||
self.queue[message.channel.id].push({
|
||||
action: "deleteMessage",
|
||||
message: message,
|
||||
then: good,
|
||||
error: bad
|
||||
});
|
||||
|
||||
self.checkQueue(message.channel.id);
|
||||
} else {
|
||||
self._deleteMessage(message).then(good)["catch"](bad);
|
||||
}
|
||||
}
|
||||
|
||||
function good() {
|
||||
prom.success = true;
|
||||
callback(null);
|
||||
resolve();
|
||||
}
|
||||
|
||||
function bad(err) {
|
||||
prom.error = err;
|
||||
callback(err);
|
||||
reject(err);
|
||||
}
|
||||
});
|
||||
|
||||
return prom;
|
||||
}
|
||||
}, {
|
||||
key: "updateMessage",
|
||||
@@ -366,26 +386,41 @@ var Client = (function () {
|
||||
|
||||
var self = this;
|
||||
|
||||
return new Promise(function (resolve, reject) {
|
||||
var prom = new Promise(function (resolve, reject) {
|
||||
|
||||
content = content instanceof Array ? content.join("\n") : content;
|
||||
|
||||
request.patch(Endpoints.CHANNELS + "/" + message.channel.id + "/messages/" + message.id).set("authorization", self.token).send({
|
||||
content: content,
|
||||
mentions: []
|
||||
}).end(function (err, res) {
|
||||
if (err) {
|
||||
callback(err);
|
||||
reject(err);
|
||||
} else {
|
||||
var msg = new Message(res.body, message.channel, message.mentions, message.sender);
|
||||
callback(null, msg);
|
||||
resolve(msg);
|
||||
|
||||
message.channel.messages[message.channel.messages.indexOf(message)] = msg;
|
||||
if (self.options.queue) {
|
||||
if (!self.queue[message.channel.id]) {
|
||||
self.queue[message.channel.id] = [];
|
||||
}
|
||||
});
|
||||
self.queue[message.channel.id].push({
|
||||
action: "updateMessage",
|
||||
message: message,
|
||||
content: content,
|
||||
then: good,
|
||||
error: bad
|
||||
});
|
||||
|
||||
self.checkQueue(message.channel.id);
|
||||
} else {
|
||||
self._updateMessage(message, content).then(good)["catch"](bad);
|
||||
}
|
||||
|
||||
function good(msg) {
|
||||
prom.message = msg;
|
||||
callback(null, msg);
|
||||
resolve(msg);
|
||||
}
|
||||
|
||||
function bad(error) {
|
||||
prom.error = error;
|
||||
callback(error);
|
||||
reject(error);
|
||||
}
|
||||
});
|
||||
|
||||
return prom;
|
||||
}
|
||||
}, {
|
||||
key: "setUsername",
|
||||
@@ -549,7 +584,7 @@ var Client = (function () {
|
||||
|
||||
var self = this;
|
||||
|
||||
return new Promise(function (resolve, reject) {
|
||||
var prom = new Promise(function (resolve, reject) {
|
||||
|
||||
var fstream;
|
||||
|
||||
@@ -563,27 +598,41 @@ var Client = (function () {
|
||||
self.resolveDestination(destination).then(send)["catch"](error);
|
||||
|
||||
function send(destination) {
|
||||
request.post(Endpoints.CHANNELS + "/" + destination + "/messages").set("authorization", self.token).attach("file", fstream, fileName).end(function (err, res) {
|
||||
|
||||
if (err) {
|
||||
error(err);
|
||||
} else {
|
||||
|
||||
var chann = self.getChannel("id", destination);
|
||||
if (chann) {
|
||||
var msg = chann.addMessage(new Message(res.body, chann, [], self.user));
|
||||
callback(null, msg);
|
||||
resolve(msg);
|
||||
}
|
||||
if (self.options.queue) {
|
||||
//queue send file too
|
||||
if (!self.queue[destination]) {
|
||||
self.queue[destination] = [];
|
||||
}
|
||||
});
|
||||
|
||||
self.queue[destination].push({
|
||||
action: "sendFile",
|
||||
attachment: fstream,
|
||||
attachmentName: fileName,
|
||||
then: good,
|
||||
error: bad
|
||||
});
|
||||
|
||||
self.checkQueue(destination);
|
||||
} else {
|
||||
//not queue
|
||||
self._sendFile(destination, fstream, fileName).then(good)["catch"](bad);
|
||||
}
|
||||
}
|
||||
|
||||
function error(err) {
|
||||
function good(msg) {
|
||||
prom.message = msg;
|
||||
callback(null, msg);
|
||||
resolve(msg);
|
||||
}
|
||||
|
||||
function bad(err) {
|
||||
prom.error = err;
|
||||
callback(err);
|
||||
reject(err);
|
||||
}
|
||||
});
|
||||
|
||||
return prom;
|
||||
}
|
||||
}, {
|
||||
key: "sendMessage",
|
||||
@@ -605,18 +654,18 @@ var Client = (function () {
|
||||
}
|
||||
|
||||
function send(destination) {
|
||||
if (~self.options.queue.indexOf("sendMessage")) {
|
||||
if (self.options.queue) {
|
||||
//we're QUEUEING messages, so sending them sequentially based on servers.
|
||||
if (!self.messageQueue[destination]) {
|
||||
self.messageQueue[destination] = [];
|
||||
if (!self.queue[destination]) {
|
||||
self.queue[destination] = [];
|
||||
}
|
||||
|
||||
self.messageQueue[destination].push({
|
||||
self.queue[destination].push({
|
||||
action: "sendMessage",
|
||||
content: message,
|
||||
mentions: mentions,
|
||||
then: [mgood],
|
||||
error: [mbad]
|
||||
then: mgood,
|
||||
error: mbad
|
||||
});
|
||||
|
||||
self.checkQueue(destination);
|
||||
@@ -1395,6 +1444,62 @@ var Client = (function () {
|
||||
});
|
||||
});
|
||||
}
|
||||
}, {
|
||||
key: "_sendFile",
|
||||
value: function _sendFile(destination, attachment) {
|
||||
var attachmentName = arguments.length <= 2 || arguments[2] === undefined ? "DEFAULT BECAUSE YOU DIDN'T SPECIFY WHY.png" : arguments[2];
|
||||
|
||||
var self = this;
|
||||
|
||||
return new Promise(function (resolve, reject) {
|
||||
request.post(Endpoints.CHANNELS + "/" + destination + "/messages").set("authorization", self.token).attach("file", attachment, attachmentName).end(function (err, res) {
|
||||
|
||||
if (err) {
|
||||
reject(err);
|
||||
} else {
|
||||
|
||||
var chann = self.getChannel("id", destination);
|
||||
if (chann) {
|
||||
var msg = chann.addMessage(new Message(res.body, chann, [], self.user));
|
||||
resolve(msg);
|
||||
}
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
}, {
|
||||
key: "_updateMessage",
|
||||
value: function _updateMessage(message, content) {
|
||||
var self = this;
|
||||
return new Promise(function (resolve, reject) {
|
||||
request.patch(Endpoints.CHANNELS + "/" + message.channel.id + "/messages/" + message.id).set("authorization", self.token).send({
|
||||
content: content,
|
||||
mentions: []
|
||||
}).end(function (err, res) {
|
||||
if (err) {
|
||||
reject(err);
|
||||
} else {
|
||||
var msg = new Message(res.body, message.channel, message.mentions, message.sender);
|
||||
resolve(msg);
|
||||
message.channel.messages[message.channel.messages.indexOf(message)] = msg;
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
}, {
|
||||
key: "_deleteMessage",
|
||||
value: function _deleteMessage(message) {
|
||||
var self = this;
|
||||
return new Promise(function (resolve, reject) {
|
||||
request.del(Endpoints.CHANNELS + "/" + message.channel.id + "/messages/" + message.id).set("authorization", self.token).end(function (err, res) {
|
||||
if (err) {
|
||||
reject(err);
|
||||
} else {
|
||||
resolve();
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
}, {
|
||||
key: "checkQueue",
|
||||
value: function checkQueue(channelID) {
|
||||
@@ -1405,21 +1510,57 @@ var Client = (function () {
|
||||
if (!this.checkingQueue[channelID]) {
|
||||
(function () {
|
||||
var doNext = function doNext() {
|
||||
if (self.messageQueue[channelID].length === 0) {
|
||||
if (self.queue[channelID].length === 0) {
|
||||
done();
|
||||
return;
|
||||
}
|
||||
var queuedEvent = self.messageQueue[channelID][0];
|
||||
var queuedEvent = self.queue[channelID][0];
|
||||
switch (queuedEvent.action) {
|
||||
case "sendMessage":
|
||||
var msgToSend = queuedEvent;
|
||||
self._sendMessage(channelID, msgToSend.content, msgToSend.mentions).then(function (msg) {
|
||||
msgToSend.then[0](msg);
|
||||
self.messageQueue[channelID].shift();
|
||||
msgToSend.then(msg);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
})["catch"](function (err) {
|
||||
msgToSend["catch"][0](err);
|
||||
self.messageQueue[channelID].shift();
|
||||
msgToSend.error(err);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
});
|
||||
break;
|
||||
case "sendFile":
|
||||
var fileToSend = queuedEvent;
|
||||
self._sendFile(channelID, fileToSend.attachment, fileToSend.attachmentName).then(function (msg) {
|
||||
fileToSend.then(msg);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
})["catch"](function (err) {
|
||||
fileToSend.error(err);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
});
|
||||
break;
|
||||
case "updateMessage":
|
||||
var msgToUpd = queuedEvent;
|
||||
self._updateMessage(msgToUpd.message, msgToUpd.content).then(function (msg) {
|
||||
msgToUpd.then(msg);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
})["catch"](function (err) {
|
||||
msgToUpd.error(err);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
});
|
||||
break;
|
||||
case "deleteMessage":
|
||||
var msgToDel = queuedEvent;
|
||||
self._deleteMessage(msgToDel.message).then(function (msg) {
|
||||
msgToDel.then(msg);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
})["catch"](function (err) {
|
||||
msgToDel.error(err);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
});
|
||||
break;
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "discord.js",
|
||||
"version": "3.1.3",
|
||||
"version": "3.1.4",
|
||||
"description": "A way to interface with the Discord API",
|
||||
"main": "./lib/index.js",
|
||||
"scripts": {
|
||||
|
||||
272
src/Client.js
272
src/Client.js
@@ -13,7 +13,7 @@ var WebSocket = require("ws");
|
||||
var fs = require("fs");
|
||||
|
||||
var defaultOptions = {
|
||||
queue: []
|
||||
queue: false
|
||||
}
|
||||
|
||||
class Client {
|
||||
@@ -25,7 +25,7 @@ class Client {
|
||||
further efforts will be made to connect.
|
||||
*/
|
||||
this.options = options;
|
||||
this.options.queue = this.options.queue || [];
|
||||
this.options.queue = this.options.queue;
|
||||
this.token = token;
|
||||
this.state = 0;
|
||||
this.websocket = null;
|
||||
@@ -52,7 +52,7 @@ class Client {
|
||||
this.pmChannelCache = [];
|
||||
this.readyTime = null;
|
||||
this.checkingQueue = {};
|
||||
this.messageQueue = {};
|
||||
this.queue = {};
|
||||
}
|
||||
|
||||
get uptime() {
|
||||
@@ -384,18 +384,33 @@ class Client {
|
||||
}
|
||||
|
||||
function remove() {
|
||||
request
|
||||
.del(`${Endpoints.CHANNELS}/${message.channel.id}/messages/${message.id}`)
|
||||
.set("authorization", self.token)
|
||||
.end(function (err, res) {
|
||||
if (err) {
|
||||
callback(err);
|
||||
reject(err);
|
||||
} else {
|
||||
callback(null);
|
||||
resolve();
|
||||
}
|
||||
if(self.options.queue){
|
||||
if (!self.queue[message.channel.id]) {
|
||||
self.queue[message.channel.id] = [];
|
||||
}
|
||||
self.queue[message.channel.id].push({
|
||||
action: "deleteMessage",
|
||||
message: message,
|
||||
then: good,
|
||||
error: bad
|
||||
});
|
||||
|
||||
self.checkQueue(message.channel.id);
|
||||
}else{
|
||||
self._deleteMessage(message).then(good).catch(bad);
|
||||
}
|
||||
}
|
||||
|
||||
function good(){
|
||||
prom.success = true;
|
||||
callback(null);
|
||||
resolve();
|
||||
}
|
||||
|
||||
function bad(err){
|
||||
prom.error = err;
|
||||
callback(err);
|
||||
reject(err);
|
||||
}
|
||||
});
|
||||
|
||||
@@ -406,31 +421,42 @@ class Client {
|
||||
|
||||
var self = this;
|
||||
|
||||
return new Promise(function (resolve, reject) {
|
||||
var prom = new Promise(function (resolve, reject) {
|
||||
|
||||
content = (content instanceof Array ? content.join("\n") : content);
|
||||
|
||||
request
|
||||
.patch(`${Endpoints.CHANNELS}/${message.channel.id}/messages/${message.id}`)
|
||||
.set("authorization", self.token)
|
||||
.send({
|
||||
if(self.options.queue){
|
||||
if (!self.queue[message.channel.id]) {
|
||||
self.queue[message.channel.id] = [];
|
||||
}
|
||||
self.queue[message.channel.id].push({
|
||||
action: "updateMessage",
|
||||
message: message,
|
||||
content: content,
|
||||
mentions: []
|
||||
})
|
||||
.end(function (err, res) {
|
||||
if (err) {
|
||||
callback(err);
|
||||
reject(err);
|
||||
} else {
|
||||
var msg = new Message(res.body, message.channel, message.mentions, message.sender);
|
||||
callback(null, msg);
|
||||
resolve(msg);
|
||||
|
||||
message.channel.messages[message.channel.messages.indexOf(message)] = msg;
|
||||
}
|
||||
then: good,
|
||||
error: bad
|
||||
});
|
||||
|
||||
self.checkQueue(message.channel.id);
|
||||
}else{
|
||||
self._updateMessage(message, content).then(good).catch(bad);
|
||||
}
|
||||
|
||||
function good(msg){
|
||||
prom.message = msg;
|
||||
callback(null, msg);
|
||||
resolve(msg);
|
||||
}
|
||||
|
||||
function bad(error){
|
||||
prom.error = error;
|
||||
callback(error);
|
||||
reject(error);
|
||||
}
|
||||
|
||||
});
|
||||
|
||||
return prom;
|
||||
}
|
||||
|
||||
setUsername(newName, callback = function (err) { }) {
|
||||
@@ -563,7 +589,7 @@ class Client {
|
||||
|
||||
var self = this;
|
||||
|
||||
return new Promise(function (resolve, reject) {
|
||||
var prom = new Promise(function (resolve, reject) {
|
||||
|
||||
var fstream;
|
||||
|
||||
@@ -577,35 +603,42 @@ class Client {
|
||||
self.resolveDestination(destination).then(send).catch(error);
|
||||
|
||||
function send(destination) {
|
||||
request
|
||||
.post(`${Endpoints.CHANNELS}/${destination}/messages`)
|
||||
.set("authorization", self.token)
|
||||
.attach("file", fstream, fileName)
|
||||
.end(function (err, res) {
|
||||
|
||||
if (err) {
|
||||
error(err);
|
||||
} else {
|
||||
|
||||
var chann = self.getChannel("id", destination);
|
||||
if (chann) {
|
||||
var msg = chann.addMessage(new Message(res.body, chann, [], self.user));
|
||||
callback(null, msg);
|
||||
resolve(msg);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
if(self.options.queue){
|
||||
//queue send file too
|
||||
if (!self.queue[destination]) {
|
||||
self.queue[destination] = [];
|
||||
}
|
||||
|
||||
self.queue[destination].push({
|
||||
action: "sendFile",
|
||||
attachment : fstream,
|
||||
attachmentName : fileName,
|
||||
then: good,
|
||||
error: bad
|
||||
});
|
||||
|
||||
self.checkQueue(destination);
|
||||
}else{
|
||||
//not queue
|
||||
self._sendFile(destination, fstream, fileName).then(good).catch(bad);
|
||||
}
|
||||
}
|
||||
|
||||
function error(err) {
|
||||
function good(msg) {
|
||||
prom.message = msg;
|
||||
callback(null, msg);
|
||||
resolve(msg);
|
||||
}
|
||||
|
||||
function bad(err) {
|
||||
prom.error = err;
|
||||
callback(err);
|
||||
reject(err);
|
||||
}
|
||||
|
||||
});
|
||||
|
||||
return prom;
|
||||
|
||||
}
|
||||
|
||||
@@ -625,18 +658,18 @@ class Client {
|
||||
}
|
||||
|
||||
function send(destination) {
|
||||
if (~self.options.queue.indexOf("sendMessage")) {
|
||||
if (self.options.queue) {
|
||||
//we're QUEUEING messages, so sending them sequentially based on servers.
|
||||
if (!self.messageQueue[destination]) {
|
||||
self.messageQueue[destination] = [];
|
||||
if (!self.queue[destination]) {
|
||||
self.queue[destination] = [];
|
||||
}
|
||||
|
||||
self.messageQueue[destination].push({
|
||||
self.queue[destination].push({
|
||||
action: "sendMessage",
|
||||
content: message,
|
||||
mentions: mentions,
|
||||
then: [mgood],
|
||||
error: [mbad]
|
||||
then: mgood,
|
||||
error: mbad
|
||||
});
|
||||
|
||||
self.checkQueue(destination);
|
||||
@@ -1156,6 +1189,73 @@ class Client {
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
_sendFile(destination, attachment, attachmentName = "DEFAULT BECAUSE YOU DIDN'T SPECIFY WHY.png"){
|
||||
|
||||
var self = this;
|
||||
|
||||
return new Promise(function(resolve, reject){
|
||||
request
|
||||
.post(`${Endpoints.CHANNELS}/${destination}/messages`)
|
||||
.set("authorization", self.token)
|
||||
.attach("file", attachment, attachmentName)
|
||||
.end(function (err, res) {
|
||||
|
||||
if (err) {
|
||||
reject(err);
|
||||
} else {
|
||||
|
||||
var chann = self.getChannel("id", destination);
|
||||
if (chann) {
|
||||
var msg = chann.addMessage(new Message(res.body, chann, [], self.user));
|
||||
resolve(msg);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
});
|
||||
});
|
||||
|
||||
}
|
||||
|
||||
_updateMessage(message, content){
|
||||
var self = this;
|
||||
return new Promise(function(resolve, reject){
|
||||
request
|
||||
.patch(`${Endpoints.CHANNELS}/${message.channel.id}/messages/${message.id}`)
|
||||
.set("authorization", self.token)
|
||||
.send({
|
||||
content: content,
|
||||
mentions: []
|
||||
})
|
||||
.end(function (err, res) {
|
||||
if (err) {
|
||||
reject(err);
|
||||
} else {
|
||||
var msg = new Message(res.body, message.channel, message.mentions, message.sender);
|
||||
resolve(msg);
|
||||
message.channel.messages[message.channel.messages.indexOf(message)] = msg;
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
_deleteMessage(message){
|
||||
var self = this;
|
||||
return new Promise(function(resolve, reject){
|
||||
request
|
||||
.del(`${Endpoints.CHANNELS}/${message.channel.id}/messages/${message.id}`)
|
||||
.set("authorization", self.token)
|
||||
.end(function (err, res) {
|
||||
if (err) {
|
||||
reject(err);
|
||||
} else {
|
||||
resolve();
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
checkQueue(channelID) {
|
||||
|
||||
@@ -1167,26 +1267,68 @@ class Client {
|
||||
doNext();
|
||||
|
||||
function doNext() {
|
||||
if (self.messageQueue[channelID].length === 0) {
|
||||
if (self.queue[channelID].length === 0) {
|
||||
done();
|
||||
return;
|
||||
}
|
||||
var queuedEvent = self.messageQueue[channelID][0];
|
||||
var queuedEvent = self.queue[channelID][0];
|
||||
switch (queuedEvent.action) {
|
||||
case "sendMessage":
|
||||
var msgToSend = queuedEvent;
|
||||
self._sendMessage(channelID, msgToSend.content, msgToSend.mentions)
|
||||
.then(function (msg) {
|
||||
msgToSend.then[0](msg);
|
||||
self.messageQueue[channelID].shift();
|
||||
msgToSend.then(msg);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
})
|
||||
.catch(function (err) {
|
||||
msgToSend.catch[0](err);
|
||||
self.messageQueue[channelID].shift();
|
||||
msgToSend.error(err);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
});
|
||||
break;
|
||||
case "sendFile":
|
||||
var fileToSend = queuedEvent;
|
||||
self._sendFile(channelID, fileToSend.attachment, fileToSend.attachmentName)
|
||||
.then(function (msg){
|
||||
fileToSend.then(msg);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
})
|
||||
.catch(function(err){
|
||||
fileToSend.error(err);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
});
|
||||
break;
|
||||
case "updateMessage":
|
||||
var msgToUpd = queuedEvent;
|
||||
self._updateMessage(msgToUpd.message, msgToUpd.content)
|
||||
.then(function(msg){
|
||||
msgToUpd.then(msg);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
})
|
||||
.catch(function(err){
|
||||
msgToUpd.error(err);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
});
|
||||
break;
|
||||
case "deleteMessage":
|
||||
var msgToDel = queuedEvent;
|
||||
self._deleteMessage(msgToDel.message)
|
||||
.then(function(msg){
|
||||
msgToDel.then(msg);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
})
|
||||
.catch(function(err){
|
||||
msgToDel.error(err);
|
||||
self.queue[channelID].shift();
|
||||
doNext();
|
||||
});
|
||||
break;
|
||||
default:
|
||||
done();
|
||||
break;
|
||||
|
||||
@@ -1,26 +1,37 @@
|
||||
var Discord = require("../");
|
||||
var mybot = new Discord.Client({
|
||||
queue : ["sendMessage"]
|
||||
queue: true
|
||||
});
|
||||
var fs = require("fs");
|
||||
|
||||
var server, channel, message, sentMessage = false;
|
||||
|
||||
mybot.on("message", function(message){
|
||||
|
||||
if( mybot.user.equals(message.sender) ){
|
||||
mybot.on("message", function (message) {
|
||||
|
||||
if (mybot.user.equals(message.sender)) {
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
if (message.content !== "$$$") {
|
||||
return;
|
||||
}
|
||||
|
||||
var action1 = mybot.sendMessage(message.channel, "this is message " + 1);
|
||||
var action2 = mybot.sendMessage(message.channel, "this is message " + 2).then(log);
|
||||
|
||||
function log(){
|
||||
mybot.sendMessage(message.channel, action1.message ? action1.message : action1.error);
|
||||
|
||||
function log() {
|
||||
mybot.updateMessage(action1.message, "blurg");
|
||||
mybot.sendMessage(message.channel, "This is message 3 million minus the million so basically just 3");
|
||||
mybot.deleteMessage(action1.message);
|
||||
mybot.sendMessage(message.channel, "This is message RJNGEIKGNER").then(log2);
|
||||
}
|
||||
|
||||
});
|
||||
|
||||
function error(err){
|
||||
function dump(msg) {
|
||||
console.log(msg);
|
||||
}
|
||||
|
||||
function error(err) {
|
||||
console.log(err);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user