mirror of
https://github.com/sochix/TLSharp.git
synced 2026-04-09 16:35:11 +00:00
Added tests and fixes to SendMediaFunctionality and GetHistory
This commit is contained in:
parent
c77cfc064d
commit
9cc6942088
8 changed files with 157 additions and 99 deletions
|
|
@ -5,68 +5,74 @@ using TLSharp.Core.MTProto;
|
|||
|
||||
namespace TLSharp.Core.Requests
|
||||
{
|
||||
class GetHistoryRequest : MTProtoRequest
|
||||
{
|
||||
InputPeer _peer;
|
||||
int _offset;
|
||||
int _max_id;
|
||||
int _limit;
|
||||
class GetHistoryRequest : MTProtoRequest
|
||||
{
|
||||
InputPeer _peer;
|
||||
int _offset;
|
||||
int _max_id;
|
||||
int _limit;
|
||||
|
||||
public List<Message> messages;
|
||||
public List<Chat> chats;
|
||||
public List<User> users;
|
||||
public List<Message> messages;
|
||||
public List<Chat> chats;
|
||||
public List<User> users;
|
||||
|
||||
public GetHistoryRequest(InputPeer peer, int offset, int max_id, int limit)
|
||||
{
|
||||
_peer = peer;
|
||||
_offset = offset;
|
||||
_max_id = max_id;
|
||||
_limit = limit;
|
||||
}
|
||||
|
||||
public override void OnSend(BinaryWriter writer)
|
||||
{
|
||||
writer.Write(0x92a1df2f);
|
||||
_peer.Write(writer);
|
||||
writer.Write(_offset);
|
||||
writer.Write(_max_id);
|
||||
writer.Write(_limit);
|
||||
}
|
||||
|
||||
public override void OnResponse(BinaryReader reader)
|
||||
{
|
||||
bool messagesSlice = reader.ReadUInt32() == 0xb446ae3; // else messages#8c718e87
|
||||
public GetHistoryRequest(InputPeer peer, int offset, int max_id, int limit)
|
||||
{
|
||||
_peer = peer;
|
||||
_offset = offset;
|
||||
_max_id = max_id;
|
||||
_limit = limit;
|
||||
}
|
||||
|
||||
if (messagesSlice) reader.ReadInt32(); // count
|
||||
public override void OnSend(BinaryWriter writer)
|
||||
{
|
||||
writer.Write(0x92a1df2f);
|
||||
_peer.Write(writer);
|
||||
writer.Write(_offset);
|
||||
writer.Write(_max_id);
|
||||
writer.Write(_limit);
|
||||
}
|
||||
|
||||
// messages
|
||||
var result = reader.ReadUInt32(); // vector#1cb5c415
|
||||
int messages_len = reader.ReadInt32();
|
||||
messages = new List<Message>(messages_len);
|
||||
for (int i = 0; i < messages_len; i++)
|
||||
messages.Add(TL.Parse<Message>(reader));
|
||||
public override void OnResponse(BinaryReader reader)
|
||||
{
|
||||
bool messagesSlice = reader.ReadUInt32() == 0xb446ae3; // else messages#8c718e87
|
||||
|
||||
// chats
|
||||
reader.ReadUInt32();
|
||||
int chats_len = reader.ReadInt32();
|
||||
chats = new List<Chat>(chats_len);
|
||||
for (int i = 0; i < chats_len; i++)
|
||||
chats.Add(TL.Parse<Chat>(reader));
|
||||
if (messagesSlice) reader.ReadInt32(); // count
|
||||
|
||||
// users
|
||||
reader.ReadUInt32();
|
||||
int users_len = reader.ReadInt32();
|
||||
users = new List<User>(users_len);
|
||||
for (int i = 0; i < users_len; i++)
|
||||
users.Add(TL.Parse<User>(reader));
|
||||
}
|
||||
// messages
|
||||
var result = reader.ReadUInt32(); // vector#1cb5c415
|
||||
int messages_len = reader.ReadInt32();
|
||||
messages = new List<Message>(messages_len);
|
||||
for (var i = 0; i < messages_len; i++)
|
||||
{
|
||||
var msgEl = TL.Parse<Message>(reader);
|
||||
|
||||
public override void OnException(Exception exception)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
messages.Add(msgEl);
|
||||
}
|
||||
|
||||
public override bool Confirmed => true;
|
||||
public override bool Responded { get; }
|
||||
}
|
||||
// chats
|
||||
reader.ReadUInt32();
|
||||
int chats_len = reader.ReadInt32();
|
||||
chats = new List<Chat>(chats_len);
|
||||
for (int i = 0; i < chats_len; i++)
|
||||
chats.Add(TL.Parse<Chat>(reader));
|
||||
|
||||
/*
|
||||
// users
|
||||
reader.ReadUInt32();
|
||||
int users_len = reader.ReadInt32();
|
||||
users = new List<User>(users_len);
|
||||
for (int i = 0; i < users_len; i++)
|
||||
users.Add(TL.Parse<User>(reader));
|
||||
*/
|
||||
}
|
||||
|
||||
public override void OnException(Exception exception)
|
||||
{
|
||||
throw new NotImplementedException();
|
||||
}
|
||||
|
||||
public override bool Confirmed => true;
|
||||
public override bool Responded { get; }
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -34,12 +34,7 @@ namespace TLSharp.Core.Requests
|
|||
|
||||
public override void OnResponse(BinaryReader reader)
|
||||
{
|
||||
var code = reader.ReadUInt32();
|
||||
|
||||
if (code != 0xd07ae726 && code != 0xa9af2881)
|
||||
throw new InvalidOperationException($"Expected Tl messages_StatedMessage type");
|
||||
|
||||
StatedMessage = TL.Parse<messages_StatedMessage>(reader);
|
||||
|
||||
}
|
||||
|
||||
public override void OnException(Exception exception)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue