make regen-apis

This commit is contained in:
OMGeeky
2024-05-16 21:23:40 +02:00
parent 52d2e89e51
commit ad85cafeef
5108 changed files with 1615625 additions and 992044 deletions

View File

@@ -1,529 +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, Ord, PartialOrd, Hash, Debug, Clone, Copy)]
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.4".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.4`.
///
/// 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>>,
}
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 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 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(),
_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(),
_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(),
_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.
@@ -538,6 +13,7 @@ impl<'a, S> EnterpriseMethods<'a, S> {
/// # extern crate hyper_rustls;
/// # extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
/// use smartdevicemanagement1::api::GoogleHomeEnterpriseSdmV1ExecuteDeviceCommandRequest;
/// use smartdevicemanagement1::api::enums::*;
/// # async fn dox() {
/// # use std::default::Default;
/// # use smartdevicemanagement1::{SmartDeviceManagement, oauth2, hyper, hyper_rustls, chrono, FieldMask};
@@ -547,7 +23,7 @@ impl<'a, S> EnterpriseMethods<'a, S> {
/// # 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);
/// # let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().unwrap().https_or_http().enable_http1().build()), auth);
/// // As the method needs a request, you would usually fill it with the desired information
/// // into the respective structure. Some of the parts shown here might not be applicable !
/// // Values shown here are possibly random and not representative !
@@ -563,12 +39,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> {}
@@ -602,7 +78,7 @@ where
}
let mut params = Params::with_capacity(4 + self._additional_params.len());
params.push("name", self._name);
params.push("name", &self._name);
params.extend(self._additional_params.iter());
@@ -829,6 +305,7 @@ where
/// # extern crate hyper;
/// # extern crate hyper_rustls;
/// # extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
/// use smartdevicemanagement1::api::enums::*;
/// # async fn dox() {
/// # use std::default::Default;
/// # use smartdevicemanagement1::{SmartDeviceManagement, oauth2, hyper, hyper_rustls, chrono, FieldMask};
@@ -838,7 +315,7 @@ where
/// # 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);
/// # let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().unwrap().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 !
@@ -849,11 +326,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> {}
@@ -887,7 +364,7 @@ where
}
let mut params = Params::with_capacity(3 + self._additional_params.len());
params.push("name", self._name);
params.push("name", &self._name);
params.extend(self._additional_params.iter());
@@ -936,6 +413,7 @@ where
let request = req_builder
.header(CONTENT_LENGTH, 0_u64)
.body(hyper::body::Body::empty());
client.request(request.unwrap()).await
@@ -1091,6 +569,7 @@ where
/// # extern crate hyper;
/// # extern crate hyper_rustls;
/// # extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
/// use smartdevicemanagement1::api::enums::*;
/// # async fn dox() {
/// # use std::default::Default;
/// # use smartdevicemanagement1::{SmartDeviceManagement, oauth2, hyper, hyper_rustls, chrono, FieldMask};
@@ -1100,7 +579,7 @@ where
/// # 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);
/// # let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().unwrap().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 !
@@ -1112,12 +591,12 @@ where
pub struct EnterpriseDeviceListCall<'a, S>
where S: 'a {
hub: &'a SmartDeviceManagement<S>,
_parent: String,
_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) _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> {}
@@ -1151,7 +630,7 @@ where
}
let mut params = Params::with_capacity(4 + self._additional_params.len());
params.push("parent", self._parent);
params.push("parent", &self._parent);
if let Some(value) = self._filter.as_ref() {
params.push("filter", value);
}
@@ -1203,6 +682,7 @@ where
let request = req_builder
.header(CONTENT_LENGTH, 0_u64)
.body(hyper::body::Body::empty());
client.request(request.unwrap()).await
@@ -1365,6 +845,7 @@ where
/// # extern crate hyper;
/// # extern crate hyper_rustls;
/// # extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
/// use smartdevicemanagement1::api::enums::*;
/// # async fn dox() {
/// # use std::default::Default;
/// # use smartdevicemanagement1::{SmartDeviceManagement, oauth2, hyper, hyper_rustls, chrono, FieldMask};
@@ -1374,7 +855,7 @@ where
/// # 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);
/// # let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().unwrap().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 !
@@ -1385,11 +866,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> {}
@@ -1423,7 +904,7 @@ where
}
let mut params = Params::with_capacity(3 + self._additional_params.len());
params.push("name", self._name);
params.push("name", &self._name);
params.extend(self._additional_params.iter());
@@ -1472,6 +953,7 @@ where
let request = req_builder
.header(CONTENT_LENGTH, 0_u64)
.body(hyper::body::Body::empty());
client.request(request.unwrap()).await
@@ -1627,6 +1109,7 @@ where
/// # extern crate hyper;
/// # extern crate hyper_rustls;
/// # extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
/// use smartdevicemanagement1::api::enums::*;
/// # async fn dox() {
/// # use std::default::Default;
/// # use smartdevicemanagement1::{SmartDeviceManagement, oauth2, hyper, hyper_rustls, chrono, FieldMask};
@@ -1636,7 +1119,7 @@ where
/// # 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);
/// # let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().unwrap().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 !
@@ -1647,11 +1130,11 @@ where
pub struct EnterpriseStructureRoomListCall<'a, S>
where S: 'a {
hub: &'a SmartDeviceManagement<S>,
_parent: 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) _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> {}
@@ -1685,7 +1168,7 @@ where
}
let mut params = Params::with_capacity(3 + self._additional_params.len());
params.push("parent", self._parent);
params.push("parent", &self._parent);
params.extend(self._additional_params.iter());
@@ -1734,6 +1217,7 @@ where
let request = req_builder
.header(CONTENT_LENGTH, 0_u64)
.body(hyper::body::Body::empty());
client.request(request.unwrap()).await
@@ -1889,6 +1373,7 @@ where
/// # extern crate hyper;
/// # extern crate hyper_rustls;
/// # extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
/// use smartdevicemanagement1::api::enums::*;
/// # async fn dox() {
/// # use std::default::Default;
/// # use smartdevicemanagement1::{SmartDeviceManagement, oauth2, hyper, hyper_rustls, chrono, FieldMask};
@@ -1898,7 +1383,7 @@ where
/// # 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);
/// # let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().unwrap().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 !
@@ -1909,11 +1394,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> {}
@@ -1947,7 +1432,7 @@ where
}
let mut params = Params::with_capacity(3 + self._additional_params.len());
params.push("name", self._name);
params.push("name", &self._name);
params.extend(self._additional_params.iter());
@@ -1996,6 +1481,7 @@ where
let request = req_builder
.header(CONTENT_LENGTH, 0_u64)
.body(hyper::body::Body::empty());
client.request(request.unwrap()).await
@@ -2151,6 +1637,7 @@ where
/// # extern crate hyper;
/// # extern crate hyper_rustls;
/// # extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
/// use smartdevicemanagement1::api::enums::*;
/// # async fn dox() {
/// # use std::default::Default;
/// # use smartdevicemanagement1::{SmartDeviceManagement, oauth2, hyper, hyper_rustls, chrono, FieldMask};
@@ -2160,7 +1647,7 @@ where
/// # 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);
/// # let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().unwrap().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 !
@@ -2172,12 +1659,12 @@ where
pub struct EnterpriseStructureListCall<'a, S>
where S: 'a {
hub: &'a SmartDeviceManagement<S>,
_parent: String,
_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) _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> {}
@@ -2211,7 +1698,7 @@ where
}
let mut params = Params::with_capacity(4 + self._additional_params.len());
params.push("parent", self._parent);
params.push("parent", &self._parent);
if let Some(value) = self._filter.as_ref() {
params.push("filter", value);
}
@@ -2263,6 +1750,7 @@ where
let request = req_builder
.header(CONTENT_LENGTH, 0_u64)
.body(hyper::body::Body::empty());
client.request(request.unwrap()).await

