google_cloud_networksecurity_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 - Network Security API
18//!
19//! This crate contains traits, types, and functions to interact with Network Security API
20//! Most applications will use the structs defined in the [client] module.
21//!
22//! The client library types and functions are stable and not expected to change.
23//! Please note that Google Cloud services do change from time to time. The client
24//! libraries are designed to preserve backwards compatibility when the service
25//! changes in compatible ways. For example, adding RPCs, or fields to messages
26//! should not introduce breaking changes to the client libraries.
27//!
28//! # Available Clients
29//!
30//! * [AddressGroupService](client/struct.AddressGroupService.html)
31//! * [OrganizationAddressGroupService](client/struct.OrganizationAddressGroupService.html)
32//! * [DnsThreatDetectorService](client/struct.DnsThreatDetectorService.html)
33//! * [FirewallActivation](client/struct.FirewallActivation.html)
34//! * [Intercept](client/struct.Intercept.html)
35//! * [Mirroring](client/struct.Mirroring.html)
36//! * [NetworkSecurity](client/struct.NetworkSecurity.html)
37//! * [OrganizationSecurityProfileGroupService](client/struct.OrganizationSecurityProfileGroupService.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#![allow(deprecated)]
51
52/// The messages and enums that are part of this client library.
53#[allow(clippy::module_inception)]
54pub mod model;
55
56pub use google_cloud_gax::Result;
57pub use google_cloud_gax::error::Error;
58
59#[allow(rustdoc::invalid_html_tags)]
60#[allow(rustdoc::redundant_explicit_links)]
61pub mod stub;
62
63///
64/// # Example
65/// ```
66/// # use google_cloud_networksecurity_v1::client::NetworkSecurity;
67/// use google_cloud_gax::paginator::ItemPaginator as _;
68/// async fn sample(
69/// parent: &str,
70/// ) -> anyhow::Result<()> {
71/// let client = NetworkSecurity::builder().build().await?;
72/// let mut list = client.list_authorization_policies()
73/// .set_parent(parent)
74/// .by_item();
75/// while let Some(item) = list.next().await.transpose()? {
76/// println!("{:?}", item);
77/// }
78/// Ok(())
79/// }
80/// ```
81/// Concrete implementations of this client library traits.
82pub mod client;
83
84/// Request builders.
85pub mod builder;
86
87#[doc(hidden)]
88pub(crate) mod tracing;
89
90#[doc(hidden)]
91pub(crate) mod transport;
92
93/// The default host used by the service.
94const DEFAULT_HOST: &str = "https://networksecurity.googleapis.com/";
95
96pub(crate) mod info {
97 const NAME: &str = env!("CARGO_PKG_NAME");
98 const VERSION: &str = env!("CARGO_PKG_VERSION");
99 pub(crate) static X_GOOG_API_CLIENT_HEADER: std::sync::LazyLock<String> =
100 std::sync::LazyLock::new(|| {
101 let ac = gaxi::api_header::XGoogApiClient {
102 name: NAME,
103 version: VERSION,
104 library_type: gaxi::api_header::GAPIC,
105 };
106 ac.rest_header_value()
107 });
108}
109
110// Define some shortcuts for imported crates.
111pub(crate) use google_cloud_gax::client_builder::ClientBuilder;
112pub(crate) use google_cloud_gax::client_builder::Result as ClientBuilderResult;
113pub(crate) use google_cloud_gax::client_builder::internal::ClientFactory;
114pub(crate) use google_cloud_gax::client_builder::internal::new_builder as new_client_builder;
115pub(crate) use google_cloud_gax::options::RequestOptions;
116pub(crate) use google_cloud_gax::options::internal::RequestBuilder;
117pub(crate) use google_cloud_gax::response::Response;