7a04f298d2
- update to latest telegram layer - remove some references to fields in tg.Entities that don't exist in the schema - originally added here: https://github.com/beeper/td/commit/820929062a2ba0104397bc01235ab58a9cff780e - referenced here - https://github.com/mautrix/telegramgo/commit/124f0967ed195b5a380c9bd02e170ada9710dde3 - https://github.com/mautrix/telegramgo/commit/4205047aab2e0639217148b5d125bfaab668bd8e
383 lines
9.8 KiB
Go
383 lines
9.8 KiB
Go
// 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{}
|
|
)
|
|
|
|
// AuthRequestFirebaseSMSRequest represents TL type `auth.requestFirebaseSms#8e39261e`.
|
|
// Request an SMS code via Firebase.
|
|
//
|
|
// See https://core.telegram.org/method/auth.requestFirebaseSms for reference.
|
|
type AuthRequestFirebaseSMSRequest struct {
|
|
// Flags, see TL conditional fields¹
|
|
//
|
|
// Links:
|
|
// 1) https://core.telegram.org/mtproto/TL-combinators#conditional-fields
|
|
Flags bin.Fields
|
|
// Phone number
|
|
PhoneNumber string
|
|
// Phone code hash returned by auth.sendCode¹
|
|
//
|
|
// Links:
|
|
// 1) https://core.telegram.org/method/auth.sendCode
|
|
PhoneCodeHash string
|
|
// On Android, a JWS object obtained as described in the auth documentation »¹
|
|
//
|
|
// Links:
|
|
// 1) https://core.telegram.org/api/auth
|
|
//
|
|
// Use SetSafetyNetToken and GetSafetyNetToken helpers.
|
|
SafetyNetToken string
|
|
// On Android, an object obtained as described in the auth documentation »¹
|
|
//
|
|
// Links:
|
|
// 1) https://core.telegram.org/api/auth
|
|
//
|
|
// Use SetPlayIntegrityToken and GetPlayIntegrityToken helpers.
|
|
PlayIntegrityToken string
|
|
// Secret token received via an apple push notification
|
|
//
|
|
// Use SetIosPushSecret and GetIosPushSecret helpers.
|
|
IosPushSecret string
|
|
}
|
|
|
|
// AuthRequestFirebaseSMSRequestTypeID is TL type id of AuthRequestFirebaseSMSRequest.
|
|
const AuthRequestFirebaseSMSRequestTypeID = 0x8e39261e
|
|
|
|
// Ensuring interfaces in compile-time for AuthRequestFirebaseSMSRequest.
|
|
var (
|
|
_ bin.Encoder = &AuthRequestFirebaseSMSRequest{}
|
|
_ bin.Decoder = &AuthRequestFirebaseSMSRequest{}
|
|
_ bin.BareEncoder = &AuthRequestFirebaseSMSRequest{}
|
|
_ bin.BareDecoder = &AuthRequestFirebaseSMSRequest{}
|
|
)
|
|
|
|
func (r *AuthRequestFirebaseSMSRequest) Zero() bool {
|
|
if r == nil {
|
|
return true
|
|
}
|
|
if !(r.Flags.Zero()) {
|
|
return false
|
|
}
|
|
if !(r.PhoneNumber == "") {
|
|
return false
|
|
}
|
|
if !(r.PhoneCodeHash == "") {
|
|
return false
|
|
}
|
|
if !(r.SafetyNetToken == "") {
|
|
return false
|
|
}
|
|
if !(r.PlayIntegrityToken == "") {
|
|
return false
|
|
}
|
|
if !(r.IosPushSecret == "") {
|
|
return false
|
|
}
|
|
|
|
return true
|
|
}
|
|
|
|
// String implements fmt.Stringer.
|
|
func (r *AuthRequestFirebaseSMSRequest) String() string {
|
|
if r == nil {
|
|
return "AuthRequestFirebaseSMSRequest(nil)"
|
|
}
|
|
type Alias AuthRequestFirebaseSMSRequest
|
|
return fmt.Sprintf("AuthRequestFirebaseSMSRequest%+v", Alias(*r))
|
|
}
|
|
|
|
// FillFrom fills AuthRequestFirebaseSMSRequest from given interface.
|
|
func (r *AuthRequestFirebaseSMSRequest) FillFrom(from interface {
|
|
GetPhoneNumber() (value string)
|
|
GetPhoneCodeHash() (value string)
|
|
GetSafetyNetToken() (value string, ok bool)
|
|
GetPlayIntegrityToken() (value string, ok bool)
|
|
GetIosPushSecret() (value string, ok bool)
|
|
}) {
|
|
r.PhoneNumber = from.GetPhoneNumber()
|
|
r.PhoneCodeHash = from.GetPhoneCodeHash()
|
|
if val, ok := from.GetSafetyNetToken(); ok {
|
|
r.SafetyNetToken = val
|
|
}
|
|
|
|
if val, ok := from.GetPlayIntegrityToken(); ok {
|
|
r.PlayIntegrityToken = val
|
|
}
|
|
|
|
if val, ok := from.GetIosPushSecret(); ok {
|
|
r.IosPushSecret = val
|
|
}
|
|
|
|
}
|
|
|
|
// TypeID returns type id in TL schema.
|
|
//
|
|
// See https://core.telegram.org/mtproto/TL-tl#remarks.
|
|
func (*AuthRequestFirebaseSMSRequest) TypeID() uint32 {
|
|
return AuthRequestFirebaseSMSRequestTypeID
|
|
}
|
|
|
|
// TypeName returns name of type in TL schema.
|
|
func (*AuthRequestFirebaseSMSRequest) TypeName() string {
|
|
return "auth.requestFirebaseSms"
|
|
}
|
|
|
|
// TypeInfo returns info about TL type.
|
|
func (r *AuthRequestFirebaseSMSRequest) TypeInfo() tdp.Type {
|
|
typ := tdp.Type{
|
|
Name: "auth.requestFirebaseSms",
|
|
ID: AuthRequestFirebaseSMSRequestTypeID,
|
|
}
|
|
if r == nil {
|
|
typ.Null = true
|
|
return typ
|
|
}
|
|
typ.Fields = []tdp.Field{
|
|
{
|
|
Name: "PhoneNumber",
|
|
SchemaName: "phone_number",
|
|
},
|
|
{
|
|
Name: "PhoneCodeHash",
|
|
SchemaName: "phone_code_hash",
|
|
},
|
|
{
|
|
Name: "SafetyNetToken",
|
|
SchemaName: "safety_net_token",
|
|
Null: !r.Flags.Has(0),
|
|
},
|
|
{
|
|
Name: "PlayIntegrityToken",
|
|
SchemaName: "play_integrity_token",
|
|
Null: !r.Flags.Has(2),
|
|
},
|
|
{
|
|
Name: "IosPushSecret",
|
|
SchemaName: "ios_push_secret",
|
|
Null: !r.Flags.Has(1),
|
|
},
|
|
}
|
|
return typ
|
|
}
|
|
|
|
// SetFlags sets flags for non-zero fields.
|
|
func (r *AuthRequestFirebaseSMSRequest) SetFlags() {
|
|
if !(r.SafetyNetToken == "") {
|
|
r.Flags.Set(0)
|
|
}
|
|
if !(r.PlayIntegrityToken == "") {
|
|
r.Flags.Set(2)
|
|
}
|
|
if !(r.IosPushSecret == "") {
|
|
r.Flags.Set(1)
|
|
}
|
|
}
|
|
|
|
// Encode implements bin.Encoder.
|
|
func (r *AuthRequestFirebaseSMSRequest) Encode(b *bin.Buffer) error {
|
|
if r == nil {
|
|
return fmt.Errorf("can't encode auth.requestFirebaseSms#8e39261e as nil")
|
|
}
|
|
b.PutID(AuthRequestFirebaseSMSRequestTypeID)
|
|
return r.EncodeBare(b)
|
|
}
|
|
|
|
// EncodeBare implements bin.BareEncoder.
|
|
func (r *AuthRequestFirebaseSMSRequest) EncodeBare(b *bin.Buffer) error {
|
|
if r == nil {
|
|
return fmt.Errorf("can't encode auth.requestFirebaseSms#8e39261e as nil")
|
|
}
|
|
r.SetFlags()
|
|
if err := r.Flags.Encode(b); err != nil {
|
|
return fmt.Errorf("unable to encode auth.requestFirebaseSms#8e39261e: field flags: %w", err)
|
|
}
|
|
b.PutString(r.PhoneNumber)
|
|
b.PutString(r.PhoneCodeHash)
|
|
if r.Flags.Has(0) {
|
|
b.PutString(r.SafetyNetToken)
|
|
}
|
|
if r.Flags.Has(2) {
|
|
b.PutString(r.PlayIntegrityToken)
|
|
}
|
|
if r.Flags.Has(1) {
|
|
b.PutString(r.IosPushSecret)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// Decode implements bin.Decoder.
|
|
func (r *AuthRequestFirebaseSMSRequest) Decode(b *bin.Buffer) error {
|
|
if r == nil {
|
|
return fmt.Errorf("can't decode auth.requestFirebaseSms#8e39261e to nil")
|
|
}
|
|
if err := b.ConsumeID(AuthRequestFirebaseSMSRequestTypeID); err != nil {
|
|
return fmt.Errorf("unable to decode auth.requestFirebaseSms#8e39261e: %w", err)
|
|
}
|
|
return r.DecodeBare(b)
|
|
}
|
|
|
|
// DecodeBare implements bin.BareDecoder.
|
|
func (r *AuthRequestFirebaseSMSRequest) DecodeBare(b *bin.Buffer) error {
|
|
if r == nil {
|
|
return fmt.Errorf("can't decode auth.requestFirebaseSms#8e39261e to nil")
|
|
}
|
|
{
|
|
if err := r.Flags.Decode(b); err != nil {
|
|
return fmt.Errorf("unable to decode auth.requestFirebaseSms#8e39261e: field flags: %w", err)
|
|
}
|
|
}
|
|
{
|
|
value, err := b.String()
|
|
if err != nil {
|
|
return fmt.Errorf("unable to decode auth.requestFirebaseSms#8e39261e: field phone_number: %w", err)
|
|
}
|
|
r.PhoneNumber = value
|
|
}
|
|
{
|
|
value, err := b.String()
|
|
if err != nil {
|
|
return fmt.Errorf("unable to decode auth.requestFirebaseSms#8e39261e: field phone_code_hash: %w", err)
|
|
}
|
|
r.PhoneCodeHash = value
|
|
}
|
|
if r.Flags.Has(0) {
|
|
value, err := b.String()
|
|
if err != nil {
|
|
return fmt.Errorf("unable to decode auth.requestFirebaseSms#8e39261e: field safety_net_token: %w", err)
|
|
}
|
|
r.SafetyNetToken = value
|
|
}
|
|
if r.Flags.Has(2) {
|
|
value, err := b.String()
|
|
if err != nil {
|
|
return fmt.Errorf("unable to decode auth.requestFirebaseSms#8e39261e: field play_integrity_token: %w", err)
|
|
}
|
|
r.PlayIntegrityToken = value
|
|
}
|
|
if r.Flags.Has(1) {
|
|
value, err := b.String()
|
|
if err != nil {
|
|
return fmt.Errorf("unable to decode auth.requestFirebaseSms#8e39261e: field ios_push_secret: %w", err)
|
|
}
|
|
r.IosPushSecret = value
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// GetPhoneNumber returns value of PhoneNumber field.
|
|
func (r *AuthRequestFirebaseSMSRequest) GetPhoneNumber() (value string) {
|
|
if r == nil {
|
|
return
|
|
}
|
|
return r.PhoneNumber
|
|
}
|
|
|
|
// GetPhoneCodeHash returns value of PhoneCodeHash field.
|
|
func (r *AuthRequestFirebaseSMSRequest) GetPhoneCodeHash() (value string) {
|
|
if r == nil {
|
|
return
|
|
}
|
|
return r.PhoneCodeHash
|
|
}
|
|
|
|
// SetSafetyNetToken sets value of SafetyNetToken conditional field.
|
|
func (r *AuthRequestFirebaseSMSRequest) SetSafetyNetToken(value string) {
|
|
r.Flags.Set(0)
|
|
r.SafetyNetToken = value
|
|
}
|
|
|
|
// GetSafetyNetToken returns value of SafetyNetToken conditional field and
|
|
// boolean which is true if field was set.
|
|
func (r *AuthRequestFirebaseSMSRequest) GetSafetyNetToken() (value string, ok bool) {
|
|
if r == nil {
|
|
return
|
|
}
|
|
if !r.Flags.Has(0) {
|
|
return value, false
|
|
}
|
|
return r.SafetyNetToken, true
|
|
}
|
|
|
|
// SetPlayIntegrityToken sets value of PlayIntegrityToken conditional field.
|
|
func (r *AuthRequestFirebaseSMSRequest) SetPlayIntegrityToken(value string) {
|
|
r.Flags.Set(2)
|
|
r.PlayIntegrityToken = value
|
|
}
|
|
|
|
// GetPlayIntegrityToken returns value of PlayIntegrityToken conditional field and
|
|
// boolean which is true if field was set.
|
|
func (r *AuthRequestFirebaseSMSRequest) GetPlayIntegrityToken() (value string, ok bool) {
|
|
if r == nil {
|
|
return
|
|
}
|
|
if !r.Flags.Has(2) {
|
|
return value, false
|
|
}
|
|
return r.PlayIntegrityToken, true
|
|
}
|
|
|
|
// SetIosPushSecret sets value of IosPushSecret conditional field.
|
|
func (r *AuthRequestFirebaseSMSRequest) SetIosPushSecret(value string) {
|
|
r.Flags.Set(1)
|
|
r.IosPushSecret = value
|
|
}
|
|
|
|
// GetIosPushSecret returns value of IosPushSecret conditional field and
|
|
// boolean which is true if field was set.
|
|
func (r *AuthRequestFirebaseSMSRequest) GetIosPushSecret() (value string, ok bool) {
|
|
if r == nil {
|
|
return
|
|
}
|
|
if !r.Flags.Has(1) {
|
|
return value, false
|
|
}
|
|
return r.IosPushSecret, true
|
|
}
|
|
|
|
// AuthRequestFirebaseSMS invokes method auth.requestFirebaseSms#8e39261e returning error if any.
|
|
// Request an SMS code via Firebase.
|
|
//
|
|
// Possible errors:
|
|
//
|
|
// 400 PHONE_CODE_EMPTY: phone_code is missing.
|
|
// 400 PHONE_NUMBER_INVALID: The phone number is invalid.
|
|
//
|
|
// See https://core.telegram.org/method/auth.requestFirebaseSms for reference.
|
|
func (c *Client) AuthRequestFirebaseSMS(ctx context.Context, request *AuthRequestFirebaseSMSRequest) (bool, error) {
|
|
var result BoolBox
|
|
|
|
if err := c.rpc.Invoke(ctx, request, &result); err != nil {
|
|
return false, err
|
|
}
|
|
_, ok := result.Bool.(*BoolTrue)
|
|
return ok, nil
|
|
}
|