make regen-apis

This commit is contained in:
OMGeeky
2023-10-21 23:50:27 +02:00
parent b09392b768
commit ec6083f22f
1959 changed files with 911619 additions and 913545 deletions

View File

@@ -1,547 +1,4 @@
use std::collections::HashMap;
use std::cell::RefCell;
use std::default::Default;
use std::collections::BTreeSet;
use std::error::Error as StdError;
use serde_json as json;
use std::io;
use std::fs;
use std::mem;
use hyper::client::connect;
use tokio::io::{AsyncRead, AsyncWrite};
use tokio::time::sleep;
use tower_service;
use serde::{Serialize, Deserialize};
use crate::{client, client::GetToken, client::serde_with};
// ##############
// UTILITIES ###
// ############
/// Identifies the an OAuth2 authorization scope.
/// A scope is needed when requesting an
/// [authorization token](https://developers.google.com/youtube/v3/guides/authentication).
#[derive(PartialEq, Eq, Hash, Debug)]
pub enum Scope {
/// See and/or control the devices that you selected
SdmService,
}
impl AsRef<str> for Scope {
fn as_ref(&self) -> &str {
match *self {
Scope::SdmService => "https://www.googleapis.com/auth/sdm.service",
}
}
}
impl Default for Scope {
fn default() -> Scope {
Scope::SdmService
}
}
// ########
// HUB ###
// ######
/// Central instance to access all SmartDeviceManagement related resource activities
///
/// # Examples
///
/// Instantiate a new hub
///
/// ```test_harness,no_run
/// extern crate hyper;
/// extern crate hyper_rustls;
/// extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
/// use smartdevicemanagement1::{Result, Error};
/// # async fn dox() {
/// use std::default::Default;
/// use smartdevicemanagement1::{SmartDeviceManagement, oauth2, hyper, hyper_rustls, chrono, FieldMask};
///
/// // Get an ApplicationSecret instance by some means. It contains the `client_id` and
/// // `client_secret`, among other things.
/// let secret: oauth2::ApplicationSecret = Default::default();
/// // Instantiate the authenticator. It will choose a suitable authentication flow for you,
/// // unless you replace `None` with the desired Flow.
/// // Provide your own `AuthenticatorDelegate` to adjust the way it operates and get feedback about
/// // what's going on. You probably want to bring in your own `TokenStorage` to persist tokens and
/// // retrieve them from storage.
/// let auth = oauth2::InstalledFlowAuthenticator::builder(
/// secret,
/// oauth2::InstalledFlowReturnMethod::HTTPRedirect,
/// ).build().await.unwrap();
/// let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().https_or_http().enable_http1().build()), auth);
/// // You can configure optional parameters by calling the respective setters at will, and
/// // execute the final call using `doit()`.
/// // Values shown here are possibly random and not representative !
/// let result = hub.enterprises().devices_get("name")
/// .doit().await;
///
/// match result {
/// Err(e) => match e {
/// // The Error enum provides details about what exactly happened.
/// // You can also just use its `Debug`, `Display` or `Error` traits
/// Error::HttpError(_)
/// |Error::Io(_)
/// |Error::MissingAPIKey
/// |Error::MissingToken(_)
/// |Error::Cancelled
/// |Error::UploadSizeLimitExceeded(_, _)
/// |Error::Failure(_)
/// |Error::BadRequest(_)
/// |Error::FieldClash(_)
/// |Error::JsonDecodeError(_, _) => println!("{}", e),
/// },
/// Ok(res) => println!("Success: {:?}", res),
/// }
/// # }
/// ```
#[derive(Clone)]
pub struct SmartDeviceManagement<S> {
pub client: hyper::Client<S, hyper::body::Body>,
pub auth: Box<dyn client::GetToken>,
_user_agent: String,
_base_url: String,
_root_url: String,
}
impl<'a, S> client::Hub for SmartDeviceManagement<S> {}
impl<'a, S> SmartDeviceManagement<S> {
pub fn new<A: 'static + client::GetToken>(client: hyper::Client<S, hyper::body::Body>, auth: A) -> SmartDeviceManagement<S> {
SmartDeviceManagement {
client,
auth: Box::new(auth),
_user_agent: "google-api-rust-client/5.0.3".to_string(),
_base_url: "https://smartdevicemanagement.googleapis.com/".to_string(),
_root_url: "https://smartdevicemanagement.googleapis.com/".to_string(),
}
}
pub fn enterprises(&'a self) -> EnterpriseMethods<'a, S> {
EnterpriseMethods { hub: &self }
}
/// Set the user-agent header field to use in all requests to the server.
/// It defaults to `google-api-rust-client/5.0.3`.
///
/// Returns the previously set user-agent.
pub fn user_agent(&mut self, agent_name: String) -> String {
mem::replace(&mut self._user_agent, agent_name)
}
/// Set the base url to use in all requests to the server.
/// It defaults to `https://smartdevicemanagement.googleapis.com/`.
///
/// Returns the previously set base url.
pub fn base_url(&mut self, new_base_url: String) -> String {
mem::replace(&mut self._base_url, new_base_url)
}
/// Set the root url to use in all requests to the server.
/// It defaults to `https://smartdevicemanagement.googleapis.com/`.
///
/// Returns the previously set root url.
pub fn root_url(&mut self, new_root_url: String) -> String {
mem::replace(&mut self._root_url, new_root_url)
}
}
// ############
// SCHEMAS ###
// ##########
/// Device resource represents an instance of enterprise managed device in the property.
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [devices get enterprises](EnterpriseDeviceGetCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1Device {
/// Required. The resource name of the device. For example: "enterprises/XYZ/devices/123".
pub name: Option<String>,
/// Assignee details of the device.
#[serde(rename="parentRelations")]
pub parent_relations: Option<Vec<GoogleHomeEnterpriseSdmV1ParentRelation>>,
/// Output only. Device traits.
pub traits: Option<HashMap<String, json::Value>>,
/// Output only. Type of the device for general display purposes. For example: "THERMOSTAT". The device type should not be used to deduce or infer functionality of the actual device it is assigned to. Instead, use the returned traits for the device.
#[serde(rename="type")]
pub type_: Option<String>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1Device {}
/// Request message for SmartDeviceManagementService.ExecuteDeviceCommand
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [devices execute command enterprises](EnterpriseDeviceExecuteCommandCall) (request)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandRequest {
/// The command name to execute, represented by the fully qualified protobuf message name.
pub command: Option<String>,
/// The command message to execute, represented as a Struct.
pub params: Option<HashMap<String, json::Value>>,
}
impl client::RequestValue for GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandRequest {}
/// Response message for SmartDeviceManagementService.ExecuteDeviceCommand
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [devices execute command enterprises](EnterpriseDeviceExecuteCommandCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandResponse {
/// The results of executing the command.
pub results: Option<HashMap<String, json::Value>>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandResponse {}
/// Response message for SmartDeviceManagementService.ListDevices
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [devices list enterprises](EnterpriseDeviceListCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ListDevicesResponse {
/// The list of devices.
pub devices: Option<Vec<GoogleHomeEnterpriseSdmV1Device>>,
/// The pagination token to retrieve the next page of results.
#[serde(rename="nextPageToken")]
pub next_page_token: Option<String>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1ListDevicesResponse {}
/// Response message for SmartDeviceManagementService.ListRooms
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [structures rooms list enterprises](EnterpriseStructureRoomListCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ListRoomsResponse {
/// The pagination token to retrieve the next page of results. If this field is omitted, there are no subsequent pages.
#[serde(rename="nextPageToken")]
pub next_page_token: Option<String>,
/// The list of rooms.
pub rooms: Option<Vec<GoogleHomeEnterpriseSdmV1Room>>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1ListRoomsResponse {}
/// Response message for SmartDeviceManagementService.ListStructures
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [structures list enterprises](EnterpriseStructureListCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ListStructuresResponse {
/// The pagination token to retrieve the next page of results. If this field is omitted, there are no subsequent pages.
#[serde(rename="nextPageToken")]
pub next_page_token: Option<String>,
/// The list of structures.
pub structures: Option<Vec<GoogleHomeEnterpriseSdmV1Structure>>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1ListStructuresResponse {}
/// Represents device relationships, for instance, structure/room to which the device is assigned to.
///
/// This type is not used in any activity, and only used as *part* of another schema.
///
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ParentRelation {
/// Output only. The custom name of the relation -- e.g., structure/room where the device is assigned to.
#[serde(rename="displayName")]
pub display_name: Option<String>,
/// Output only. The name of the relation -- e.g., structure/room where the device is assigned to. For example: "enterprises/XYZ/structures/ABC" or "enterprises/XYZ/structures/ABC/rooms/123"
pub parent: Option<String>,
}
impl client::Part for GoogleHomeEnterpriseSdmV1ParentRelation {}
/// Room resource represents an instance of sub-space within a structure such as rooms in a hotel suite or rental apartment.
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [structures rooms get enterprises](EnterpriseStructureRoomGetCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1Room {
/// Output only. The resource name of the room. For example: "enterprises/XYZ/structures/ABC/rooms/123".
pub name: Option<String>,
/// Room traits.
pub traits: Option<HashMap<String, json::Value>>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1Room {}
/// Structure resource represents an instance of enterprise managed home or hotel room.
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [structures get enterprises](EnterpriseStructureGetCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1Structure {
/// Output only. The resource name of the structure. For example: "enterprises/XYZ/structures/ABC".
pub name: Option<String>,
/// Structure traits.
pub traits: Option<HashMap<String, json::Value>>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1Structure {}
// ###################
// MethodBuilders ###
// #################
/// A builder providing access to all methods supported on *enterprise* resources.
/// It is not used directly, but through the [`SmartDeviceManagement`] hub.
///
/// # Example
///
/// Instantiate a resource builder
///
/// ```test_harness,no_run
/// extern crate hyper;
/// extern crate hyper_rustls;
/// extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
///
/// # async fn dox() {
/// use std::default::Default;
/// use smartdevicemanagement1::{SmartDeviceManagement, oauth2, hyper, hyper_rustls, chrono, FieldMask};
///
/// let secret: oauth2::ApplicationSecret = Default::default();
/// let auth = oauth2::InstalledFlowAuthenticator::builder(
/// secret,
/// oauth2::InstalledFlowReturnMethod::HTTPRedirect,
/// ).build().await.unwrap();
/// let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().https_or_http().enable_http1().build()), auth);
/// // Usually you wouldn't bind this to a variable, but keep calling *CallBuilders*
/// // like `devices_execute_command(...)`, `devices_get(...)`, `devices_list(...)`, `structures_get(...)`, `structures_list(...)`, `structures_rooms_get(...)` and `structures_rooms_list(...)`
/// // to build up your call.
/// let rb = hub.enterprises();
/// # }
/// ```
pub struct EnterpriseMethods<'a, S>
where S: 'a {
hub: &'a SmartDeviceManagement<S>,
}
impl<'a, S> client::MethodsBuilder for EnterpriseMethods<'a, S> {}
impl<'a, S> EnterpriseMethods<'a, S> {
/// Create a builder to help you perform the following task:
///
/// Executes a command to device managed by the enterprise.
///
/// # Arguments
///
/// * `request` - No description provided.
/// * `name` - The name of the device requested. For example: "enterprises/XYZ/devices/123"
pub fn devices_execute_command(&self, request: GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandRequest, name: &str) -> EnterpriseDeviceExecuteCommandCall<'a, S> {
EnterpriseDeviceExecuteCommandCall {
hub: self.hub,
_request: request,
_name: name.to_string(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Gets a device managed by the enterprise.
///
/// # Arguments
///
/// * `name` - The name of the device requested. For example: "enterprises/XYZ/devices/123"
pub fn devices_get(&self, name: &str) -> EnterpriseDeviceGetCall<'a, S> {
EnterpriseDeviceGetCall {
hub: self.hub,
_name: name.to_string(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Lists devices managed by the enterprise.
///
/// # Arguments
///
/// * `parent` - The parent enterprise to list devices under. E.g. "enterprises/XYZ".
pub fn devices_list(&self, parent: &str) -> EnterpriseDeviceListCall<'a, S> {
EnterpriseDeviceListCall {
hub: self.hub,
_parent: parent.to_string(),
_page_token: Default::default(),
_page_size: Default::default(),
_filter: Default::default(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Gets a room managed by the enterprise.
///
/// # Arguments
///
/// * `name` - The name of the room requested. For example: "enterprises/XYZ/structures/ABC/rooms/123".
pub fn structures_rooms_get(&self, name: &str) -> EnterpriseStructureRoomGetCall<'a, S> {
EnterpriseStructureRoomGetCall {
hub: self.hub,
_name: name.to_string(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Lists rooms managed by the enterprise.
///
/// # Arguments
///
/// * `parent` - The parent resource name of the rooms requested. For example: "enterprises/XYZ/structures/ABC".
pub fn structures_rooms_list(&self, parent: &str) -> EnterpriseStructureRoomListCall<'a, S> {
EnterpriseStructureRoomListCall {
hub: self.hub,
_parent: parent.to_string(),
_page_token: Default::default(),
_page_size: Default::default(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Gets a structure managed by the enterprise.
///
/// # Arguments
///
/// * `name` - The name of the structure requested. For example: "enterprises/XYZ/structures/ABC".
pub fn structures_get(&self, name: &str) -> EnterpriseStructureGetCall<'a, S> {
EnterpriseStructureGetCall {
hub: self.hub,
_name: name.to_string(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Lists structures managed by the enterprise.
///
/// # Arguments
///
/// * `parent` - The parent enterprise to list structures under. E.g. "enterprises/XYZ".
pub fn structures_list(&self, parent: &str) -> EnterpriseStructureListCall<'a, S> {
EnterpriseStructureListCall {
hub: self.hub,
_parent: parent.to_string(),
_page_token: Default::default(),
_page_size: Default::default(),
_filter: Default::default(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
}
// ###################
// CallBuilders ###
// #################
use super::*;
/// Executes a command to device managed by the enterprise.
///
/// A builder for the *devices.executeCommand* method supported by a *enterprise* resource.
@@ -581,12 +38,12 @@ impl<'a, S> EnterpriseMethods<'a, S> {
pub struct EnterpriseDeviceExecuteCommandCall<'a, S>
where S: 'a {
hub: &'a SmartDeviceManagement<S>,
_request: GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandRequest,
_name: String,
_delegate: Option<&'a mut dyn client::Delegate>,
_additional_params: HashMap<String, String>,
_scopes: BTreeSet<String>
pub(super) hub: &'a SmartDeviceManagement<S>,
pub(super) _request: GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandRequest,
pub(super) _name: String,
pub(super) _delegate: Option<&'a mut dyn client::Delegate>,
pub(super) _additional_params: HashMap<String, String>,
pub(super) _scopes: BTreeSet<String>
}
impl<'a, S> client::CallBuilder for EnterpriseDeviceExecuteCommandCall<'a, S> {}
@@ -867,11 +324,11 @@ where
pub struct EnterpriseDeviceGetCall<'a, S>
where S: 'a {
hub: &'a SmartDeviceManagement<S>,
_name: String,
_delegate: Option<&'a mut dyn client::Delegate>,
_additional_params: HashMap<String, String>,
_scopes: BTreeSet<String>
pub(super) hub: &'a SmartDeviceManagement<S>,
pub(super) _name: String,
pub(super) _delegate: Option<&'a mut dyn client::Delegate>,
pub(super) _additional_params: HashMap<String, String>,
pub(super) _scopes: BTreeSet<String>
}
impl<'a, S> client::CallBuilder for EnterpriseDeviceGetCall<'a, S> {}
@@ -1132,14 +589,14 @@ where
pub struct EnterpriseDeviceListCall<'a, S>
where S: 'a {
hub: &'a SmartDeviceManagement<S>,
_parent: String,
_page_token: Option<String>,
_page_size: Option<i32>,
_filter: Option<String>,
_delegate: Option<&'a mut dyn client::Delegate>,
_additional_params: HashMap<String, String>,
_scopes: BTreeSet<String>
pub(super) hub: &'a SmartDeviceManagement<S>,
pub(super) _parent: String,
pub(super) _page_token: Option<String>,
pub(super) _page_size: Option<i32>,
pub(super) _filter: Option<String>,
pub(super) _delegate: Option<&'a mut dyn client::Delegate>,
pub(super) _additional_params: HashMap<String, String>,
pub(super) _scopes: BTreeSet<String>
}
impl<'a, S> client::CallBuilder for EnterpriseDeviceListCall<'a, S> {}
@@ -1427,11 +884,11 @@ where
pub struct EnterpriseStructureRoomGetCall<'a, S>
where S: 'a {
hub: &'a SmartDeviceManagement<S>,
_name: String,
_delegate: Option<&'a mut dyn client::Delegate>,
_additional_params: HashMap<String, String>,
_scopes: BTreeSet<String>
pub(super) hub: &'a SmartDeviceManagement<S>,
pub(super) _name: String,
pub(super) _delegate: Option<&'a mut dyn client::Delegate>,
pub(super) _additional_params: HashMap<String, String>,
pub(super) _scopes: BTreeSet<String>
}
impl<'a, S> client::CallBuilder for EnterpriseStructureRoomGetCall<'a, S> {}
@@ -1691,13 +1148,13 @@ where
pub struct EnterpriseStructureRoomListCall<'a, S>
where S: 'a {
hub: &'a SmartDeviceManagement<S>,
_parent: String,
_page_token: Option<String>,
_page_size: Option<i32>,
_delegate: Option<&'a mut dyn client::Delegate>,
_additional_params: HashMap<String, String>,
_scopes: BTreeSet<String>
pub(super) hub: &'a SmartDeviceManagement<S>,
pub(super) _parent: String,
pub(super) _page_token: Option<String>,
pub(super) _page_size: Option<i32>,
pub(super) _delegate: Option<&'a mut dyn client::Delegate>,
pub(super) _additional_params: HashMap<String, String>,
pub(super) _scopes: BTreeSet<String>
}
impl<'a, S> client::CallBuilder for EnterpriseStructureRoomListCall<'a, S> {}
@@ -1975,11 +1432,11 @@ where
pub struct EnterpriseStructureGetCall<'a, S>
where S: 'a {
hub: &'a SmartDeviceManagement<S>,
_name: String,
_delegate: Option<&'a mut dyn client::Delegate>,
_additional_params: HashMap<String, String>,
_scopes: BTreeSet<String>
pub(super) hub: &'a SmartDeviceManagement<S>,
pub(super) _name: String,
pub(super) _delegate: Option<&'a mut dyn client::Delegate>,
pub(super) _additional_params: HashMap<String, String>,
pub(super) _scopes: BTreeSet<String>
}
impl<'a, S> client::CallBuilder for EnterpriseStructureGetCall<'a, S> {}
@@ -2240,14 +1697,14 @@ where
pub struct EnterpriseStructureListCall<'a, S>
where S: 'a {
hub: &'a SmartDeviceManagement<S>,
_parent: String,
_page_token: Option<String>,
_page_size: Option<i32>,
_filter: Option<String>,
_delegate: Option<&'a mut dyn client::Delegate>,
_additional_params: HashMap<String, String>,
_scopes: BTreeSet<String>
pub(super) hub: &'a SmartDeviceManagement<S>,
pub(super) _parent: String,
pub(super) _page_token: Option<String>,
pub(super) _page_size: Option<i32>,
pub(super) _filter: Option<String>,
pub(super) _delegate: Option<&'a mut dyn client::Delegate>,
pub(super) _additional_params: HashMap<String, String>,
pub(super) _scopes: BTreeSet<String>
}
impl<'a, S> client::CallBuilder for EnterpriseStructureListCall<'a, S> {}

View File

@@ -0,0 +1,106 @@
use super::*;
/// Central instance to access all SmartDeviceManagement related resource activities
///
/// # Examples
///
/// Instantiate a new hub
///
/// ```test_harness,no_run
/// extern crate hyper;
/// extern crate hyper_rustls;
/// extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
/// use smartdevicemanagement1::{Result, Error};
/// # async fn dox() {
/// use std::default::Default;
/// use smartdevicemanagement1::{SmartDeviceManagement, oauth2, hyper, hyper_rustls, chrono, FieldMask};
///
/// // Get an ApplicationSecret instance by some means. It contains the `client_id` and
/// // `client_secret`, among other things.
/// let secret: oauth2::ApplicationSecret = Default::default();
/// // Instantiate the authenticator. It will choose a suitable authentication flow for you,
/// // unless you replace `None` with the desired Flow.
/// // Provide your own `AuthenticatorDelegate` to adjust the way it operates and get feedback about
/// // what's going on. You probably want to bring in your own `TokenStorage` to persist tokens and
/// // retrieve them from storage.
/// let auth = oauth2::InstalledFlowAuthenticator::builder(
/// secret,
/// oauth2::InstalledFlowReturnMethod::HTTPRedirect,
/// ).build().await.unwrap();
/// let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().https_or_http().enable_http1().build()), auth);
/// // You can configure optional parameters by calling the respective setters at will, and
/// // execute the final call using `doit()`.
/// // Values shown here are possibly random and not representative !
/// let result = hub.enterprises().devices_get("name")
/// .doit().await;
///
/// match result {
/// Err(e) => match e {
/// // The Error enum provides details about what exactly happened.
/// // You can also just use its `Debug`, `Display` or `Error` traits
/// Error::HttpError(_)
/// |Error::Io(_)
/// |Error::MissingAPIKey
/// |Error::MissingToken(_)
/// |Error::Cancelled
/// |Error::UploadSizeLimitExceeded(_, _)
/// |Error::Failure(_)
/// |Error::BadRequest(_)
/// |Error::FieldClash(_)
/// |Error::JsonDecodeError(_, _) => println!("{}", e),
/// },
/// Ok(res) => println!("Success: {:?}", res),
/// }
/// # }
/// ```
#[derive(Clone)]
pub struct SmartDeviceManagement<S> {
pub client: hyper::Client<S, hyper::body::Body>,
pub auth: Box<dyn client::GetToken>,
pub(super) _user_agent: String,
pub(super) _base_url: String,
pub(super) _root_url: String,
}
impl<'a, S> client::Hub for SmartDeviceManagement<S> {}
impl<'a, S> SmartDeviceManagement<S> {
pub fn new<A: 'static + client::GetToken>(client: hyper::Client<S, hyper::body::Body>, auth: A) -> SmartDeviceManagement<S> {
SmartDeviceManagement {
client,
auth: Box::new(auth),
_user_agent: "google-api-rust-client/5.0.3".to_string(),
_base_url: "https://smartdevicemanagement.googleapis.com/".to_string(),
_root_url: "https://smartdevicemanagement.googleapis.com/".to_string(),
}
}
pub fn enterprises(&'a self) -> EnterpriseMethods<'a, S> {
EnterpriseMethods { hub: &self }
}
/// Set the user-agent header field to use in all requests to the server.
/// It defaults to `google-api-rust-client/5.0.3`.
///
/// Returns the previously set user-agent.
pub fn user_agent(&mut self, agent_name: String) -> String {
mem::replace(&mut self._user_agent, agent_name)
}
/// Set the base url to use in all requests to the server.
/// It defaults to `https://smartdevicemanagement.googleapis.com/`.
///
/// Returns the previously set base url.
pub fn base_url(&mut self, new_base_url: String) -> String {
mem::replace(&mut self._base_url, new_base_url)
}
/// Set the root url to use in all requests to the server.
/// It defaults to `https://smartdevicemanagement.googleapis.com/`.
///
/// Returns the previously set root url.
pub fn root_url(&mut self, new_root_url: String) -> String {
mem::replace(&mut self._root_url, new_root_url)
}
}

View File

@@ -0,0 +1,171 @@
use super::*;
/// A builder providing access to all methods supported on *enterprise* resources.
/// It is not used directly, but through the [`SmartDeviceManagement`] hub.
///
/// # Example
///
/// Instantiate a resource builder
///
/// ```test_harness,no_run
/// extern crate hyper;
/// extern crate hyper_rustls;
/// extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
///
/// # async fn dox() {
/// use std::default::Default;
/// use smartdevicemanagement1::{SmartDeviceManagement, oauth2, hyper, hyper_rustls, chrono, FieldMask};
///
/// let secret: oauth2::ApplicationSecret = Default::default();
/// let auth = oauth2::InstalledFlowAuthenticator::builder(
/// secret,
/// oauth2::InstalledFlowReturnMethod::HTTPRedirect,
/// ).build().await.unwrap();
/// let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().https_or_http().enable_http1().build()), auth);
/// // Usually you wouldn't bind this to a variable, but keep calling *CallBuilders*
/// // like `devices_execute_command(...)`, `devices_get(...)`, `devices_list(...)`, `structures_get(...)`, `structures_list(...)`, `structures_rooms_get(...)` and `structures_rooms_list(...)`
/// // to build up your call.
/// let rb = hub.enterprises();
/// # }
/// ```
pub struct EnterpriseMethods<'a, S>
where S: 'a {
pub(super) hub: &'a SmartDeviceManagement<S>,
}
impl<'a, S> client::MethodsBuilder for EnterpriseMethods<'a, S> {}
impl<'a, S> EnterpriseMethods<'a, S> {
/// Create a builder to help you perform the following task:
///
/// Executes a command to device managed by the enterprise.
///
/// # Arguments
///
/// * `request` - No description provided.
/// * `name` - The name of the device requested. For example: "enterprises/XYZ/devices/123"
pub fn devices_execute_command(&self, request: GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandRequest, name: &str) -> EnterpriseDeviceExecuteCommandCall<'a, S> {
EnterpriseDeviceExecuteCommandCall {
hub: self.hub,
_request: request,
_name: name.to_string(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Gets a device managed by the enterprise.
///
/// # Arguments
///
/// * `name` - The name of the device requested. For example: "enterprises/XYZ/devices/123"
pub fn devices_get(&self, name: &str) -> EnterpriseDeviceGetCall<'a, S> {
EnterpriseDeviceGetCall {
hub: self.hub,
_name: name.to_string(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Lists devices managed by the enterprise.
///
/// # Arguments
///
/// * `parent` - The parent enterprise to list devices under. E.g. "enterprises/XYZ".
pub fn devices_list(&self, parent: &str) -> EnterpriseDeviceListCall<'a, S> {
EnterpriseDeviceListCall {
hub: self.hub,
_parent: parent.to_string(),
_page_token: Default::default(),
_page_size: Default::default(),
_filter: Default::default(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Gets a room managed by the enterprise.
///
/// # Arguments
///
/// * `name` - The name of the room requested. For example: "enterprises/XYZ/structures/ABC/rooms/123".
pub fn structures_rooms_get(&self, name: &str) -> EnterpriseStructureRoomGetCall<'a, S> {
EnterpriseStructureRoomGetCall {
hub: self.hub,
_name: name.to_string(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Lists rooms managed by the enterprise.
///
/// # Arguments
///
/// * `parent` - The parent resource name of the rooms requested. For example: "enterprises/XYZ/structures/ABC".
pub fn structures_rooms_list(&self, parent: &str) -> EnterpriseStructureRoomListCall<'a, S> {
EnterpriseStructureRoomListCall {
hub: self.hub,
_parent: parent.to_string(),
_page_token: Default::default(),
_page_size: Default::default(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Gets a structure managed by the enterprise.
///
/// # Arguments
///
/// * `name` - The name of the structure requested. For example: "enterprises/XYZ/structures/ABC".
pub fn structures_get(&self, name: &str) -> EnterpriseStructureGetCall<'a, S> {
EnterpriseStructureGetCall {
hub: self.hub,
_name: name.to_string(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
/// Create a builder to help you perform the following task:
///
/// Lists structures managed by the enterprise.
///
/// # Arguments
///
/// * `parent` - The parent enterprise to list structures under. E.g. "enterprises/XYZ".
pub fn structures_list(&self, parent: &str) -> EnterpriseStructureListCall<'a, S> {
EnterpriseStructureListCall {
hub: self.hub,
_parent: parent.to_string(),
_page_token: Default::default(),
_page_size: Default::default(),
_filter: Default::default(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
}

View File

@@ -0,0 +1,32 @@
use std::collections::HashMap;
use std::cell::RefCell;
use std::default::Default;
use std::collections::BTreeSet;
use std::error::Error as StdError;
use serde_json as json;
use std::io;
use std::fs;
use std::mem;
use hyper::client::connect;
use tokio::io::{AsyncRead, AsyncWrite};
use tokio::time::sleep;
use tower_service;
use serde::{Serialize, Deserialize};
use crate::{client, client::GetToken, client::serde_with};
mod utilities;
pub use utilities::*;
mod hub;
pub use hub::*;
mod schemas;
pub use schemas::*;
mod method_builders;
pub use method_builders::*;
mod call_builders;
pub use call_builders::*;

View File

@@ -0,0 +1,204 @@
use super::*;
/// Device resource represents an instance of enterprise managed device in the property.
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [devices get enterprises](EnterpriseDeviceGetCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1Device {
/// Required. The resource name of the device. For example: "enterprises/XYZ/devices/123".
pub name: Option<String>,
/// Assignee details of the device.
#[serde(rename="parentRelations")]
pub parent_relations: Option<Vec<GoogleHomeEnterpriseSdmV1ParentRelation>>,
/// Output only. Device traits.
pub traits: Option<HashMap<String, json::Value>>,
/// Output only. Type of the device for general display purposes. For example: "THERMOSTAT". The device type should not be used to deduce or infer functionality of the actual device it is assigned to. Instead, use the returned traits for the device.
#[serde(rename="type")]
pub type_: Option<String>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1Device {}
/// Request message for SmartDeviceManagementService.ExecuteDeviceCommand
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [devices execute command enterprises](EnterpriseDeviceExecuteCommandCall) (request)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandRequest {
/// The command name to execute, represented by the fully qualified protobuf message name.
pub command: Option<String>,
/// The command message to execute, represented as a Struct.
pub params: Option<HashMap<String, json::Value>>,
}
impl client::RequestValue for GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandRequest {}
/// Response message for SmartDeviceManagementService.ExecuteDeviceCommand
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [devices execute command enterprises](EnterpriseDeviceExecuteCommandCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandResponse {
/// The results of executing the command.
pub results: Option<HashMap<String, json::Value>>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandResponse {}
/// Response message for SmartDeviceManagementService.ListDevices
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [devices list enterprises](EnterpriseDeviceListCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ListDevicesResponse {
/// The list of devices.
pub devices: Option<Vec<GoogleHomeEnterpriseSdmV1Device>>,
/// The pagination token to retrieve the next page of results.
#[serde(rename="nextPageToken")]
pub next_page_token: Option<String>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1ListDevicesResponse {}
/// Response message for SmartDeviceManagementService.ListRooms
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [structures rooms list enterprises](EnterpriseStructureRoomListCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ListRoomsResponse {
/// The pagination token to retrieve the next page of results. If this field is omitted, there are no subsequent pages.
#[serde(rename="nextPageToken")]
pub next_page_token: Option<String>,
/// The list of rooms.
pub rooms: Option<Vec<GoogleHomeEnterpriseSdmV1Room>>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1ListRoomsResponse {}
/// Response message for SmartDeviceManagementService.ListStructures
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [structures list enterprises](EnterpriseStructureListCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ListStructuresResponse {
/// The pagination token to retrieve the next page of results. If this field is omitted, there are no subsequent pages.
#[serde(rename="nextPageToken")]
pub next_page_token: Option<String>,
/// The list of structures.
pub structures: Option<Vec<GoogleHomeEnterpriseSdmV1Structure>>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1ListStructuresResponse {}
/// Represents device relationships, for instance, structure/room to which the device is assigned to.
///
/// This type is not used in any activity, and only used as *part* of another schema.
///
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1ParentRelation {
/// Output only. The custom name of the relation -- e.g., structure/room where the device is assigned to.
#[serde(rename="displayName")]
pub display_name: Option<String>,
/// Output only. The name of the relation -- e.g., structure/room where the device is assigned to. For example: "enterprises/XYZ/structures/ABC" or "enterprises/XYZ/structures/ABC/rooms/123"
pub parent: Option<String>,
}
impl client::Part for GoogleHomeEnterpriseSdmV1ParentRelation {}
/// Room resource represents an instance of sub-space within a structure such as rooms in a hotel suite or rental apartment.
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [structures rooms get enterprises](EnterpriseStructureRoomGetCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1Room {
/// Output only. The resource name of the room. For example: "enterprises/XYZ/structures/ABC/rooms/123".
pub name: Option<String>,
/// Room traits.
pub traits: Option<HashMap<String, json::Value>>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1Room {}
/// Structure resource represents an instance of enterprise managed home or hotel room.
///
/// # Activities
///
/// This type is used in activities, which are methods you may call on this type or where this type is involved in.
/// The list links the activity name, along with information about where it is used (one of *request* and *response*).
///
/// * [structures get enterprises](EnterpriseStructureGetCall) (response)
#[serde_with::serde_as(crate = "::client::serde_with")]
#[derive(Default, Clone, Debug, Serialize, Deserialize)]
pub struct GoogleHomeEnterpriseSdmV1Structure {
/// Output only. The resource name of the structure. For example: "enterprises/XYZ/structures/ABC".
pub name: Option<String>,
/// Structure traits.
pub traits: Option<HashMap<String, json::Value>>,
}
impl client::ResponseResult for GoogleHomeEnterpriseSdmV1Structure {}

View File

@@ -0,0 +1,24 @@
use super::*;
/// Identifies the an OAuth2 authorization scope.
/// A scope is needed when requesting an
/// [authorization token](https://developers.google.com/youtube/v3/guides/authentication).
#[derive(PartialEq, Eq, Hash, Debug, Clone)]
pub enum Scope {
/// See and/or control the devices that you selected
SdmService,
}
impl AsRef<str> for Scope {
fn as_ref(&self) -> &str {
match *self {
Scope::SdmService => "https://www.googleapis.com/auth/sdm.service",
}
}
}
impl Default for Scope {
fn default() -> Scope {
Scope::SdmService
}
}