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 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94
use anyhow::Result;
use crate::Client;
pub struct SettingsPartner {
    pub client: Client,
}
impl SettingsPartner {
    #[doc(hidden)]
    pub fn new(client: Client) -> Self {
        SettingsPartner { client }
    }
    /**
    * Returns all New Relic partner settings.
    *
    * This function performs a `GET` to the `/partner_settings/new_relic` endpoint.
    *
    * **This endpoint allows you to retrieve your current New Relic partner settings.**
    *
    * Our partner settings allow you to integrate your SendGrid account with our partners to increase your SendGrid experience and functionality. For more information about our partners, and how you can begin integrating with them, please visit our [Partners documentation](https://sendgrid.com/docs/ui/account-and-settings/partners/).
    *
    * By integrating with New Relic, you can send your SendGrid email statistics to your New Relic Dashboard. If you enable this setting, your stats will be sent to New Relic every 5 minutes. You will need your New Relic License Key to enable this setting. For more information, please see our [SendGrid for New Relic documentation](https://sendgrid.com/docs/ui/analytics-and-reporting/tracking-stats-using-new-relic/).
    *
    * **Parameters:**
    *
    * * `on_behalf_of: &str` -- The license key provided with your New Relic account.
    */
    pub async fn get_partner_settings_new_relic(
        &self,
    ) -> Result<crate::types::PartnerSettingsNewRelic> {
        let url = "/partner_settings/new_relic".to_string();
        self.client.get(&url, None).await
    }
    /**
    * Updates New Relic partner settings.
    *
    * This function performs a `PATCH` to the `/partner_settings/new_relic` endpoint.
    *
    * **This endpoint allows you to update or change your New Relic partner settings.**
    *
    * Our partner settings allow you to integrate your SendGrid account with our partners to increase your SendGrid experience and functionality. For more information about our partners, and how you can begin integrating with them, please visit our [Partners documentation](https://sendgrid.com/docs/ui/account-and-settings/partners/).
    *
    * By integrating with New Relic, you can send your SendGrid email statistics to your New Relic Dashboard. If you enable this setting, your stats will be sent to New Relic every 5 minutes. You will need your New Relic License Key to enable this setting. For more information, please see our [SendGrid for New Relic documentation](https://sendgrid.com/docs/ui/analytics-and-reporting/tracking-stats-using-new-relic/).
    *
    * **Parameters:**
    *
    * * `on_behalf_of: &str` -- The license key provided with your New Relic account.
    */
    pub async fn patch_partner_settings_new_relic(
        &self,
        body: &crate::types::PatchPartnerSettingsNewRelicRequest,
    ) -> Result<crate::types::PartnerSettingsNewRelic> {
        let url = "/partner_settings/new_relic".to_string();
        self.client
            .patch(&url, Some(reqwest::Body::from(serde_json::to_vec(body)?)))
            .await
    }
    /**
    * Returns a list of all partner settings.
    *
    * This function performs a `GET` to the `/partner_settings` endpoint.
    *
    * **This endpoint allows you to retrieve a list of all partner settings that you can enable.**
    *
    * Our partner settings allow you to integrate your SendGrid account with our partners to increase your SendGrid experience and functionality. For more information about our partners, and how you can begin integrating with them, please visit our [Partners documentation](https://sendgrid.com/docs/ui/account-and-settings/partners/).
    *
    * **Parameters:**
    *
    * * `limit: i64` -- The number of settings to return per page.
    * * `offset: i64` -- The paging offset.
    * * `on_behalf_of: &str` -- The license key provided with your New Relic account.
    */
    pub async fn get_partner_settings(
        &self,
        limit: i64,
        offset: i64,
    ) -> Result<crate::types::GetPartnerSettingsResponse> {
        let mut query_args: Vec<(String, String)> = Default::default();
        if limit > 0 {
            query_args.push(("limit".to_string(), limit.to_string()));
        }
        if offset > 0 {
            query_args.push(("offset".to_string(), offset.to_string()));
        }
        let query_ = serde_urlencoded::to_string(&query_args).unwrap();
        let url = format!("/partner_settings?{}", query_);
        self.client.get(&url, None).await
    }
}