View File

@@ -0,0 +1,4 @@
use super::*;

View File

@@ -0,0 +1,107 @@
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};
/// use smartdevicemanagement1::api::enums::*;
/// # 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().unwrap().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.5".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.5`.
///
/// 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,165 @@
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().unwrap().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(),
_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(),
_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(),
_filter: Default::default(),
_delegate: Default::default(),
_additional_params: Default::default(),
_scopes: Default::default(),
}
}
}

View File

@@ -0,0 +1,35 @@
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::*;
pub mod enums;
pub(crate) use enums::*;

View File

@@ -0,0 +1,192 @@
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>>,
}
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 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 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
}
}

View File

@@ -2,14 +2,14 @@
// This file was generated automatically from 'src/generator/templates/api/lib.rs.mako'
// DO NOT EDIT !
//! This documentation was generated from *Smart Device Management* crate version *5.0.4+20240218*, where *20240218* is the exact revision of the *smartdevicemanagement:v1* schema built by the [mako](http://www.makotemplates.org/) code generator *v5.0.4*.
//! This documentation was generated from *Smart Device Management* crate version *5.0.5+20240324*, where *20240324* is the exact revision of the *smartdevicemanagement:v1* schema built by the [mako](http://www.makotemplates.org/) code generator *v5.0.5*.
//!
//! Everything else about the *Smart Device Management* *v1* API can be found at the
//! [official documentation site](https://developers.google.com/nest/device-access).
//! The original source code is [on github](https://github.com/Byron/google-apis-rs/tree/main/gen/smartdevicemanagement1).
//! # Features
//!
//! Handle the following *Resources* with ease from the central [hub](SmartDeviceManagement) ...
//! Handle the following *Resources* with ease from the central [hub](SmartDeviceManagement) ...
//!
//! * enterprises
//! * [*devices execute command*](api::EnterpriseDeviceExecuteCommandCall), [*devices get*](api::EnterpriseDeviceGetCall), [*devices list*](api::EnterpriseDeviceListCall), [*structures get*](api::EnterpriseStructureGetCall), [*structures list*](api::EnterpriseStructureListCall), [*structures rooms get*](api::EnterpriseStructureRoomGetCall) and [*structures rooms list*](api::EnterpriseStructureRoomListCall)
@@ -50,8 +50,8 @@
//! let r = hub.enterprises().devices_get(...).doit().await
//! ```
//!
//! The `resource()` and `activity(...)` calls create [builders][builder-pattern]. The second one dealing with `Activities`
//! supports various methods to configure the impending operation (not shown here). It is made such that all required arguments have to be
//! The `resource()` and `activity(...)` calls create [builders][builder-pattern]. The second one dealing with `Activities`
//! supports various methods to configure the impending operation (not shown here). It is made such that all required arguments have to be
//! specified right away (i.e. `(...)`), whereas all optional ones can be [build up][builder-pattern] as desired.
//! The `doit()` method performs the actual communication with the server and returns the respective result.
//!
@@ -75,23 +75,24 @@
//! extern crate hyper_rustls;
//! extern crate google_smartdevicemanagement1 as smartdevicemanagement1;
//! use smartdevicemanagement1::{Result, Error};
//! use smartdevicemanagement1::api::enums::*;
//! # 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
//! // 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,
//! // 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
//! // 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);
//! let mut hub = SmartDeviceManagement::new(hyper::Client::builder().build(hyper_rustls::HttpsConnectorBuilder::new().with_native_roots().unwrap().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 !
@@ -120,10 +121,10 @@
//! ## Handling Errors
//!
//! All errors produced by the system are provided either as [Result](client::Result) enumeration as return value of
//! the doit() methods, or handed as possibly intermediate results to either the
//! the doit() methods, or handed as possibly intermediate results to either the
//! [Hub Delegate](client::Delegate), or the [Authenticator Delegate](https://docs.rs/yup-oauth2/*/yup_oauth2/trait.AuthenticatorDelegate.html).
//!
//! When delegates handle errors or intermediate values, they may have a chance to instruct the system to retry. This
//! When delegates handle errors or intermediate values, they may have a chance to instruct the system to retry. This
//! makes the system potentially resilient to all kinds of errors.
//!
//! ## Uploads and Downloads
@@ -133,25 +134,25 @@
//! You can see it as meta-data for the actual media. To trigger a media download, you will have to set up the builder by making
//! this call: `.param("alt", "media")`.
//!
//! Methods supporting uploads can do so using up to 2 different protocols:
//! *simple* and *resumable*. The distinctiveness of each is represented by customized
//! Methods supporting uploads can do so using up to 2 different protocols:
//! *simple* and *resumable*. The distinctiveness of each is represented by customized
//! `doit(...)` methods, which are then named `upload(...)` and `upload_resumable(...)` respectively.
//!
//! ## Customization and Callbacks
//!
//! You may alter the way an `doit()` method is called by providing a [delegate](client::Delegate) to the
//! [Method Builder](client::CallBuilder) before making the final `doit()` call.
//! Respective methods will be called to provide progress information, as well as determine whether the system should
//! You may alter the way an `doit()` method is called by providing a [delegate](client::Delegate) to the
//! [Method Builder](client::CallBuilder) before making the final `doit()` call.
//! Respective methods will be called to provide progress information, as well as determine whether the system should
//! retry on failure.
//!
//! The [delegate trait](client::Delegate) is default-implemented, allowing you to customize it with minimal effort.
//!
//! ## Optional Parts in Server-Requests
//!
//! All structures provided by this library are made to be [encodable](client::RequestValue) and
//! [decodable](client::ResponseResult) via *json*. Optionals are used to indicate that partial requests are responses
//! All structures provided by this library are made to be [encodable](client::RequestValue) and
//! [decodable](client::ResponseResult) via *json*. Optionals are used to indicate that partial requests are responses
//! are valid.
//! Most optionals are are considered [Parts](client::Part) which are identifiable by name, which will be sent to
//! Most optionals are are considered [Parts](client::Part) which are identifiable by name, which will be sent to
//! the server to indicate either the set parts of the request or the desired parts in the response.
//!
//! ## Builder Arguments