Files
mautrix-telegram/pkg/gotd/tg/tl_updates_channel_difference_gen.go
T
2025-06-27 20:03:37 -07:00

1290 lines
36 KiB
Go
Generated

// Code generated by gotdgen, DO NOT EDIT.
package tg
import (
"context"
"errors"
"fmt"
"sort"
"strings"
"go.uber.org/multierr"
"go.mau.fi/mautrix-telegram/pkg/gotd/bin"
"go.mau.fi/mautrix-telegram/pkg/gotd/tdjson"
"go.mau.fi/mautrix-telegram/pkg/gotd/tdp"
"go.mau.fi/mautrix-telegram/pkg/gotd/tgerr"
)
// No-op definition for keeping imports.
var (
_ = bin.Buffer{}
_ = context.Background()
_ = fmt.Stringer(nil)
_ = strings.Builder{}
_ = errors.Is
_ = multierr.AppendInto
_ = sort.Ints
_ = tdp.Format
_ = tgerr.Error{}
_ = tdjson.Encoder{}
)
// UpdatesChannelDifferenceEmpty represents TL type `updates.channelDifferenceEmpty#3e11affb`.
// There are no new updates
//
// See https://core.telegram.org/constructor/updates.channelDifferenceEmpty for reference.
type UpdatesChannelDifferenceEmpty struct {
// Flags, see TL conditional fields¹
//
// Links:
// 1) https://core.telegram.org/mtproto/TL-combinators#conditional-fields
Flags bin.Fields
// Whether there are more updates that must be fetched (always false)
Final bool
// The latest PTS¹
//
// Links:
// 1) https://core.telegram.org/api/updates
Pts int
// Clients are supposed to refetch the channel difference after timeout seconds have
// elapsed, if the user is currently viewing the chat, see here »¹ for more info.
//
// Links:
// 1) https://core.telegram.org/api/updates#subscribing-to-updates-of-channels-supergroups
//
// Use SetTimeout and GetTimeout helpers.
Timeout int
}
// UpdatesChannelDifferenceEmptyTypeID is TL type id of UpdatesChannelDifferenceEmpty.
const UpdatesChannelDifferenceEmptyTypeID = 0x3e11affb
// construct implements constructor of UpdatesChannelDifferenceClass.
func (c UpdatesChannelDifferenceEmpty) construct() UpdatesChannelDifferenceClass { return &c }
// Ensuring interfaces in compile-time for UpdatesChannelDifferenceEmpty.
var (
_ bin.Encoder = &UpdatesChannelDifferenceEmpty{}
_ bin.Decoder = &UpdatesChannelDifferenceEmpty{}
_ bin.BareEncoder = &UpdatesChannelDifferenceEmpty{}
_ bin.BareDecoder = &UpdatesChannelDifferenceEmpty{}
_ UpdatesChannelDifferenceClass = &UpdatesChannelDifferenceEmpty{}
)
func (c *UpdatesChannelDifferenceEmpty) Zero() bool {
if c == nil {
return true
}
if !(c.Flags.Zero()) {
return false
}
if !(c.Final == false) {
return false
}
if !(c.Pts == 0) {
return false
}
if !(c.Timeout == 0) {
return false
}
return true
}
// String implements fmt.Stringer.
func (c *UpdatesChannelDifferenceEmpty) String() string {
if c == nil {
return "UpdatesChannelDifferenceEmpty(nil)"
}
type Alias UpdatesChannelDifferenceEmpty
return fmt.Sprintf("UpdatesChannelDifferenceEmpty%+v", Alias(*c))
}
// FillFrom fills UpdatesChannelDifferenceEmpty from given interface.
func (c *UpdatesChannelDifferenceEmpty) FillFrom(from interface {
GetFinal() (value bool)
GetPts() (value int)
GetTimeout() (value int, ok bool)
}) {
c.Final = from.GetFinal()
c.Pts = from.GetPts()
if val, ok := from.GetTimeout(); ok {
c.Timeout = val
}
}
// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
func (*UpdatesChannelDifferenceEmpty) TypeID() uint32 {
return UpdatesChannelDifferenceEmptyTypeID
}
// TypeName returns name of type in TL schema.
func (*UpdatesChannelDifferenceEmpty) TypeName() string {
return "updates.channelDifferenceEmpty"
}
// TypeInfo returns info about TL type.
func (c *UpdatesChannelDifferenceEmpty) TypeInfo() tdp.Type {
typ := tdp.Type{
Name: "updates.channelDifferenceEmpty",
ID: UpdatesChannelDifferenceEmptyTypeID,
}
if c == nil {
typ.Null = true
return typ
}
typ.Fields = []tdp.Field{
{
Name: "Final",
SchemaName: "final",
Null: !c.Flags.Has(0),
},
{
Name: "Pts",
SchemaName: "pts",
},
{
Name: "Timeout",
SchemaName: "timeout",
Null: !c.Flags.Has(1),
},
}
return typ
}
// SetFlags sets flags for non-zero fields.
func (c *UpdatesChannelDifferenceEmpty) SetFlags() {
if !(c.Final == false) {
c.Flags.Set(0)
}
if !(c.Timeout == 0) {
c.Flags.Set(1)
}
}
// Encode implements bin.Encoder.
func (c *UpdatesChannelDifferenceEmpty) Encode(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't encode updates.channelDifferenceEmpty#3e11affb as nil")
}
b.PutID(UpdatesChannelDifferenceEmptyTypeID)
return c.EncodeBare(b)
}
// EncodeBare implements bin.BareEncoder.
func (c *UpdatesChannelDifferenceEmpty) EncodeBare(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't encode updates.channelDifferenceEmpty#3e11affb as nil")
}
c.SetFlags()
if err := c.Flags.Encode(b); err != nil {
return fmt.Errorf("unable to encode updates.channelDifferenceEmpty#3e11affb: field flags: %w", err)
}
b.PutInt(c.Pts)
if c.Flags.Has(1) {
b.PutInt(c.Timeout)
}
return nil
}
// Decode implements bin.Decoder.
func (c *UpdatesChannelDifferenceEmpty) Decode(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't decode updates.channelDifferenceEmpty#3e11affb to nil")
}
if err := b.ConsumeID(UpdatesChannelDifferenceEmptyTypeID); err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceEmpty#3e11affb: %w", err)
}
return c.DecodeBare(b)
}
// DecodeBare implements bin.BareDecoder.
func (c *UpdatesChannelDifferenceEmpty) DecodeBare(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't decode updates.channelDifferenceEmpty#3e11affb to nil")
}
{
if err := c.Flags.Decode(b); err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceEmpty#3e11affb: field flags: %w", err)
}
}
c.Final = c.Flags.Has(0)
{
value, err := b.Int()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceEmpty#3e11affb: field pts: %w", err)
}
c.Pts = value
}
if c.Flags.Has(1) {
value, err := b.Int()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceEmpty#3e11affb: field timeout: %w", err)
}
c.Timeout = value
}
return nil
}
// SetFinal sets value of Final conditional field.
func (c *UpdatesChannelDifferenceEmpty) SetFinal(value bool) {
if value {
c.Flags.Set(0)
c.Final = true
} else {
c.Flags.Unset(0)
c.Final = false
}
}
// GetFinal returns value of Final conditional field.
func (c *UpdatesChannelDifferenceEmpty) GetFinal() (value bool) {
if c == nil {
return
}
return c.Flags.Has(0)
}
// GetPts returns value of Pts field.
func (c *UpdatesChannelDifferenceEmpty) GetPts() (value int) {
if c == nil {
return
}
return c.Pts
}
// SetTimeout sets value of Timeout conditional field.
func (c *UpdatesChannelDifferenceEmpty) SetTimeout(value int) {
c.Flags.Set(1)
c.Timeout = value
}
// GetTimeout returns value of Timeout conditional field and
// boolean which is true if field was set.
func (c *UpdatesChannelDifferenceEmpty) GetTimeout() (value int, ok bool) {
if c == nil {
return
}
if !c.Flags.Has(1) {
return value, false
}
return c.Timeout, true
}
// UpdatesChannelDifferenceTooLong represents TL type `updates.channelDifferenceTooLong#a4bcc6fe`.
// The provided pts + limit < remote pts. Simply, there are too many updates to be
// fetched (more than limit), the client has to resolve the update gap in one of the
// following ways (assuming the existence of a persistent database to locally store
// messages):
// It should be also noted that some messages like live location messages shouldn't be
// deleted.
//
// See https://core.telegram.org/constructor/updates.channelDifferenceTooLong for reference.
type UpdatesChannelDifferenceTooLong struct {
// Flags, see TL conditional fields¹
//
// Links:
// 1) https://core.telegram.org/mtproto/TL-combinators#conditional-fields
Flags bin.Fields
// Whether there are more updates that must be fetched (always false)
Final bool
// Clients are supposed to refetch the channel difference after timeout seconds have
// elapsed
//
// Use SetTimeout and GetTimeout helpers.
Timeout int
// Dialog containing the latest PTS¹ that can be used to reset the channel state
//
// Links:
// 1) https://core.telegram.org/api/updates
Dialog DialogClass
// The latest messages
Messages []MessageClass
// Chats from messages
Chats []ChatClass
// Users from messages
Users []UserClass
}
// UpdatesChannelDifferenceTooLongTypeID is TL type id of UpdatesChannelDifferenceTooLong.
const UpdatesChannelDifferenceTooLongTypeID = 0xa4bcc6fe
// construct implements constructor of UpdatesChannelDifferenceClass.
func (c UpdatesChannelDifferenceTooLong) construct() UpdatesChannelDifferenceClass { return &c }
// Ensuring interfaces in compile-time for UpdatesChannelDifferenceTooLong.
var (
_ bin.Encoder = &UpdatesChannelDifferenceTooLong{}
_ bin.Decoder = &UpdatesChannelDifferenceTooLong{}
_ bin.BareEncoder = &UpdatesChannelDifferenceTooLong{}
_ bin.BareDecoder = &UpdatesChannelDifferenceTooLong{}
_ UpdatesChannelDifferenceClass = &UpdatesChannelDifferenceTooLong{}
)
func (c *UpdatesChannelDifferenceTooLong) Zero() bool {
if c == nil {
return true
}
if !(c.Flags.Zero()) {
return false
}
if !(c.Final == false) {
return false
}
if !(c.Timeout == 0) {
return false
}
if !(c.Dialog == nil) {
return false
}
if !(c.Messages == nil) {
return false
}
if !(c.Chats == nil) {
return false
}
if !(c.Users == nil) {
return false
}
return true
}
// String implements fmt.Stringer.
func (c *UpdatesChannelDifferenceTooLong) String() string {
if c == nil {
return "UpdatesChannelDifferenceTooLong(nil)"
}
type Alias UpdatesChannelDifferenceTooLong
return fmt.Sprintf("UpdatesChannelDifferenceTooLong%+v", Alias(*c))
}
// FillFrom fills UpdatesChannelDifferenceTooLong from given interface.
func (c *UpdatesChannelDifferenceTooLong) FillFrom(from interface {
GetFinal() (value bool)
GetTimeout() (value int, ok bool)
GetDialog() (value DialogClass)
GetMessages() (value []MessageClass)
GetChats() (value []ChatClass)
GetUsers() (value []UserClass)
}) {
c.Final = from.GetFinal()
if val, ok := from.GetTimeout(); ok {
c.Timeout = val
}
c.Dialog = from.GetDialog()
c.Messages = from.GetMessages()
c.Chats = from.GetChats()
c.Users = from.GetUsers()
}
// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
func (*UpdatesChannelDifferenceTooLong) TypeID() uint32 {
return UpdatesChannelDifferenceTooLongTypeID
}
// TypeName returns name of type in TL schema.
func (*UpdatesChannelDifferenceTooLong) TypeName() string {
return "updates.channelDifferenceTooLong"
}
// TypeInfo returns info about TL type.
func (c *UpdatesChannelDifferenceTooLong) TypeInfo() tdp.Type {
typ := tdp.Type{
Name: "updates.channelDifferenceTooLong",
ID: UpdatesChannelDifferenceTooLongTypeID,
}
if c == nil {
typ.Null = true
return typ
}
typ.Fields = []tdp.Field{
{
Name: "Final",
SchemaName: "final",
Null: !c.Flags.Has(0),
},
{
Name: "Timeout",
SchemaName: "timeout",
Null: !c.Flags.Has(1),
},
{
Name: "Dialog",
SchemaName: "dialog",
},
{
Name: "Messages",
SchemaName: "messages",
},
{
Name: "Chats",
SchemaName: "chats",
},
{
Name: "Users",
SchemaName: "users",
},
}
return typ
}
// SetFlags sets flags for non-zero fields.
func (c *UpdatesChannelDifferenceTooLong) SetFlags() {
if !(c.Final == false) {
c.Flags.Set(0)
}
if !(c.Timeout == 0) {
c.Flags.Set(1)
}
}
// Encode implements bin.Encoder.
func (c *UpdatesChannelDifferenceTooLong) Encode(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't encode updates.channelDifferenceTooLong#a4bcc6fe as nil")
}
b.PutID(UpdatesChannelDifferenceTooLongTypeID)
return c.EncodeBare(b)
}
// EncodeBare implements bin.BareEncoder.
func (c *UpdatesChannelDifferenceTooLong) EncodeBare(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't encode updates.channelDifferenceTooLong#a4bcc6fe as nil")
}
c.SetFlags()
if err := c.Flags.Encode(b); err != nil {
return fmt.Errorf("unable to encode updates.channelDifferenceTooLong#a4bcc6fe: field flags: %w", err)
}
if c.Flags.Has(1) {
b.PutInt(c.Timeout)
}
if c.Dialog == nil {
return fmt.Errorf("unable to encode updates.channelDifferenceTooLong#a4bcc6fe: field dialog is nil")
}
if err := c.Dialog.Encode(b); err != nil {
return fmt.Errorf("unable to encode updates.channelDifferenceTooLong#a4bcc6fe: field dialog: %w", err)
}
b.PutVectorHeader(len(c.Messages))
for idx, v := range c.Messages {
if v == nil {
return fmt.Errorf("unable to encode updates.channelDifferenceTooLong#a4bcc6fe: field messages element with index %d is nil", idx)
}
if err := v.Encode(b); err != nil {
return fmt.Errorf("unable to encode updates.channelDifferenceTooLong#a4bcc6fe: field messages element with index %d: %w", idx, err)
}
}
b.PutVectorHeader(len(c.Chats))
for idx, v := range c.Chats {
if v == nil {
return fmt.Errorf("unable to encode updates.channelDifferenceTooLong#a4bcc6fe: field chats element with index %d is nil", idx)
}
if err := v.Encode(b); err != nil {
return fmt.Errorf("unable to encode updates.channelDifferenceTooLong#a4bcc6fe: field chats element with index %d: %w", idx, err)
}
}
b.PutVectorHeader(len(c.Users))
for idx, v := range c.Users {
if v == nil {
return fmt.Errorf("unable to encode updates.channelDifferenceTooLong#a4bcc6fe: field users element with index %d is nil", idx)
}
if err := v.Encode(b); err != nil {
return fmt.Errorf("unable to encode updates.channelDifferenceTooLong#a4bcc6fe: field users element with index %d: %w", idx, err)
}
}
return nil
}
// Decode implements bin.Decoder.
func (c *UpdatesChannelDifferenceTooLong) Decode(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't decode updates.channelDifferenceTooLong#a4bcc6fe to nil")
}
if err := b.ConsumeID(UpdatesChannelDifferenceTooLongTypeID); err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceTooLong#a4bcc6fe: %w", err)
}
return c.DecodeBare(b)
}
// DecodeBare implements bin.BareDecoder.
func (c *UpdatesChannelDifferenceTooLong) DecodeBare(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't decode updates.channelDifferenceTooLong#a4bcc6fe to nil")
}
{
if err := c.Flags.Decode(b); err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceTooLong#a4bcc6fe: field flags: %w", err)
}
}
c.Final = c.Flags.Has(0)
if c.Flags.Has(1) {
value, err := b.Int()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceTooLong#a4bcc6fe: field timeout: %w", err)
}
c.Timeout = value
}
{
value, err := DecodeDialog(b)
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceTooLong#a4bcc6fe: field dialog: %w", err)
}
c.Dialog = value
}
{
headerLen, err := b.VectorHeader()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceTooLong#a4bcc6fe: field messages: %w", err)
}
if headerLen > 0 {
c.Messages = make([]MessageClass, 0, headerLen%bin.PreallocateLimit)
}
for idx := 0; idx < headerLen; idx++ {
value, err := DecodeMessage(b)
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceTooLong#a4bcc6fe: field messages: %w", err)
}
c.Messages = append(c.Messages, value)
}
}
{
headerLen, err := b.VectorHeader()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceTooLong#a4bcc6fe: field chats: %w", err)
}
if headerLen > 0 {
c.Chats = make([]ChatClass, 0, headerLen%bin.PreallocateLimit)
}
for idx := 0; idx < headerLen; idx++ {
value, err := DecodeChat(b)
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceTooLong#a4bcc6fe: field chats: %w", err)
}
c.Chats = append(c.Chats, value)
}
}
{
headerLen, err := b.VectorHeader()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceTooLong#a4bcc6fe: field users: %w", err)
}
if headerLen > 0 {
c.Users = make([]UserClass, 0, headerLen%bin.PreallocateLimit)
}
for idx := 0; idx < headerLen; idx++ {
value, err := DecodeUser(b)
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifferenceTooLong#a4bcc6fe: field users: %w", err)
}
c.Users = append(c.Users, value)
}
}
return nil
}
// SetFinal sets value of Final conditional field.
func (c *UpdatesChannelDifferenceTooLong) SetFinal(value bool) {
if value {
c.Flags.Set(0)
c.Final = true
} else {
c.Flags.Unset(0)
c.Final = false
}
}
// GetFinal returns value of Final conditional field.
func (c *UpdatesChannelDifferenceTooLong) GetFinal() (value bool) {
if c == nil {
return
}
return c.Flags.Has(0)
}
// SetTimeout sets value of Timeout conditional field.
func (c *UpdatesChannelDifferenceTooLong) SetTimeout(value int) {
c.Flags.Set(1)
c.Timeout = value
}
// GetTimeout returns value of Timeout conditional field and
// boolean which is true if field was set.
func (c *UpdatesChannelDifferenceTooLong) GetTimeout() (value int, ok bool) {
if c == nil {
return
}
if !c.Flags.Has(1) {
return value, false
}
return c.Timeout, true
}
// GetDialog returns value of Dialog field.
func (c *UpdatesChannelDifferenceTooLong) GetDialog() (value DialogClass) {
if c == nil {
return
}
return c.Dialog
}
// GetMessages returns value of Messages field.
func (c *UpdatesChannelDifferenceTooLong) GetMessages() (value []MessageClass) {
if c == nil {
return
}
return c.Messages
}
// GetChats returns value of Chats field.
func (c *UpdatesChannelDifferenceTooLong) GetChats() (value []ChatClass) {
if c == nil {
return
}
return c.Chats
}
// GetUsers returns value of Users field.
func (c *UpdatesChannelDifferenceTooLong) GetUsers() (value []UserClass) {
if c == nil {
return
}
return c.Users
}
// MapMessages returns field Messages wrapped in MessageClassArray helper.
func (c *UpdatesChannelDifferenceTooLong) MapMessages() (value MessageClassArray) {
return MessageClassArray(c.Messages)
}
// MapChats returns field Chats wrapped in ChatClassArray helper.
func (c *UpdatesChannelDifferenceTooLong) MapChats() (value ChatClassArray) {
return ChatClassArray(c.Chats)
}
// MapUsers returns field Users wrapped in UserClassArray helper.
func (c *UpdatesChannelDifferenceTooLong) MapUsers() (value UserClassArray) {
return UserClassArray(c.Users)
}
// UpdatesChannelDifference represents TL type `updates.channelDifference#2064674e`.
// The new updates
//
// See https://core.telegram.org/constructor/updates.channelDifference for reference.
type UpdatesChannelDifference struct {
// Flags, see TL conditional fields¹
//
// Links:
// 1) https://core.telegram.org/mtproto/TL-combinators#conditional-fields
Flags bin.Fields
// Whether there are more updates to be fetched using getDifference, starting from the
// provided pts
Final bool
// The PTS¹ from which to start getting updates the next time
//
// Links:
// 1) https://core.telegram.org/api/updates
Pts int
// Clients are supposed to refetch the channel difference after timeout seconds have
// elapsed, if the user is currently viewing the chat, see here »¹ for more info.
//
// Links:
// 1) https://core.telegram.org/api/updates#subscribing-to-updates-of-channels-supergroups
//
// Use SetTimeout and GetTimeout helpers.
Timeout int
// New messages
NewMessages []MessageClass
// Other updates
OtherUpdates []UpdateClass
// Chats
Chats []ChatClass
// Users
Users []UserClass
}
// UpdatesChannelDifferenceTypeID is TL type id of UpdatesChannelDifference.
const UpdatesChannelDifferenceTypeID = 0x2064674e
// construct implements constructor of UpdatesChannelDifferenceClass.
func (c UpdatesChannelDifference) construct() UpdatesChannelDifferenceClass { return &c }
// Ensuring interfaces in compile-time for UpdatesChannelDifference.
var (
_ bin.Encoder = &UpdatesChannelDifference{}
_ bin.Decoder = &UpdatesChannelDifference{}
_ bin.BareEncoder = &UpdatesChannelDifference{}
_ bin.BareDecoder = &UpdatesChannelDifference{}
_ UpdatesChannelDifferenceClass = &UpdatesChannelDifference{}
)
func (c *UpdatesChannelDifference) Zero() bool {
if c == nil {
return true
}
if !(c.Flags.Zero()) {
return false
}
if !(c.Final == false) {
return false
}
if !(c.Pts == 0) {
return false
}
if !(c.Timeout == 0) {
return false
}
if !(c.NewMessages == nil) {
return false
}
if !(c.OtherUpdates == nil) {
return false
}
if !(c.Chats == nil) {
return false
}
if !(c.Users == nil) {
return false
}
return true
}
// String implements fmt.Stringer.
func (c *UpdatesChannelDifference) String() string {
if c == nil {
return "UpdatesChannelDifference(nil)"
}
type Alias UpdatesChannelDifference
return fmt.Sprintf("UpdatesChannelDifference%+v", Alias(*c))
}
// FillFrom fills UpdatesChannelDifference from given interface.
func (c *UpdatesChannelDifference) FillFrom(from interface {
GetFinal() (value bool)
GetPts() (value int)
GetTimeout() (value int, ok bool)
GetNewMessages() (value []MessageClass)
GetOtherUpdates() (value []UpdateClass)
GetChats() (value []ChatClass)
GetUsers() (value []UserClass)
}) {
c.Final = from.GetFinal()
c.Pts = from.GetPts()
if val, ok := from.GetTimeout(); ok {
c.Timeout = val
}
c.NewMessages = from.GetNewMessages()
c.OtherUpdates = from.GetOtherUpdates()
c.Chats = from.GetChats()
c.Users = from.GetUsers()
}
// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
func (*UpdatesChannelDifference) TypeID() uint32 {
return UpdatesChannelDifferenceTypeID
}
// TypeName returns name of type in TL schema.
func (*UpdatesChannelDifference) TypeName() string {
return "updates.channelDifference"
}
// TypeInfo returns info about TL type.
func (c *UpdatesChannelDifference) TypeInfo() tdp.Type {
typ := tdp.Type{
Name: "updates.channelDifference",
ID: UpdatesChannelDifferenceTypeID,
}
if c == nil {
typ.Null = true
return typ
}
typ.Fields = []tdp.Field{
{
Name: "Final",
SchemaName: "final",
Null: !c.Flags.Has(0),
},
{
Name: "Pts",
SchemaName: "pts",
},
{
Name: "Timeout",
SchemaName: "timeout",
Null: !c.Flags.Has(1),
},
{
Name: "NewMessages",
SchemaName: "new_messages",
},
{
Name: "OtherUpdates",
SchemaName: "other_updates",
},
{
Name: "Chats",
SchemaName: "chats",
},
{
Name: "Users",
SchemaName: "users",
},
}
return typ
}
// SetFlags sets flags for non-zero fields.
func (c *UpdatesChannelDifference) SetFlags() {
if !(c.Final == false) {
c.Flags.Set(0)
}
if !(c.Timeout == 0) {
c.Flags.Set(1)
}
}
// Encode implements bin.Encoder.
func (c *UpdatesChannelDifference) Encode(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't encode updates.channelDifference#2064674e as nil")
}
b.PutID(UpdatesChannelDifferenceTypeID)
return c.EncodeBare(b)
}
// EncodeBare implements bin.BareEncoder.
func (c *UpdatesChannelDifference) EncodeBare(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't encode updates.channelDifference#2064674e as nil")
}
c.SetFlags()
if err := c.Flags.Encode(b); err != nil {
return fmt.Errorf("unable to encode updates.channelDifference#2064674e: field flags: %w", err)
}
b.PutInt(c.Pts)
if c.Flags.Has(1) {
b.PutInt(c.Timeout)
}
b.PutVectorHeader(len(c.NewMessages))
for idx, v := range c.NewMessages {
if v == nil {
return fmt.Errorf("unable to encode updates.channelDifference#2064674e: field new_messages element with index %d is nil", idx)
}
if err := v.Encode(b); err != nil {
return fmt.Errorf("unable to encode updates.channelDifference#2064674e: field new_messages element with index %d: %w", idx, err)
}
}
b.PutVectorHeader(len(c.OtherUpdates))
for idx, v := range c.OtherUpdates {
if v == nil {
return fmt.Errorf("unable to encode updates.channelDifference#2064674e: field other_updates element with index %d is nil", idx)
}
if err := v.Encode(b); err != nil {
return fmt.Errorf("unable to encode updates.channelDifference#2064674e: field other_updates element with index %d: %w", idx, err)
}
}
b.PutVectorHeader(len(c.Chats))
for idx, v := range c.Chats {
if v == nil {
return fmt.Errorf("unable to encode updates.channelDifference#2064674e: field chats element with index %d is nil", idx)
}
if err := v.Encode(b); err != nil {
return fmt.Errorf("unable to encode updates.channelDifference#2064674e: field chats element with index %d: %w", idx, err)
}
}
b.PutVectorHeader(len(c.Users))
for idx, v := range c.Users {
if v == nil {
return fmt.Errorf("unable to encode updates.channelDifference#2064674e: field users element with index %d is nil", idx)
}
if err := v.Encode(b); err != nil {
return fmt.Errorf("unable to encode updates.channelDifference#2064674e: field users element with index %d: %w", idx, err)
}
}
return nil
}
// Decode implements bin.Decoder.
func (c *UpdatesChannelDifference) Decode(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't decode updates.channelDifference#2064674e to nil")
}
if err := b.ConsumeID(UpdatesChannelDifferenceTypeID); err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: %w", err)
}
return c.DecodeBare(b)
}
// DecodeBare implements bin.BareDecoder.
func (c *UpdatesChannelDifference) DecodeBare(b *bin.Buffer) error {
if c == nil {
return fmt.Errorf("can't decode updates.channelDifference#2064674e to nil")
}
{
if err := c.Flags.Decode(b); err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: field flags: %w", err)
}
}
c.Final = c.Flags.Has(0)
{
value, err := b.Int()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: field pts: %w", err)
}
c.Pts = value
}
if c.Flags.Has(1) {
value, err := b.Int()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: field timeout: %w", err)
}
c.Timeout = value
}
{
headerLen, err := b.VectorHeader()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: field new_messages: %w", err)
}
if headerLen > 0 {
c.NewMessages = make([]MessageClass, 0, headerLen%bin.PreallocateLimit)
}
for idx := 0; idx < headerLen; idx++ {
value, err := DecodeMessage(b)
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: field new_messages: %w", err)
}
c.NewMessages = append(c.NewMessages, value)
}
}
{
headerLen, err := b.VectorHeader()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: field other_updates: %w", err)
}
if headerLen > 0 {
c.OtherUpdates = make([]UpdateClass, 0, headerLen%bin.PreallocateLimit)
}
for idx := 0; idx < headerLen; idx++ {
value, err := DecodeUpdate(b)
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: field other_updates: %w", err)
}
c.OtherUpdates = append(c.OtherUpdates, value)
}
}
{
headerLen, err := b.VectorHeader()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: field chats: %w", err)
}
if headerLen > 0 {
c.Chats = make([]ChatClass, 0, headerLen%bin.PreallocateLimit)
}
for idx := 0; idx < headerLen; idx++ {
value, err := DecodeChat(b)
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: field chats: %w", err)
}
c.Chats = append(c.Chats, value)
}
}
{
headerLen, err := b.VectorHeader()
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: field users: %w", err)
}
if headerLen > 0 {
c.Users = make([]UserClass, 0, headerLen%bin.PreallocateLimit)
}
for idx := 0; idx < headerLen; idx++ {
value, err := DecodeUser(b)
if err != nil {
return fmt.Errorf("unable to decode updates.channelDifference#2064674e: field users: %w", err)
}
c.Users = append(c.Users, value)
}
}
return nil
}
// SetFinal sets value of Final conditional field.
func (c *UpdatesChannelDifference) SetFinal(value bool) {
if value {
c.Flags.Set(0)
c.Final = true
} else {
c.Flags.Unset(0)
c.Final = false
}
}
// GetFinal returns value of Final conditional field.
func (c *UpdatesChannelDifference) GetFinal() (value bool) {
if c == nil {
return
}
return c.Flags.Has(0)
}
// GetPts returns value of Pts field.
func (c *UpdatesChannelDifference) GetPts() (value int) {
if c == nil {
return
}
return c.Pts
}
// SetTimeout sets value of Timeout conditional field.
func (c *UpdatesChannelDifference) SetTimeout(value int) {
c.Flags.Set(1)
c.Timeout = value
}
// GetTimeout returns value of Timeout conditional field and
// boolean which is true if field was set.
func (c *UpdatesChannelDifference) GetTimeout() (value int, ok bool) {
if c == nil {
return
}
if !c.Flags.Has(1) {
return value, false
}
return c.Timeout, true
}
// GetNewMessages returns value of NewMessages field.
func (c *UpdatesChannelDifference) GetNewMessages() (value []MessageClass) {
if c == nil {
return
}
return c.NewMessages
}
// GetOtherUpdates returns value of OtherUpdates field.
func (c *UpdatesChannelDifference) GetOtherUpdates() (value []UpdateClass) {
if c == nil {
return
}
return c.OtherUpdates
}
// GetChats returns value of Chats field.
func (c *UpdatesChannelDifference) GetChats() (value []ChatClass) {
if c == nil {
return
}
return c.Chats
}
// GetUsers returns value of Users field.
func (c *UpdatesChannelDifference) GetUsers() (value []UserClass) {
if c == nil {
return
}
return c.Users
}
// MapNewMessages returns field NewMessages wrapped in MessageClassArray helper.
func (c *UpdatesChannelDifference) MapNewMessages() (value MessageClassArray) {
return MessageClassArray(c.NewMessages)
}
// MapOtherUpdates returns field OtherUpdates wrapped in UpdateClassArray helper.
func (c *UpdatesChannelDifference) MapOtherUpdates() (value UpdateClassArray) {
return UpdateClassArray(c.OtherUpdates)
}
// MapChats returns field Chats wrapped in ChatClassArray helper.
func (c *UpdatesChannelDifference) MapChats() (value ChatClassArray) {
return ChatClassArray(c.Chats)
}
// MapUsers returns field Users wrapped in UserClassArray helper.
func (c *UpdatesChannelDifference) MapUsers() (value UserClassArray) {
return UserClassArray(c.Users)
}
// UpdatesChannelDifferenceClassName is schema name of UpdatesChannelDifferenceClass.
const UpdatesChannelDifferenceClassName = "updates.ChannelDifference"
// UpdatesChannelDifferenceClass represents updates.ChannelDifference generic type.
//
// See https://core.telegram.org/type/updates.ChannelDifference for reference.
//
// Example:
//
// g, err := tg.DecodeUpdatesChannelDifference(buf)
// if err != nil {
// panic(err)
// }
// switch v := g.(type) {
// case *tg.UpdatesChannelDifferenceEmpty: // updates.channelDifferenceEmpty#3e11affb
// case *tg.UpdatesChannelDifferenceTooLong: // updates.channelDifferenceTooLong#a4bcc6fe
// case *tg.UpdatesChannelDifference: // updates.channelDifference#2064674e
// default: panic(v)
// }
type UpdatesChannelDifferenceClass interface {
bin.Encoder
bin.Decoder
bin.BareEncoder
bin.BareDecoder
construct() UpdatesChannelDifferenceClass
// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
TypeID() uint32
// TypeName returns name of type in TL schema.
TypeName() string
// String implements fmt.Stringer.
String() string
// Zero returns true if current object has a zero value.
Zero() bool
// Whether there are more updates that must be fetched (always false)
GetFinal() (value bool)
// Clients are supposed to refetch the channel difference after timeout seconds have
// elapsed, if the user is currently viewing the chat, see here »¹ for more info.
//
// Links:
// 1) https://core.telegram.org/api/updates#subscribing-to-updates-of-channels-supergroups
GetTimeout() (value int, ok bool)
// AsNotEmpty tries to map UpdatesChannelDifferenceClass to NotEmptyUpdatesChannelDifference.
AsNotEmpty() (NotEmptyUpdatesChannelDifference, bool)
}
// NotEmptyUpdatesChannelDifference represents NotEmpty subset of UpdatesChannelDifferenceClass.
type NotEmptyUpdatesChannelDifference interface {
bin.Encoder
bin.Decoder
bin.BareEncoder
bin.BareDecoder
construct() UpdatesChannelDifferenceClass
// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
TypeID() uint32
// TypeName returns name of type in TL schema.
TypeName() string
// String implements fmt.Stringer.
String() string
// Zero returns true if current object has a zero value.
Zero() bool
// Whether there are more updates that must be fetched (always false)
GetFinal() (value bool)
// Clients are supposed to refetch the channel difference after timeout seconds have
// elapsed
GetTimeout() (value int, ok bool)
// Chats from messages
GetChats() (value []ChatClass)
// Users from messages
GetUsers() (value []UserClass)
}
// AsNotEmpty tries to map UpdatesChannelDifferenceEmpty to NotEmptyUpdatesChannelDifference.
func (c *UpdatesChannelDifferenceEmpty) AsNotEmpty() (NotEmptyUpdatesChannelDifference, bool) {
value, ok := (UpdatesChannelDifferenceClass(c)).(NotEmptyUpdatesChannelDifference)
return value, ok
}
// AsNotEmpty tries to map UpdatesChannelDifferenceTooLong to NotEmptyUpdatesChannelDifference.
func (c *UpdatesChannelDifferenceTooLong) AsNotEmpty() (NotEmptyUpdatesChannelDifference, bool) {
value, ok := (UpdatesChannelDifferenceClass(c)).(NotEmptyUpdatesChannelDifference)
return value, ok
}
// AsNotEmpty tries to map UpdatesChannelDifference to NotEmptyUpdatesChannelDifference.
func (c *UpdatesChannelDifference) AsNotEmpty() (NotEmptyUpdatesChannelDifference, bool) {
value, ok := (UpdatesChannelDifferenceClass(c)).(NotEmptyUpdatesChannelDifference)
return value, ok
}
// DecodeUpdatesChannelDifference implements binary de-serialization for UpdatesChannelDifferenceClass.
func DecodeUpdatesChannelDifference(buf *bin.Buffer) (UpdatesChannelDifferenceClass, error) {
id, err := buf.PeekID()
if err != nil {
return nil, err
}
switch id {
case UpdatesChannelDifferenceEmptyTypeID:
// Decoding updates.channelDifferenceEmpty#3e11affb.
v := UpdatesChannelDifferenceEmpty{}
if err := v.Decode(buf); err != nil {
return nil, fmt.Errorf("unable to decode UpdatesChannelDifferenceClass: %w", err)
}
return &v, nil
case UpdatesChannelDifferenceTooLongTypeID:
// Decoding updates.channelDifferenceTooLong#a4bcc6fe.
v := UpdatesChannelDifferenceTooLong{}
if err := v.Decode(buf); err != nil {
return nil, fmt.Errorf("unable to decode UpdatesChannelDifferenceClass: %w", err)
}
return &v, nil
case UpdatesChannelDifferenceTypeID:
// Decoding updates.channelDifference#2064674e.
v := UpdatesChannelDifference{}
if err := v.Decode(buf); err != nil {
return nil, fmt.Errorf("unable to decode UpdatesChannelDifferenceClass: %w", err)
}
return &v, nil
default:
return nil, fmt.Errorf("unable to decode UpdatesChannelDifferenceClass: %w", bin.NewUnexpectedID(id))
}
}
// UpdatesChannelDifference boxes the UpdatesChannelDifferenceClass providing a helper.
type UpdatesChannelDifferenceBox struct {
ChannelDifference UpdatesChannelDifferenceClass
}
// Decode implements bin.Decoder for UpdatesChannelDifferenceBox.
func (b *UpdatesChannelDifferenceBox) Decode(buf *bin.Buffer) error {
if b == nil {
return fmt.Errorf("unable to decode UpdatesChannelDifferenceBox to nil")
}
v, err := DecodeUpdatesChannelDifference(buf)
if err != nil {
return fmt.Errorf("unable to decode boxed value: %w", err)
}
b.ChannelDifference = v
return nil
}
// Encode implements bin.Encode for UpdatesChannelDifferenceBox.
func (b *UpdatesChannelDifferenceBox) Encode(buf *bin.Buffer) error {
if b == nil || b.ChannelDifference == nil {
return fmt.Errorf("unable to encode UpdatesChannelDifferenceClass as nil")
}
return b.ChannelDifference.Encode(buf)
}