package tg
import (
"context"
"errors"
"fmt"
"sort"
"strings"
"go.uber.org/multierr"
"github.com/gotd/td/bin"
"github.com/gotd/td/tdjson"
"github.com/gotd/td/tdp"
"github.com/gotd/td/tgerr"
)
var (
_ = bin .Buffer {}
_ = context .Background ()
_ = fmt .Stringer (nil )
_ = strings .Builder {}
_ = errors .Is
_ = multierr .AppendInto
_ = sort .Ints
_ = tdp .Format
_ = tgerr .Error {}
_ = tdjson .Encoder {}
)
type MessagesReadHistoryRequest struct {
Peer InputPeerClass
MaxID int
}
const MessagesReadHistoryRequestTypeID = 0xe306d3a
var (
_ bin .Encoder = &MessagesReadHistoryRequest {}
_ bin .Decoder = &MessagesReadHistoryRequest {}
_ bin .BareEncoder = &MessagesReadHistoryRequest {}
_ bin .BareDecoder = &MessagesReadHistoryRequest {}
)
func (r *MessagesReadHistoryRequest ) Zero () bool {
if r == nil {
return true
}
if !(r .Peer == nil ) {
return false
}
if !(r .MaxID == 0 ) {
return false
}
return true
}
func (r *MessagesReadHistoryRequest ) String () string {
if r == nil {
return "MessagesReadHistoryRequest(nil)"
}
type Alias MessagesReadHistoryRequest
return fmt .Sprintf ("MessagesReadHistoryRequest%+v" , Alias (*r ))
}
func (r *MessagesReadHistoryRequest ) FillFrom (from interface {
GetPeer () (value InputPeerClass )
GetMaxID () (value int )
}) {
r .Peer = from .GetPeer ()
r .MaxID = from .GetMaxID ()
}
func (*MessagesReadHistoryRequest ) TypeID () uint32 {
return MessagesReadHistoryRequestTypeID
}
func (*MessagesReadHistoryRequest ) TypeName () string {
return "messages.readHistory"
}
func (r *MessagesReadHistoryRequest ) TypeInfo () tdp .Type {
typ := tdp .Type {
Name : "messages.readHistory" ,
ID : MessagesReadHistoryRequestTypeID ,
}
if r == nil {
typ .Null = true
return typ
}
typ .Fields = []tdp .Field {
{
Name : "Peer" ,
SchemaName : "peer" ,
},
{
Name : "MaxID" ,
SchemaName : "max_id" ,
},
}
return typ
}
func (r *MessagesReadHistoryRequest ) Encode (b *bin .Buffer ) error {
if r == nil {
return fmt .Errorf ("can't encode messages.readHistory#e306d3a as nil" )
}
b .PutID (MessagesReadHistoryRequestTypeID )
return r .EncodeBare (b )
}
func (r *MessagesReadHistoryRequest ) EncodeBare (b *bin .Buffer ) error {
if r == nil {
return fmt .Errorf ("can't encode messages.readHistory#e306d3a as nil" )
}
if r .Peer == nil {
return fmt .Errorf ("unable to encode messages.readHistory#e306d3a: field peer is nil" )
}
if err := r .Peer .Encode (b ); err != nil {
return fmt .Errorf ("unable to encode messages.readHistory#e306d3a: field peer: %w" , err )
}
b .PutInt (r .MaxID )
return nil
}
func (r *MessagesReadHistoryRequest ) Decode (b *bin .Buffer ) error {
if r == nil {
return fmt .Errorf ("can't decode messages.readHistory#e306d3a to nil" )
}
if err := b .ConsumeID (MessagesReadHistoryRequestTypeID ); err != nil {
return fmt .Errorf ("unable to decode messages.readHistory#e306d3a: %w" , err )
}
return r .DecodeBare (b )
}
func (r *MessagesReadHistoryRequest ) DecodeBare (b *bin .Buffer ) error {
if r == nil {
return fmt .Errorf ("can't decode messages.readHistory#e306d3a to nil" )
}
{
value , err := DecodeInputPeer (b )
if err != nil {
return fmt .Errorf ("unable to decode messages.readHistory#e306d3a: field peer: %w" , err )
}
r .Peer = value
}
{
value , err := b .Int ()
if err != nil {
return fmt .Errorf ("unable to decode messages.readHistory#e306d3a: field max_id: %w" , err )
}
r .MaxID = value
}
return nil
}
func (r *MessagesReadHistoryRequest ) GetPeer () (value InputPeerClass ) {
if r == nil {
return
}
return r .Peer
}
func (r *MessagesReadHistoryRequest ) GetMaxID () (value int ) {
if r == nil {
return
}
return r .MaxID
}
func (c *Client ) MessagesReadHistory (ctx context .Context , request *MessagesReadHistoryRequest ) (*MessagesAffectedMessages , error ) {
var result MessagesAffectedMessages
if err := c .rpc .Invoke (ctx , request , &result ); err != nil {
return nil , err
}
return &result , nil
}
The pages are generated with Golds v0.6.7 . (GOOS=linux GOARCH=amd64)
Golds is a Go 101 project developed by Tapir Liu .
PR and bug reports are welcome and can be submitted to the issue list .
Please follow @Go100and1 (reachable from the left QR code) to get the latest news of Golds .