replace fetch with flummi-fetch-cookies

This commit is contained in:
Flummi 2019-08-17 11:45:04 +00:00
parent a176408990
commit 5a33c21887
5 changed files with 80 additions and 35 deletions

View File

@ -5,7 +5,7 @@ import EventEmitter from "events";
const clients = [];
const cuffeo = class cuffeo extends EventEmitter {
export default class cuffeo extends EventEmitter {
constructor(cfg) {
super();
for (let srv in cfg) {
@ -36,5 +36,3 @@ const cuffeo = class cuffeo extends EventEmitter {
});
}
};
export { cuffeo, clients };

View File

@ -12,5 +12,6 @@
"author": "Flummi",
"license": "ISC",
"dependencies": {
"flumm-fetch-cookies": "git+https://gitfap.de/keinBot/flumm-fetch-cookies"
}
}

77
src/clients/discord.mjs Normal file
View File

@ -0,0 +1,77 @@
import Discord from "discord.js";
import EventEmitter from "events";
export class discord extends EventEmitter {
constructor(options) {
super();
this.options = options || {};
this.token = options.token || null;
this.set = this.options.set || "all";
this.network = "discord";
this.bot = new Discord.Client();
this.bot.login(this.token);
this.server = {
set: this.set,
channel: new Map(),
user: new Map(),
me: {}
};
this.bot.on("ready", () => {
this.server.me = {
nickname: this.bot.user.username,
username: this.bot.user.username,
account: this.bot.user.id.toString(),
prefix: `${this.bot.user.username}!${this.bot.user.id.toString()}`,
id: this.bot.user.id.toString()
};
});
this.bot.on("message", msg => {
if(msg.author.id !== this.server.me.id)
this.emit("data", ["message", this.reply(msg)]);
});
}
reply(tmp) {
return {
type: "discord",
network: "Discord",
channel: tmp.channel.name,
channelid: tmp.channel.id,
user: {
prefix: `${tmp.author.username}!${tmp.author.id}`,
nick: tmp.author.username,
username: tmp.author.username,
account: tmp.author.id.toString()
},
message: tmp.content,
time: ~~(Date.now() / 1000),
self: this.server,
reply: msg => this.send(tmp, this.format(msg)),
replyAction: msg => this.send(tmp, this.format(`*${msg}*`), "normal"),
replyNotice: msg => this.send(tmp, this.format(msg))
};
}
send(r, msg, mode = "blah") {
switch(mode) {
case "normal":
r.channel.send(msg);
break;
default:
r.reply(msg);
break;
}
}
sendmsg(mode, recipient, msg) {
this.bot.channels.get(recipient).send(msg);
}
format(msg) {
return msg.toString()
.replace(/\[b\](.*?)\[\/b\]/g, "**$1**") // bold
.replace(/\[i\](.*?)\[\/i\]/g, "*$1*") // italic
.replace(/\[color=(.*?)](.*?)\[\/color\]/g, "$2")
;
}
};

View File

@ -1,4 +1,4 @@
import fetch from "../inc/fetch";
import fetch from "flumm-fetch-cookies";
import EventEmitter from "events";
export class tg extends EventEmitter {

View File

@ -1,31 +0,0 @@
import http from "http";
import https from "https";
import url from "url";
import querystring from "querystring";
export default (a, options = {}, link = url.parse(a)) => new Promise((resolve, reject) => {
options = {...{
hostname: link.hostname,
path: link.path,
method: "GET"
}, ...options};
let body = "";
if(options.method === "POST") {
body = querystring.stringify(options.body);
delete options.body;
options.headers = {
"Content-Type": "application/x-www-form-urlencoded",
"Content-Length": Buffer.byteLength(body)
}
}
const post = (link.protocol === "https:"?https:http).request(options, (res, data = "") => res
.setEncoding("utf8")
.on("data", chunk => data += chunk)
.on("end", () => resolve({
text: () => data,
json: () => { try { return JSON.parse(data); } catch(err) { return "no json D:"; } },
buffer: () => new Buffer.from(data)
}))
).on("error", err => reject(err));
post.end(body);
});