You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

496 lines
10 KiB

// Code generated by gotdgen, DO NOT EDIT.
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"
)
// 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{}
)
// Page represents TL type `page#98657f0d`.
// Instant view¹ page
//
// Links:
// 1) https://instantview.telegram.org
//
// See https://core.telegram.org/constructor/page for reference.
type Page struct {
// Flags, see TL conditional fields¹
//
// Links:
// 1) https://core.telegram.org/mtproto/TL-combinators#conditional-fields
Flags bin.Fields
// Indicates that not full page preview is available to the client and it will need to
// fetch full Instant View from the server using messages.getWebPagePreview¹.
//
// Links:
// 1) https://core.telegram.org/method/messages.getWebPagePreview
Part bool
// Whether the page contains RTL text
Rtl bool
// Whether this is an IV v2¹ page
//
// Links:
// 1) https://instantview.telegram.org/docs#what-39s-new-in-2-0
V2 bool
// Original page HTTP URL
URL string
// Page elements (like with HTML elements, only as TL constructors)
Blocks []PageBlockClass
// Photos in page
Photos []PhotoClass
// Media in page
Documents []DocumentClass
// Viewcount
//
// Use SetViews and GetViews helpers.
Views int
}
// PageTypeID is TL type id of Page.
const PageTypeID = 0x98657f0d
// Ensuring interfaces in compile-time for Page.
var (
_ bin.Encoder = &Page{}
_ bin.Decoder = &Page{}
_ bin.BareEncoder = &Page{}
_ bin.BareDecoder = &Page{}
)
func (p *Page) Zero() bool {
if p == nil {
return true
}
if !(p.Flags.Zero()) {
return false
}
if !(p.Part == false) {
return false
}
if !(p.Rtl == false) {
return false
}
if !(p.V2 == false) {
return false
}
if !(p.URL == "") {
return false
}
if !(p.Blocks == nil) {
return false
}
if !(p.Photos == nil) {
return false
}
if !(p.Documents == nil) {
return false
}
if !(p.Views == 0) {
return false
}
return true
}
// String implements fmt.Stringer.
func (p *Page) String() string {
if p == nil {
return "Page(nil)"
}
type Alias Page
return fmt.Sprintf("Page%+v", Alias(*p))
}
// FillFrom fills Page from given interface.
func (p *Page) FillFrom(from interface {
GetPart() (value bool)
GetRtl() (value bool)
GetV2() (value bool)
GetURL() (value string)
GetBlocks() (value []PageBlockClass)
GetPhotos() (value []PhotoClass)
GetDocuments() (value []DocumentClass)
GetViews() (value int, ok bool)
}) {
p.Part = from.GetPart()
p.Rtl = from.GetRtl()
p.V2 = from.GetV2()
p.URL = from.GetURL()
p.Blocks = from.GetBlocks()
p.Photos = from.GetPhotos()
p.Documents = from.GetDocuments()
if val, ok := from.GetViews(); ok {
p.Views = val
}
}
// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
func (*Page) TypeID() uint32 {
return PageTypeID
}
// TypeName returns name of type in TL schema.
func (*Page) TypeName() string {
return "page"
}
// TypeInfo returns info about TL type.
func (p *Page) TypeInfo() tdp.Type {
typ := tdp.Type{
Name: "page",
ID: PageTypeID,
}
if p == nil {
typ.Null = true
return typ
}
typ.Fields = []tdp.Field{
{
Name: "Part",
SchemaName: "part",
Null: !p.Flags.Has(0),
},
{
Name: "Rtl",
SchemaName: "rtl",
Null: !p.Flags.Has(1),
},
{
Name: "V2",
SchemaName: "v2",
Null: !p.Flags.Has(2),
},
{
Name: "URL",
SchemaName: "url",
},
{
Name: "Blocks",
SchemaName: "blocks",
},
{
Name: "Photos",
SchemaName: "photos",
},
{
Name: "Documents",
SchemaName: "documents",
},
{
Name: "Views",
SchemaName: "views",
Null: !p.Flags.Has(3),
},
}
return typ
}
// SetFlags sets flags for non-zero fields.
func (p *Page) SetFlags() {
if !(p.Part == false) {
p.Flags.Set(0)
}
if !(p.Rtl == false) {
p.Flags.Set(1)
}
if !(p.V2 == false) {
p.Flags.Set(2)
}
if !(p.Views == 0) {
p.Flags.Set(3)
}
}
// Encode implements bin.Encoder.
func (p *Page) Encode(b *bin.Buffer) error {
if p == nil {
return fmt.Errorf("can't encode page#98657f0d as nil")
}
b.PutID(PageTypeID)
return p.EncodeBare(b)
}
// EncodeBare implements bin.BareEncoder.
func (p *Page) EncodeBare(b *bin.Buffer) error {
if p == nil {
return fmt.Errorf("can't encode page#98657f0d as nil")
}
p.SetFlags()
if err := p.Flags.Encode(b); err != nil {
return fmt.Errorf("unable to encode page#98657f0d: field flags: %w", err)
}
b.PutString(p.URL)
b.PutVectorHeader(len(p.Blocks))
for idx, v := range p.Blocks {
if v == nil {
return fmt.Errorf("unable to encode page#98657f0d: field blocks element with index %d is nil", idx)
}
if err := v.Encode(b); err != nil {
return fmt.Errorf("unable to encode page#98657f0d: field blocks element with index %d: %w", idx, err)
}
}
b.PutVectorHeader(len(p.Photos))
for idx, v := range p.Photos {
if v == nil {
return fmt.Errorf("unable to encode page#98657f0d: field photos element with index %d is nil", idx)
}
if err := v.Encode(b); err != nil {
return fmt.Errorf("unable to encode page#98657f0d: field photos element with index %d: %w", idx, err)
}
}
b.PutVectorHeader(len(p.Documents))
for idx, v := range p.Documents {
if v == nil {
return fmt.Errorf("unable to encode page#98657f0d: field documents element with index %d is nil", idx)
}
if err := v.Encode(b); err != nil {
return fmt.Errorf("unable to encode page#98657f0d: field documents element with index %d: %w", idx, err)
}
}
if p.Flags.Has(3) {
b.PutInt(p.Views)
}
return nil
}
// Decode implements bin.Decoder.
func (p *Page) Decode(b *bin.Buffer) error {
if p == nil {
return fmt.Errorf("can't decode page#98657f0d to nil")
}
if err := b.ConsumeID(PageTypeID); err != nil {
return fmt.Errorf("unable to decode page#98657f0d: %w", err)
}
return p.DecodeBare(b)
}
// DecodeBare implements bin.BareDecoder.
func (p *Page) DecodeBare(b *bin.Buffer) error {
if p == nil {
return fmt.Errorf("can't decode page#98657f0d to nil")
}
{
if err := p.Flags.Decode(b); err != nil {
return fmt.Errorf("unable to decode page#98657f0d: field flags: %w", err)
}
}
p.Part = p.Flags.Has(0)
p.Rtl = p.Flags.Has(1)
p.V2 = p.Flags.Has(2)
{
value, err := b.String()
if err != nil {
return fmt.Errorf("unable to decode page#98657f0d: field url: %w", err)
}
p.URL = value
}
{
headerLen, err := b.VectorHeader()
if err != nil {
return fmt.Errorf("unable to decode page#98657f0d: field blocks: %w", err)
}
if headerLen > 0 {
p.Blocks = make([]PageBlockClass, 0, headerLen%bin.PreallocateLimit)
}
for idx := 0; idx < headerLen; idx++ {
value, err := DecodePageBlock(b)
if err != nil {
return fmt.Errorf("unable to decode page#98657f0d: field blocks: %w", err)
}
p.Blocks = append(p.Blocks, value)
}
}
{
headerLen, err := b.VectorHeader()
if err != nil {
return fmt.Errorf("unable to decode page#98657f0d: field photos: %w", err)
}
if headerLen > 0 {
p.Photos = make([]PhotoClass, 0, headerLen%bin.PreallocateLimit)
}
for idx := 0; idx < headerLen; idx++ {
value, err := DecodePhoto(b)
if err != nil {
return fmt.Errorf("unable to decode page#98657f0d: field photos: %w", err)
}
p.Photos = append(p.Photos, value)
}
}
{
headerLen, err := b.VectorHeader()
if err != nil {
return fmt.Errorf("unable to decode page#98657f0d: field documents: %w", err)
}
if headerLen > 0 {
p.Documents = make([]DocumentClass, 0, headerLen%bin.PreallocateLimit)
}
for idx := 0; idx < headerLen; idx++ {
value, err := DecodeDocument(b)
if err != nil {
return fmt.Errorf("unable to decode page#98657f0d: field documents: %w", err)
}
p.Documents = append(p.Documents, value)
}
}
if p.Flags.Has(3) {
value, err := b.Int()
if err != nil {
return fmt.Errorf("unable to decode page#98657f0d: field views: %w", err)
}
p.Views = value
}
return nil
}
// SetPart sets value of Part conditional field.
func (p *Page) SetPart(value bool) {
if value {
p.Flags.Set(0)
p.Part = true
} else {
p.Flags.Unset(0)
p.Part = false
}
}
// GetPart returns value of Part conditional field.
func (p *Page) GetPart() (value bool) {
if p == nil {
return
}
return p.Flags.Has(0)
}
// SetRtl sets value of Rtl conditional field.
func (p *Page) SetRtl(value bool) {
if value {
p.Flags.Set(1)
p.Rtl = true
} else {
p.Flags.Unset(1)
p.Rtl = false
}
}
// GetRtl returns value of Rtl conditional field.
func (p *Page) GetRtl() (value bool) {
if p == nil {
return
}
return p.Flags.Has(1)
}
// SetV2 sets value of V2 conditional field.
func (p *Page) SetV2(value bool) {
if value {
p.Flags.Set(2)
p.V2 = true
} else {
p.Flags.Unset(2)
p.V2 = false
}
}
// GetV2 returns value of V2 conditional field.
func (p *Page) GetV2() (value bool) {
if p == nil {
return
}
return p.Flags.Has(2)
}
// GetURL returns value of URL field.
func (p *Page) GetURL() (value string) {
if p == nil {
return
}
return p.URL
}
// GetBlocks returns value of Blocks field.
func (p *Page) GetBlocks() (value []PageBlockClass) {
if p == nil {
return
}
return p.Blocks
}
// GetPhotos returns value of Photos field.
func (p *Page) GetPhotos() (value []PhotoClass) {
if p == nil {
return
}
return p.Photos
}
// GetDocuments returns value of Documents field.
func (p *Page) GetDocuments() (value []DocumentClass) {
if p == nil {
return
}
return p.Documents
}
// SetViews sets value of Views conditional field.
func (p *Page) SetViews(value int) {
p.Flags.Set(3)
p.Views = value
}
// GetViews returns value of Views conditional field and
// boolean which is true if field was set.
func (p *Page) GetViews() (value int, ok bool) {
if p == nil {
return
}
if !p.Flags.Has(3) {
return value, false
}
return p.Views, true
}
// MapBlocks returns field Blocks wrapped in PageBlockClassArray helper.
func (p *Page) MapBlocks() (value PageBlockClassArray) {
return PageBlockClassArray(p.Blocks)
}
// MapPhotos returns field Photos wrapped in PhotoClassArray helper.
func (p *Page) MapPhotos() (value PhotoClassArray) {
return PhotoClassArray(p.Photos)
}
// MapDocuments returns field Documents wrapped in DocumentClassArray helper.
func (p *Page) MapDocuments() (value DocumentClassArray) {
return DocumentClassArray(p.Documents)
}