// Code generated by gotdgen, DO NOT EDIT.

package tg

import (
	
	
	
	
	

	

	
	
	
	
)

// 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{}
)

// RequirementToContactEmpty represents TL type `requirementToContactEmpty#50a9839`.
// This user can be freely contacted.
//
// See https://core.telegram.org/constructor/requirementToContactEmpty for reference.
type RequirementToContactEmpty struct {
}

// RequirementToContactEmptyTypeID is TL type id of RequirementToContactEmpty.
const RequirementToContactEmptyTypeID = 0x50a9839

// construct implements constructor of RequirementToContactClass.
func ( RequirementToContactEmpty) () RequirementToContactClass { return & }

// Ensuring interfaces in compile-time for RequirementToContactEmpty.
var (
	_ bin.Encoder     = &RequirementToContactEmpty{}
	_ bin.Decoder     = &RequirementToContactEmpty{}
	_ bin.BareEncoder = &RequirementToContactEmpty{}
	_ bin.BareDecoder = &RequirementToContactEmpty{}

	_ RequirementToContactClass = &RequirementToContactEmpty{}
)

func ( *RequirementToContactEmpty) () bool {
	if  == nil {
		return true
	}

	return true
}

// String implements fmt.Stringer.
func ( *RequirementToContactEmpty) () string {
	if  == nil {
		return "RequirementToContactEmpty(nil)"
	}
	type  RequirementToContactEmpty
	return fmt.Sprintf("RequirementToContactEmpty%+v", (*))
}

// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
func (*RequirementToContactEmpty) () uint32 {
	return RequirementToContactEmptyTypeID
}

// TypeName returns name of type in TL schema.
func (*RequirementToContactEmpty) () string {
	return "requirementToContactEmpty"
}

// TypeInfo returns info about TL type.
func ( *RequirementToContactEmpty) () tdp.Type {
	 := tdp.Type{
		Name: "requirementToContactEmpty",
		ID:   RequirementToContactEmptyTypeID,
	}
	if  == nil {
		.Null = true
		return 
	}
	.Fields = []tdp.Field{}
	return 
}

// Encode implements bin.Encoder.
func ( *RequirementToContactEmpty) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode requirementToContactEmpty#50a9839 as nil")
	}
	.PutID(RequirementToContactEmptyTypeID)
	return .EncodeBare()
}

// EncodeBare implements bin.BareEncoder.
func ( *RequirementToContactEmpty) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode requirementToContactEmpty#50a9839 as nil")
	}
	return nil
}

// Decode implements bin.Decoder.
func ( *RequirementToContactEmpty) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode requirementToContactEmpty#50a9839 to nil")
	}
	if  := .ConsumeID(RequirementToContactEmptyTypeID);  != nil {
		return fmt.Errorf("unable to decode requirementToContactEmpty#50a9839: %w", )
	}
	return .DecodeBare()
}

// DecodeBare implements bin.BareDecoder.
func ( *RequirementToContactEmpty) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode requirementToContactEmpty#50a9839 to nil")
	}
	return nil
}

// RequirementToContactPremium represents TL type `requirementToContactPremium#e581e4e9`.
// This user requires us to buy a Premium¹ subscription in order to contact them.
//
// Links:
//  1. https://core.telegram.org/api/premium
//
// See https://core.telegram.org/constructor/requirementToContactPremium for reference.
type RequirementToContactPremium struct {
}

// RequirementToContactPremiumTypeID is TL type id of RequirementToContactPremium.
const RequirementToContactPremiumTypeID = 0xe581e4e9

// construct implements constructor of RequirementToContactClass.
func ( RequirementToContactPremium) () RequirementToContactClass { return & }

// Ensuring interfaces in compile-time for RequirementToContactPremium.
var (
	_ bin.Encoder     = &RequirementToContactPremium{}
	_ bin.Decoder     = &RequirementToContactPremium{}
	_ bin.BareEncoder = &RequirementToContactPremium{}
	_ bin.BareDecoder = &RequirementToContactPremium{}

	_ RequirementToContactClass = &RequirementToContactPremium{}
)

func ( *RequirementToContactPremium) () bool {
	if  == nil {
		return true
	}

	return true
}

// String implements fmt.Stringer.
func ( *RequirementToContactPremium) () string {
	if  == nil {
		return "RequirementToContactPremium(nil)"
	}
	type  RequirementToContactPremium
	return fmt.Sprintf("RequirementToContactPremium%+v", (*))
}

// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
func (*RequirementToContactPremium) () uint32 {
	return RequirementToContactPremiumTypeID
}

