google_cloud_devicestreaming_v1/lib.rs
1// Copyright 2025 Google LLC
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// https://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14//
15// Code generated by sidekick. DO NOT EDIT.
16
17//! Google Cloud Client Libraries for Rust - Device Streaming API
18//!
19//! **WARNING:** some RPCs have no corresponding Rust function to call them.
20//! Typically these are streaming RPCs. We expect adding these RPCs in a
21//! way that does not break the existing APIs or changes their behavior in a
22//! significant way. We do anticipate a number of new crate dependencies
23//! will be required. If you need these RPCs please open an issue in our
24//! GitHub repository.
25//!
26//! This crate contains traits, types, and functions to interact with Device Streaming API
27//! Most applications will use the structs defined in the [client] module.
28//!
29//! The client library types and functions are stable and not expected to change.
30//! Please note that Google Cloud services do change from time to time. The client
31//! libraries are designed to preserve backwards compatibility when the service
32//! changes in compatible ways. For example, adding RPCs, or fields to messages
33//! should not introduce breaking changes to the client libraries.
34//!
35//! # Available Clients
36//!
37//! * [DirectAccessService](client/struct.DirectAccessService.html)
38//!
39//! # Features
40//!
41//! - `default-rustls-provider`: enabled by default. Use the default rustls
42//! crypto provider ([aws-lc-rs]) for TLS and authentication. Applications
43//! with specific requirements for cryptography (such as exclusively using the
44//! [ring] crate) should disable this default and call
45//! `rustls::crypto::CryptoProvider::install_default()`.
46//!
47//! [aws-lc-rs]: https://crates.io/crates/aws-lc-rs
48//! [ring]: https://crates.io/crates/ring
49
50/// The messages and enums that are part of this client library.
51#[allow(clippy::module_inception)]
52pub mod model;
53
54pub use google_cloud_gax::Result;
55pub use google_cloud_gax::error::Error;
56
57#[allow(rustdoc::invalid_html_tags)]
58#[allow(rustdoc::redundant_explicit_links)]
59pub mod stub;
60
61///
62/// # Example
63/// ```
64/// # use google_cloud_devicestreaming_v1::client::DirectAccessService;
65/// use google_cloud_gax::paginator::ItemPaginator as _;
66/// # async fn sample() -> Result<(), Box<dyn std::error::Error>> {
67/// let client = DirectAccessService::builder().build().await?;
68/// let parent = "parent_value";
69/// let mut list = client.list_device_sessions()
70/// .set_parent(parent)
71/// .by_item();
72/// while let Some(item) = list.next().await.transpose()? {
73/// println!("{:?}", item);
74/// }
75/// # Ok(()) }
76/// ```
77/// Concrete implementations of this client library traits.
78pub mod client;
79
80/// Request builders.
81pub mod builder;
82
83#[doc(hidden)]
84pub(crate) mod tracing;
85
86#[doc(hidden)]
87pub(crate) mod transport;
88
89/// The default host used by the service.
90const DEFAULT_HOST: &str = "https://devicestreaming.googleapis.com/";
91
92pub(crate) mod info {
93 const NAME: &str = env!("CARGO_PKG_NAME");
94 const VERSION: &str = env!("CARGO_PKG_VERSION");
95 lazy_static::lazy_static! {
96 pub(crate) static ref X_GOOG_API_CLIENT_HEADER: String = {
97 let ac = gaxi::api_header::XGoogApiClient{
98 name: NAME,
99 version: VERSION,
100 library_type: gaxi::api_header::GAPIC,
101 };
102 ac.rest_header_value()
103 };
104 }
105}
106
107// Define some shortcuts for imported crates.
108pub(crate) use google_cloud_gax::client_builder::ClientBuilder;
109pub(crate) use google_cloud_gax::client_builder::Result as ClientBuilderResult;
110pub(crate) use google_cloud_gax::client_builder::internal::ClientFactory;
111pub(crate) use google_cloud_gax::client_builder::internal::new_builder as new_client_builder;
112pub(crate) use google_cloud_gax::options::RequestOptions;
113pub(crate) use google_cloud_gax::options::internal::RequestBuilder;
114pub(crate) use google_cloud_gax::response::Response;