1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
//! Generated by `codegen_payloads`, do not edit by hand.

use serde::Serialize;
use url::Url;

use crate::types::{AllowedUpdate, InputFile, True};

impl_payload! {
    @[multipart = certificate]
    /// Use this method to specify a url and receive incoming updates via an outgoing webhook. Whenever there is an update for the bot, we will send an HTTPS POST request to the specified url, containing a JSON-serialized [`Update`]. In case of an unsuccessful request, we will give up after a reasonable amount of attempts. Returns True on success.
    ///
    /// If you'd like to make sure that the Webhook request comes from Telegram, we recommend using a secret path in the URL, e.g. `https://www.example.com/<token>`. Since nobody else knows your bot's token, you can be pretty sure it's us.
    ///
    /// [`Update`]: crate::types::Update
    #[derive(Debug, Clone, Serialize)]
    pub SetWebhook (SetWebhookSetters) => True {
        required {
            /// HTTPS url to send updates to. Use an empty string to remove webhook integration
            pub url: Url,
        }
        optional {
            /// Upload your public key certificate so that the root certificate in use can be checked. See our [self-signed guide] for details.
            ///
            /// [self-signed guide]: https://core.telegram.org/bots/self-signed
            pub certificate: InputFile,
            /// The fixed IP address which will be used to send webhook requests instead of the IP address resolved through DNS
            pub ip_address: String [into],
            /// Maximum allowed number of simultaneous HTTPS connections to the webhook for update delivery, 1-100. Defaults to 40. Use lower values to limit the load on your bot's server, and higher values to increase your bot's throughput.
            pub max_connections: u8,
            /// A JSON-serialized list of the update types you want your bot to receive. For example, specify [“message”, “edited_channel_post”, “callback_query”] to only receive updates of these types. See [`Update`] for a complete list of available update types. Specify an empty list to receive all updates regardless of type (default). If not specified, the previous setting will be used.
            ///
            /// Please note that this parameter doesn't affect updates created before the call to the setWebhook, so unwanted updates may be received for a short period of time.
            ///
            /// [`Update`]: crate::types::Update
            pub allowed_updates: Vec<AllowedUpdate> [collect],
            /// Pass _True_ to drop all pending updates
            pub drop_pending_updates: bool,
            /// A secret token to be sent in a header “X-Telegram-Bot-Api-Secret-Token” in every webhook request, 1-256 characters. Only characters `A-Z`, `a-z`, `0-9`, `_` and `-` are allowed. The header is useful to ensure that the request comes from a webhook set by you.
            pub secret_token: String [into],
        }
    }
}