// TypeName returns name of type in TL schema.
func (*RequirementToContactPremium) () string {
	return "requirementToContactPremium"
}

// TypeInfo returns info about TL type.
func ( *RequirementToContactPremium) () tdp.Type {
	 := tdp.Type{
		Name: "requirementToContactPremium",
		ID:   RequirementToContactPremiumTypeID,
	}
	if  == nil {
		.Null = true
		return 
	}
	.Fields = []tdp.Field{}
	return 
}

// Encode implements bin.Encoder.
func ( *RequirementToContactPremium) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode requirementToContactPremium#e581e4e9 as nil")
	}
	.PutID(RequirementToContactPremiumTypeID)
	return .EncodeBare()
}

// EncodeBare implements bin.BareEncoder.
func ( *RequirementToContactPremium) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode requirementToContactPremium#e581e4e9 as nil")
	}
	return nil
}

// Decode implements bin.Decoder.
func ( *RequirementToContactPremium) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode requirementToContactPremium#e581e4e9 to nil")
	}
	if  := .ConsumeID(RequirementToContactPremiumTypeID);  != nil {
		return fmt.Errorf("unable to decode requirementToContactPremium#e581e4e9: %w", )
	}
	return .DecodeBare()
}

// DecodeBare implements bin.BareDecoder.
func ( *RequirementToContactPremium) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode requirementToContactPremium#e581e4e9 to nil")
	}
	return nil
}

// RequirementToContactPaidMessages represents TL type `requirementToContactPaidMessages#b4f67e93`.
// This user requires us to pay the specified amount of Telegram Stars¹ to send them a
// message, see here »² for the full flow.
//
// Links:
//  1. https://core.telegram.org/api/stars
//  2. https://core.telegram.org/api/paid-messages
//
// See https://core.telegram.org/constructor/requirementToContactPaidMessages for reference.
type RequirementToContactPaidMessages struct {
	// The required amount of Telegram Stars¹.
	//
	// Links:
	//  1) https://core.telegram.org/api/stars
	StarsAmount int64
}

// RequirementToContactPaidMessagesTypeID is TL type id of RequirementToContactPaidMessages.
const RequirementToContactPaidMessagesTypeID = 0xb4f67e93

// construct implements constructor of RequirementToContactClass.
func ( RequirementToContactPaidMessages) () RequirementToContactClass { return & }

// Ensuring interfaces in compile-time for RequirementToContactPaidMessages.
var (
	_ bin.Encoder     = &RequirementToContactPaidMessages{}
	_ bin.Decoder     = &RequirementToContactPaidMessages{}
	_ bin.BareEncoder = &RequirementToContactPaidMessages{}
	_ bin.BareDecoder = &RequirementToContactPaidMessages{}

	_ RequirementToContactClass = &RequirementToContactPaidMessages{}
)

func ( *RequirementToContactPaidMessages) () bool {
	if  == nil {
		return true
	}
	if !(.StarsAmount == 0) {
		return false
	}

	return true
}

// String implements fmt.Stringer.
func ( *RequirementToContactPaidMessages) () string {
	if  == nil {
		return "RequirementToContactPaidMessages(nil)"
	}
	type  RequirementToContactPaidMessages
	return fmt.Sprintf("RequirementToContactPaidMessages%+v", (*))
}

// FillFrom fills RequirementToContactPaidMessages from given interface.
func ( *RequirementToContactPaidMessages) ( interface {
	() ( int64)
}) {
	.StarsAmount = .()
}

// TypeID returns type id in TL schema.
//
// See https://core.telegram.org/mtproto/TL-tl#remarks.
func (*RequirementToContactPaidMessages) () uint32 {
	return RequirementToContactPaidMessagesTypeID
}

// TypeName returns name of type in TL schema.
func (*RequirementToContactPaidMessages) () string {
	return "requirementToContactPaidMessages"
}

// TypeInfo returns info about TL type.
func ( *RequirementToContactPaidMessages) () tdp.Type {
	 := tdp.Type{
		Name: "requirementToContactPaidMessages",
		ID:   RequirementToContactPaidMessagesTypeID,
	}
	if  == nil {
		.Null = true
		return 
	}
	.Fields = []tdp.Field{
		{
			Name:       "StarsAmount",
			SchemaName: "stars_amount",
		},
	}
	return 
}

// Encode implements bin.Encoder.
func ( *RequirementToContactPaidMessages) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode requirementToContactPaidMessages#b4f67e93 as nil")
	}
	.PutID(RequirementToContactPaidMessagesTypeID)
	return .EncodeBare()
}

