Work on UserTypes.

This commit is contained in:
Kitteh 2021-06-03 12:31:40 +01:00
parent 3920682ff5
commit a68c3e2c82
11 changed files with 129 additions and 18 deletions

View file

@ -22,10 +22,12 @@ pub const Client = struct {
stream: *std.net.Stream, stream: *std.net.Stream,
pub fn handshake(s: *Client) !void { pub fn handshake(s: *Client) !void {
const magic = 0x42b33f00; //const magic = 0x42b33f00;
//try write.writeUInt(s.stream.writer(), magic);
//try write.writeUInt(s.stream.writer(), 0x80000002);
try s.stream.writer().writeAll(&[_]u8{0x42, 0xb3, 0x3f, 0x00, 0x00, 0x00, 0x00, 0x01, 0x80, 0x00, 0x00, 0x00});
try write.writeUInt(s.stream.writer(), magic);
try write.writeUInt(s.stream.writer(), 0x80000002);
var flags = try read.readByte(s.stream.reader()); var flags = try read.readByte(s.stream.reader());
var extra = try read.readShort(s.stream.reader()); var extra = try read.readShort(s.stream.reader());
var version = try read.readSignedByte(s.stream.reader()); var version = try read.readSignedByte(s.stream.reader());
@ -38,6 +40,9 @@ pub const Client = struct {
var map = std.StringHashMap(QVariantType).init(s.allocator); var map = std.StringHashMap(QVariantType).init(s.allocator);
try map.put("MsgType", .{ .String = "ClientInit" }); try map.put("MsgType", .{ .String = "ClientInit" });
try map.put("UseCompression", .{ .UInt = 0 });
try map.put("UseSSL", .{ .UInt = 0 });
try map.put("ProtocolVersion", .{ .UInt = 10 }); try map.put("ProtocolVersion", .{ .UInt = 10 });
try map.put("ClientVersion", .{ .String = "0.1 (quasselclient)" }); try map.put("ClientVersion", .{ .String = "0.1 (quasselclient)" });
try map.put("ClientDate", .{ .String = "Wed, 02 Jun 2021 17:30:30 +0100" }); try map.put("ClientDate", .{ .String = "Wed, 02 Jun 2021 17:30:30 +0100" });

View file

@ -7,12 +7,23 @@ const initClient = @import("./client.zig").initClient;
pub fn main() !void { pub fn main() !void {
const allocator = std.heap.page_allocator; const allocator = std.heap.page_allocator;
var sock = try std.net.tcpConnectToHost(allocator, "127.0.0.1", 64242);
var argIter = std.process.args();
_ = try argIter.next(allocator).?;
var host = try argIter.next(allocator).?;
var port = try argIter.next(allocator).?;
var portInt = try std.fmt.parseInt(u16, port, 10);
var username = try argIter.next(allocator).?;
var password = try argIter.next(allocator).?;
std.debug.print("host={s} port={d}\n", .{host, portInt});
var sock = try std.net.tcpConnectToHost(allocator, host, portInt);
var client = initClient(allocator, &sock); var client = initClient(allocator, &sock);
try client.handshake(); try client.handshake();
try client.quassel_init_packet(); try client.quassel_init_packet();
try client.quassel_login("z", "password"); try client.quassel_login(username, password);
while (true) { while (true) {
try client.read_quassel_packet(); try client.read_quassel_packet();
} }

View file

@ -9,4 +9,4 @@ pub const readQVariantList = @import("./read/readQVariantList.zig").readQVariant
pub const readQVariantT = @import("./read/readQVariantT.zig").readQVariantT; pub const readQVariantT = @import("./read/readQVariantT.zig").readQVariantT;
pub const readQVariant = @import("./read/readQVariant.zig").readQVariant; pub const readQVariant = @import("./read/readQVariant.zig").readQVariant;
pub const readQVariantMap = @import("./read/readQVariantMap.zig").readQVariantMap; pub const readQVariantMap = @import("./read/readQVariantMap.zig").readQVariantMap;
pub const readQStringList = @import("./readQStringList.zig").readQStringList; pub const readQStringList = @import("./read/readQStringList.zig").readQStringList;

View file

@ -0,0 +1,3 @@
pub fn readLong(reader: anytype) !i64 {
return try reader.readIntBig(i64);
}

View file

@ -11,6 +11,7 @@ const readQVariantList = @import("./readQVariantList.zig").readQVariantList;
const readQVariant = @import("./readQVariant.zig").readQVariant; const readQVariant = @import("./readQVariant.zig").readQVariant;
const readQVariantMap = @import("./readQVariantMap.zig").readQVariantMap; const readQVariantMap = @import("./readQVariantMap.zig").readQVariantMap;
const readQStringList = @import("./readQStringList.zig").readQStringList; const readQStringList = @import("./readQStringList.zig").readQStringList;
const readUserType = @import("./usertypes/readUserType.zig").readUserType;
const QVariant = @import("../types/QVariant.zig").QVariant; const QVariant = @import("../types/QVariant.zig").QVariant;
const QVariantTypes = @import("../types/QVariantTypes.zig").QVariantTypes; const QVariantTypes = @import("../types/QVariantTypes.zig").QVariantTypes;
@ -54,9 +55,8 @@ pub fn readQVariantT(reader: anytype, type_id: u32, allocator: *std.mem.Allocato
return QVariant{ .Short = short }; return QVariant{ .Short = short };
}, },
@enumToInt(QVariantTypes.UserType) => { @enumToInt(QVariantTypes.UserType) => {
var userTypeName = readQByteArray(reader, allocator); var usertype = try readUserType(reader, allocator);
std.debug.print("name: {s}\n", .{userTypeName}); return QVariant{ .UserType = usertype };
@panic("TODO IMPLEMENT USERTYPES.");
}, },
else => { else => {
std.debug.print("Unknown Type ID: {d}\n", .{type_id}); std.debug.print("Unknown Type ID: {d}\n", .{type_id});

View file

@ -0,0 +1,71 @@
const std = @import("std");
const UserType = @import("../../types/UserType.zig").UserType;
const UserTypeNames = @import("../../types/UserType.zig").UserTypeNames;
const readInt = @import("../readInt.zig").readInt;
const readShort = @import("../readShort.zig").readShort;
const readLong = @import("../readLong.zig").readLong;
const readQByteArray = @import("../readQByteArray.zig").readQByteArray;
const readQVariantMap = @import("../readQVariantMap.zig").readQVariantMap;
pub fn readUserType(reader: anytype, allocator: *std.mem.Allocator) !UserType {
var userTypeName = try readQByteArray(reader, allocator);
userTypeName = userTypeName[0 .. userTypeName.len - 1];
if (std.mem.eql(u8, userTypeName, "BufferId")) {
return UserType{
.BufferId = try readInt(reader),
};
} else if (std.mem.eql(u8, userTypeName, "IdentityId")) {
return UserType{
.IdentityId = try readInt(reader),
};
} else if (std.mem.eql(u8, userTypeName, "NetworkId")) {
return UserType{
.NetworkId = try readInt(reader),
};
} else if (std.mem.eql(u8, userTypeName, "MsgId")) {
return UserType{
.MsgId = try readInt(reader),
};
} else if (std.mem.eql(u8, userTypeName, "PeerPtr")) {
return UserType{
.PeerPtr = try readLong(reader),
};
} else if (std.mem.eql(u8, userTypeName, "IrcUser")) {
return UserType{
.IrcUser = try readQVariantMap(reader, allocator),
};
} else if (std.mem.eql(u8, userTypeName, "IrcChannel")) {
return UserType{
.IrcChannel = try readQVariantMap(reader, allocator),
};
} else if (std.mem.eql(u8, userTypeName, "Identity")) {
return UserType{
.Identity = try readQVariantMap(reader, allocator),
};
} else if (std.mem.eql(u8, userTypeName, "NetworkInfo")) {
return UserType{
.NetworkInfo = try readQVariantMap(reader, allocator),
};
} else if (std.mem.eql(u8, userTypeName, "NetworkServer")) {
return UserType{
.NetworkServer = try readQVariantMap(reader, allocator),
};
} else if (std.mem.eql(u8, userTypeName, "BufferInfo")) {
return UserType{
.BufferInfo = .{
.ID = try readInt(reader),
.NetworkID = try readInt(reader),
.Type = try readShort(reader),
.Name = try readQByteArray(reader, allocator),
},
};
} else {
std.debug.print("Unknown UserType With Name: {s}\n", .{userTypeName});
@panic("Unknown Usertype.");
}
return UserType{
.NetworkId = 1,
};
}

View file

@ -4,7 +4,8 @@ const global_allocator = std.testing.allocator;
const read = @import("./read.zig"); const read = @import("./read.zig");
const write = @import("./write.zig"); const write = @import("./write.zig");
const qvar = @import("./qvariant.zig"); const QVariant = @import("./types/QVariant.zig").QVariant;
const freeQVariant = @import("./utils/freeQVariant.zig").freeQVariant;
test "UInt serialization/deserialization" { test "UInt serialization/deserialization" {
var byteList = std.ArrayList(u8).init(global_allocator); var byteList = std.ArrayList(u8).init(global_allocator);
@ -122,7 +123,7 @@ test "QVariant QVariantMap serialization/deserialization" {
var byteList = std.ArrayList(u8).init(global_allocator); var byteList = std.ArrayList(u8).init(global_allocator);
defer byteList.deinit(); defer byteList.deinit();
var map = std.StringHashMap(qvar.QVariant).init(global_allocator); var map = std.StringHashMap(QVariant).init(global_allocator);
defer map.deinit(); defer map.deinit();
try map.put("testkey", .{ .UInt = 1337 }); try map.put("testkey", .{ .UInt = 1337 });
@ -133,7 +134,7 @@ test "QVariant QVariantMap serialization/deserialization" {
var fBS = std.io.fixedBufferStream(byteList.items); var fBS = std.io.fixedBufferStream(byteList.items);
var varient = try read.readQVariant(fBS.reader(), global_allocator); var varient = try read.readQVariant(fBS.reader(), global_allocator);
defer qvar.freeQVariant(varient, global_allocator); defer freeQVariant(varient, global_allocator);
var qVariantMap = varient.QVariantMap; var qVariantMap = varient.QVariantMap;

View file

@ -1,6 +1,5 @@
const std = @import("std"); const std = @import("std");
const range = @import("./rangeiter.zig").range; const UserType = @import("./UserType.zig").UserType;
const UserTypes = @import("./UserTypes.zig").UserTypes;
pub const QVariant = union(enum) { pub const QVariant = union(enum) {
Int: i32, Int: i32,
@ -12,5 +11,5 @@ pub const QVariant = union(enum) {
QStringList: [][]const u8, QStringList: [][]const u8,
QVariantList: []QVariant, QVariantList: []QVariant,
QVariantMap: std.StringHashMap(QVariant), QVariantMap: std.StringHashMap(QVariant),
UserType: UserTypes, UserType: UserType,
}; };

View file

@ -0,0 +1,23 @@
const std = @import("std");
const QVariant = @import("./QVariant.zig").QVariant;
pub const UserType = union(enum) {
BufferId: i32,
IdentityId: i32,
NetworkId: i32,
MsgId: i32,
PeerPtr: i64,
IrcUser: std.StringHashMap(QVariant),
IrcChannel: std.StringHashMap(QVariant),
Identity: std.StringHashMap(QVariant),
NetworkInfo: std.StringHashMap(QVariant),
NetworkServer: std.StringHashMap(QVariant),
BufferInfo: BufferInfo,
};
pub const BufferInfo = struct {
ID: i32,
NetworkID: i32,
Type: u16,
Name: []u8,
};

View file

@ -1,3 +0,0 @@
pub const UserTypes = union(enum) {
NetworkId: i32,
};

View file

@ -3,6 +3,7 @@ pub const writeUInt = @import("./write/writeUInt.zig").writeUInt;
pub const writeShort = @import("./write/writeShort.zig").writeShort; pub const writeShort = @import("./write/writeShort.zig").writeShort;
pub const writeByte = @import("./write/writeByte.zig").writeByte; pub const writeByte = @import("./write/writeByte.zig").writeByte;
pub const writeSignedByte = @import("./write/writeSignedByte.zig").writeSignedByte; pub const writeSignedByte = @import("./write/writeSignedByte.zig").writeSignedByte;
pub const writeQStringList = @import("./write/writeQStringList.zig").writeQStringList;
pub const writeQByteArray = @import("./write/writeQByteArray.zig").writeQByteArray; pub const writeQByteArray = @import("./write/writeQByteArray.zig").writeQByteArray;
pub const writeString = @import("./write/writeString.zig").writeString; pub const writeString = @import("./write/writeString.zig").writeString;
pub const writeQVariantList = @import("./write/writeQVariantList.zig").writeQVariantList; pub const writeQVariantList = @import("./write/writeQVariantList.zig").writeQVariantList;