// 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{} ) // MessagesSendEncryptedServiceRequest represents TL type `messages.sendEncryptedService#32d439a4`. // Sends a service message to a secret chat. // // See https://core.telegram.org/method/messages.sendEncryptedService for reference. type MessagesSendEncryptedServiceRequest struct { // Secret chat ID Peer InputEncryptedChat // Unique client message ID required to prevent message resending RandomID int64 // TL-serialization of DecryptedMessage¹ type, encrypted with a key generated during // chat initialization // // Links: // 1) https://core.telegram.org/type/DecryptedMessage Data []byte } // MessagesSendEncryptedServiceRequestTypeID is TL type id of MessagesSendEncryptedServiceRequest. const MessagesSendEncryptedServiceRequestTypeID = 0x32d439a4 // Ensuring interfaces in compile-time for MessagesSendEncryptedServiceRequest. var ( _ bin.Encoder = &MessagesSendEncryptedServiceRequest{} _ bin.Decoder = &MessagesSendEncryptedServiceRequest{} _ bin.BareEncoder = &MessagesSendEncryptedServiceRequest{} _ bin.BareDecoder = &MessagesSendEncryptedServiceRequest{} ) func (s *MessagesSendEncryptedServiceRequest) Zero() bool { if s == nil { return true } if !(s.Peer.Zero()) { return false } if !(s.RandomID == 0) { return false } if !(s.Data == nil) { return false } return true } // String implements fmt.Stringer. func (s *MessagesSendEncryptedServiceRequest) String() string { if s == nil { return "MessagesSendEncryptedServiceRequest(nil)" } type Alias MessagesSendEncryptedServiceRequest return fmt.Sprintf("MessagesSendEncryptedServiceRequest%+v", Alias(*s)) } // FillFrom fills MessagesSendEncryptedServiceRequest from given interface. func (s *MessagesSendEncryptedServiceRequest) FillFrom(from interface { GetPeer() (value InputEncryptedChat) GetRandomID() (value int64) GetData() (value []byte) }) { s.Peer = from.GetPeer() s.RandomID = from.GetRandomID() s.Data = from.GetData() } // TypeID returns type id in TL schema. // // See https://core.telegram.org/mtproto/TL-tl#remarks. func (*MessagesSendEncryptedServiceRequest) TypeID() uint32 { return MessagesSendEncryptedServiceRequestTypeID } // TypeName returns name of type in TL schema. func (*MessagesSendEncryptedServiceRequest) TypeName() string { return "messages.sendEncryptedService" } // TypeInfo returns info about TL type. func (s *MessagesSendEncryptedServiceRequest) TypeInfo() tdp.Type { typ := tdp.Type{ Name: "messages.sendEncryptedService", ID: MessagesSendEncryptedServiceRequestTypeID, } if s == nil { typ.Null = true return typ } typ.Fields = []tdp.Field{ { Name: "Peer", SchemaName: "peer", }, { Name: "RandomID", SchemaName: "random_id", }, { Name: "Data", SchemaName: "data", }, } return typ } // Encode implements bin.Encoder. func (s *MessagesSendEncryptedServiceRequest) Encode(b *bin.Buffer) error { if s == nil { return fmt.Errorf("can't encode messages.sendEncryptedService#32d439a4 as nil") } b.PutID(MessagesSendEncryptedServiceRequestTypeID) return s.EncodeBare(b) } // EncodeBare implements bin.BareEncoder. func (s *MessagesSendEncryptedServiceRequest) EncodeBare(b *bin.Buffer) error { if s == nil { return fmt.Errorf("can't encode messages.sendEncryptedService#32d439a4 as nil") } if err := s.Peer.Encode(b); err != nil { return fmt.Errorf("unable to encode messages.sendEncryptedService#32d439a4: field peer: %w", err) } b.PutLong(s.RandomID) b.PutBytes(s.Data) return nil } // Decode implements bin.Decoder. func (s *MessagesSendEncryptedServiceRequest) Decode(b *bin.Buffer) error { if s == nil { return fmt.Errorf("can't decode messages.sendEncryptedService#32d439a4 to nil") } if err := b.ConsumeID(MessagesSendEncryptedServiceRequestTypeID); err != nil { return fmt.Errorf("unable to decode messages.sendEncryptedService#32d439a4: %w", err) } return s.DecodeBare(b) } // DecodeBare implements bin.BareDecoder. func (s *MessagesSendEncryptedServiceRequest) DecodeBare(b *bin.Buffer) error { if s == nil { return fmt.Errorf("can't decode messages.sendEncryptedService#32d439a4 to nil") } { if err := s.Peer.Decode(b); err != nil { return fmt.Errorf("unable to decode messages.sendEncryptedService#32d439a4: field peer: %w", err) } } { value, err := b.Long() if err != nil { return fmt.Errorf("unable to decode messages.sendEncryptedService#32d439a4: field random_id: %w", err) } s.RandomID = value } { value, err := b.Bytes() if err != nil { return fmt.Errorf("unable to decode messages.sendEncryptedService#32d439a4: field data: %w", err) } s.Data = value } return nil } // GetPeer returns value of Peer field. func (s *MessagesSendEncryptedServiceRequest) GetPeer() (value InputEncryptedChat) { if s == nil { return } return s.Peer } // GetRandomID returns value of RandomID field. func (s *MessagesSendEncryptedServiceRequest) GetRandomID() (value int64) { if s == nil { return } return s.RandomID } // GetData returns value of Data field. func (s *MessagesSendEncryptedServiceRequest) GetData() (value []byte) { if s == nil { return } return s.Data } // MessagesSendEncryptedService invokes method messages.sendEncryptedService#32d439a4 returning error if any. // Sends a service message to a secret chat. // // Possible errors: // // 400 CHAT_ID_INVALID: The provided chat id is invalid. // 400 DATA_INVALID: Encrypted data invalid. // 400 ENCRYPTION_DECLINED: The secret chat was declined. // 400 ENCRYPTION_ID_INVALID: The provided secret chat ID is invalid. // 500 MSG_WAIT_FAILED: A waiting call returned an error. // 403 USER_DELETED: You can't send this secret message because the other participant deleted their account. // 403 USER_IS_BLOCKED: You were blocked by this user. // // See https://core.telegram.org/method/messages.sendEncryptedService for reference. func (c *Client) MessagesSendEncryptedService(ctx context.Context, request *MessagesSendEncryptedServiceRequest) (MessagesSentEncryptedMessageClass, error) { var result MessagesSentEncryptedMessageBox if err := c.rpc.Invoke(ctx, request, &result); err != nil { return nil, err } return result.SentEncryptedMessage, nil }