aboutsummaryrefslogtreecommitdiff
path: root/node_modules/mysql2/lib/packets/auth_switch_request.js
diff options
context:
space:
mode:
authorJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
committerJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
commit080c5819d87b933816d724a83f3bf4f1686770a7 (patch)
tree4a2ccc68b27edf7d4cbc586c932cc7542b655e19 /node_modules/mysql2/lib/packets/auth_switch_request.js
parent5ac7049a9d30733165cc212dee308163c2a14644 (diff)
parentd003b82235a9329f912522a2f70aa950dfce4998 (diff)
downloadLYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.tar.gz
LYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.zip
Merge branch 'master' of https://github.com/JoelHMikael/FoodJS
Updating remote changes
Diffstat (limited to 'node_modules/mysql2/lib/packets/auth_switch_request.js')
-rw-r--r--node_modules/mysql2/lib/packets/auth_switch_request.js38
1 files changed, 38 insertions, 0 deletions
diff --git a/node_modules/mysql2/lib/packets/auth_switch_request.js b/node_modules/mysql2/lib/packets/auth_switch_request.js
new file mode 100644
index 0000000..a05abf2
--- /dev/null
+++ b/node_modules/mysql2/lib/packets/auth_switch_request.js
@@ -0,0 +1,38 @@
+'use strict';
+
+// http://dev.mysql.com/doc/internals/en/connection-phase-packets.html#packet-Protocol::AuthSwitchRequest
+
+const Packet = require('../packets/packet');
+
+class AuthSwitchRequest {
+ constructor(opts) {
+ this.pluginName = opts.pluginName;
+ this.pluginData = opts.pluginData;
+ }
+
+ toPacket() {
+ const length = 6 + this.pluginName.length + this.pluginData.length;
+ const buffer = Buffer.allocUnsafe(length);
+ const packet = new Packet(0, buffer, 0, length);
+ packet.offset = 4;
+ packet.writeInt8(0xfe);
+ // TODO: use server encoding
+ packet.writeNullTerminatedString(this.pluginName, 'cesu8');
+ packet.writeBuffer(this.pluginData);
+ return packet;
+ }
+
+ static fromPacket(packet) {
+ packet.readInt8(); // marker
+ // assert marker == 0xfe?
+ // TODO: use server encoding
+ const name = packet.readNullTerminatedString('cesu8');
+ const data = packet.readBuffer();
+ return new AuthSwitchRequest({
+ pluginName: name,
+ pluginData: data
+ });
+ }
+}
+
+module.exports = AuthSwitchRequest;