// EncodeBare implements bin.BareEncoder.
func ( *RequirementToContactPaidMessages) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't encode requirementToContactPaidMessages#b4f67e93 as nil")
	}
	.PutLong(.StarsAmount)
	return nil
}

// Decode implements bin.Decoder.
func ( *RequirementToContactPaidMessages) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode requirementToContactPaidMessages#b4f67e93 to nil")
	}
	if  := .ConsumeID(RequirementToContactPaidMessagesTypeID);  != nil {
		return fmt.Errorf("unable to decode requirementToContactPaidMessages#b4f67e93: %w", )
	}
	return .DecodeBare()
}

// DecodeBare implements bin.BareDecoder.
func ( *RequirementToContactPaidMessages) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("can't decode requirementToContactPaidMessages#b4f67e93 to nil")
	}
	{
		,  := .Long()
		if  != nil {
			return fmt.Errorf("unable to decode requirementToContactPaidMessages#b4f67e93: field stars_amount: %w", )
		}
		.StarsAmount = 
	}
	return nil
}

// GetStarsAmount returns value of StarsAmount field.
func ( *RequirementToContactPaidMessages) () ( int64) {
	if  == nil {
		return
	}
	return .StarsAmount
}

// RequirementToContactClassName is schema name of RequirementToContactClass.
const RequirementToContactClassName = "RequirementToContact"

// RequirementToContactClass represents RequirementToContact generic type.
//
// See https://core.telegram.org/type/RequirementToContact for reference.
//
// Constructors:
//   - [RequirementToContactEmpty]
//   - [RequirementToContactPremium]
//   - [RequirementToContactPaidMessages]
//
// Example:
//
//	g, err := tg.DecodeRequirementToContact(buf)
//	if err != nil {
//	    panic(err)
//	}
//	switch v := g.(type) {
//	case *tg.RequirementToContactEmpty: // requirementToContactEmpty#50a9839
//	case *tg.RequirementToContactPremium: // requirementToContactPremium#e581e4e9
//	case *tg.RequirementToContactPaidMessages: // requirementToContactPaidMessages#b4f67e93
//	default: panic(v)
//	}
type RequirementToContactClass interface {
	bin.Encoder
	bin.Decoder
	bin.BareEncoder
	bin.BareDecoder
	construct() RequirementToContactClass

	// 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
}

// DecodeRequirementToContact implements binary de-serialization for RequirementToContactClass.
func ( *bin.Buffer) (RequirementToContactClass, error) {
	,  := .PeekID()
	if  != nil {
		return nil, 
	}
	switch  {
	case RequirementToContactEmptyTypeID:
		// Decoding requirementToContactEmpty#50a9839.
		 := RequirementToContactEmpty{}
		if  := .Decode();  != nil {
			return nil, fmt.Errorf("unable to decode RequirementToContactClass: %w", )
		}
		return &, nil
	case RequirementToContactPremiumTypeID:
		// Decoding requirementToContactPremium#e581e4e9.
		 := RequirementToContactPremium{}
		if  := .Decode();  != nil {
			return nil, fmt.Errorf("unable to decode RequirementToContactClass: %w", )
		}
		return &, nil
	case RequirementToContactPaidMessagesTypeID:
		// Decoding requirementToContactPaidMessages#b4f67e93.
		 := RequirementToContactPaidMessages{}
		if  := .Decode();  != nil {
			return nil, fmt.Errorf("unable to decode RequirementToContactClass: %w", )
		}
		return &, nil
	default:
		return nil, fmt.Errorf("unable to decode RequirementToContactClass: %w", bin.NewUnexpectedID())
	}
}

// RequirementToContact boxes the RequirementToContactClass providing a helper.
type RequirementToContactBox struct {
	RequirementToContact RequirementToContactClass
}

// Decode implements bin.Decoder for RequirementToContactBox.
func ( *RequirementToContactBox) ( *bin.Buffer) error {
	if  == nil {
		return fmt.Errorf("unable to decode RequirementToContactBox to nil")
	}
	,  := DecodeRequirementToContact()
	if  != nil {
		return fmt.Errorf("unable to decode boxed value: %w", )
	}
	.RequirementToContact = 
	return nil
}

// Encode implements bin.Encode for RequirementToContactBox.
func ( *RequirementToContactBox) ( *bin.Buffer) error {
	if  == nil || .RequirementToContact == nil {
		return fmt.Errorf("unable to encode RequirementToContactClass as nil")
	}
	return .RequirementToContact.Encode()
}