blob: dd242d8d877718d0cf6a45cf9dbf60d1c9f28215 [file] [edit]
// Copyright 2019 Google LLC
//
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file or at
// https://developers.google.com/open-source/licenses/bsd
// This is a generated file (see the discoveryapis_generator project).
// ignore_for_file: camel_case_types
// ignore_for_file: comment_references
// ignore_for_file: deprecated_member_use_from_same_package
// ignore_for_file: doc_directive_unknown
// ignore_for_file: lines_longer_than_80_chars
// ignore_for_file: non_constant_identifier_names
// ignore_for_file: prefer_interpolation_to_compose_strings
// ignore_for_file: unintended_html_in_doc_comment
// ignore_for_file: unnecessary_brace_in_string_interps
// ignore_for_file: unnecessary_lambdas
// ignore_for_file: unnecessary_string_interpolations
/// Cloud Asset API - v1
///
/// The Cloud Asset API manages the history and inventory of Google Cloud
/// resources.
///
/// For more information, see
/// <https://cloud.google.com/asset-inventory/docs/quickstart>
///
/// Create an instance of [CloudAssetApi] to access these resources:
///
/// - [AssetsResource]
/// - [EffectiveIamPoliciesResource]
/// - [FeedsResource]
/// - [OperationsResource]
/// - [SavedQueriesResource]
/// - [V1Resource]
library;
import 'dart:async' as async;
import 'dart:convert' as convert;
import 'dart:core' as core;
import 'package:_discoveryapis_commons/_discoveryapis_commons.dart' as commons;
import 'package:http/http.dart' as http;
import '../shared.dart';
import '../src/user_agent.dart';
export 'package:_discoveryapis_commons/_discoveryapis_commons.dart'
show ApiRequestError, DetailedApiRequestError;
/// The Cloud Asset API manages the history and inventory of Google Cloud
/// resources.
class CloudAssetApi {
/// See, edit, configure, and delete your Google Cloud data and see the email
/// address for your Google Account.
static const cloudPlatformScope =
'https://www.googleapis.com/auth/cloud-platform';
final commons.ApiRequester _requester;
AssetsResource get assets => AssetsResource(_requester);
EffectiveIamPoliciesResource get effectiveIamPolicies =>
EffectiveIamPoliciesResource(_requester);
FeedsResource get feeds => FeedsResource(_requester);
OperationsResource get operations => OperationsResource(_requester);
SavedQueriesResource get savedQueries => SavedQueriesResource(_requester);
V1Resource get v1 => V1Resource(_requester);
CloudAssetApi(
http.Client client, {
core.String rootUrl = 'https://cloudasset.googleapis.com/',
core.String servicePath = '',
}) : _requester = commons.ApiRequester(
client,
rootUrl,
servicePath,
requestHeaders,
);
}
class AssetsResource {
final commons.ApiRequester _requester;
AssetsResource(commons.ApiRequester client) : _requester = client;
/// Lists assets with time and resource types and returns paged results in
/// response.
///
/// Request parameters:
///
/// [parent] - Required. Name of the organization, folder, or project the
/// assets belong to. Format: "organizations/\[organization-number\]" (such as
/// "organizations/123"), "projects/\[project-id\]" (such as
/// "projects/my-project-id"), "projects/\[project-number\]" (such as
/// "projects/12345"), or "folders/\[folder-number\]" (such as
/// "folders/12345").
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [assetTypes] - A list of asset types to take a snapshot for. For example:
/// "compute.googleapis.com/Disk". Regular expression is also supported. For
/// example: * "compute.googleapis.com.*" snapshots resources whose asset type
/// starts with "compute.googleapis.com". * ".*Instance" snapshots resources
/// whose asset type ends with "Instance". * ".*Instance.*" snapshots
/// resources whose asset type contains "Instance". See
/// [RE2](https://github.com/google/re2/wiki/Syntax) for all supported regular
/// expression syntax. If the regular expression does not match any supported
/// asset type, an INVALID_ARGUMENT error will be returned. If specified, only
/// matching assets will be returned, otherwise, it will snapshot all asset
/// types. See
/// [Introduction to Cloud Asset Inventory](https://cloud.google.com/asset-inventory/docs/overview)
/// for all supported asset types.
///
/// [contentType] - Asset content type. If not specified, no content but the
/// asset name will be returned.
/// Possible string values are:
/// - "CONTENT_TYPE_UNSPECIFIED" : Unspecified content type.
/// - "RESOURCE" : Resource metadata.
/// - "IAM_POLICY" : The actual IAM policy set on a resource.
/// - "ORG_POLICY" : The organization policy set on an asset.
/// - "ACCESS_POLICY" : The Access Context Manager policy set on an asset.
/// - "OS_INVENTORY" : The runtime OS Inventory information.
/// - "RELATIONSHIP" : The related resources.
///
/// [pageSize] - The maximum number of assets to be returned in a single
/// response. Default is 100, minimum is 1, and maximum is 1000.
///
/// [pageToken] - The `next_page_token` returned from the previous
/// `ListAssetsResponse`, or unspecified for the first `ListAssetsRequest`. It
/// is a continuation of a prior `ListAssets` call, and the API should return
/// the next page of assets.
///
/// [readTime] - Timestamp to take an asset snapshot. This can only be set to
/// a timestamp between the current time and the current time minus 35 days
/// (inclusive). If not specified, the current time will be used. Due to
/// delays in resource data collection and indexing, there is a volatile
/// window during which running the same query may get different results.
///
/// [relationshipTypes] - A list of relationship types to output, for example:
/// `INSTANCE_TO_INSTANCEGROUP`. This field should only be specified if
/// content_type=RELATIONSHIP. * If specified: it snapshots specified
/// relationships. It returns an error if any of the \[relationship_types\]
/// doesn't belong to the supported relationship types of the \[asset_types\]
/// or if any of the \[asset_types\] doesn't belong to the source types of the
/// \[relationship_types\]. * Otherwise: it snapshots the supported
/// relationships for all \[asset_types\] or returns an error if any of the
/// \[asset_types\] has no relationship support. An unspecified asset types
/// field means all supported asset_types. See
/// [Introduction to Cloud Asset Inventory](https://cloud.google.com/asset-inventory/docs/overview)
/// for all supported asset types and relationship types.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [ListAssetsResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<ListAssetsResponse> list(
core.String parent, {
core.List<core.String>? assetTypes,
core.String? contentType,
core.int? pageSize,
core.String? pageToken,
core.String? readTime,
core.List<core.String>? relationshipTypes,
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'assetTypes': ?assetTypes,
'contentType': ?contentType == null ? null : [contentType],
'pageSize': ?pageSize == null ? null : ['${pageSize}'],
'pageToken': ?pageToken == null ? null : [pageToken],
'readTime': ?readTime == null ? null : [readTime],
'relationshipTypes': ?relationshipTypes,
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$parent') + '/assets';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return ListAssetsResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
}
class EffectiveIamPoliciesResource {
final commons.ApiRequester _requester;
EffectiveIamPoliciesResource(commons.ApiRequester client)
: _requester = client;
/// Gets effective IAM policies for a batch of resources.
///
/// Request parameters:
///
/// [scope] - Required. Only IAM policies on or below the scope will be
/// returned. This can only be an organization number (such as
/// "organizations/123"), a folder number (such as "folders/123"), a project
/// ID (such as "projects/my-project-id"), or a project number (such as
/// "projects/12345"). To know how to get organization ID, visit
/// [here ](https://cloud.google.com/resource-manager/docs/creating-managing-organization#retrieving_your_organization_id).
/// To know how to get folder or project ID, visit
/// [here ](https://cloud.google.com/resource-manager/docs/creating-managing-folders#viewing_or_listing_folders_and_projects).
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [names] - Required. The names refer to the
/// [full_resource_names](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// of the asset types
/// [supported by search APIs](https://cloud.google.com/asset-inventory/docs/supported-asset-types).
/// A maximum of 20 resources' effective policies can be retrieved in a batch.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [BatchGetEffectiveIamPoliciesResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<BatchGetEffectiveIamPoliciesResponse> batchGet(
core.String scope, {
core.List<core.String>? names,
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'names': ?names,
'fields': ?$fields == null ? null : [$fields],
};
final url_ =
'v1/' +
core.Uri.encodeFull('$scope') +
'/effectiveIamPolicies:batchGet';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return BatchGetEffectiveIamPoliciesResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
}
class FeedsResource {
final commons.ApiRequester _requester;
FeedsResource(commons.ApiRequester client) : _requester = client;
/// Creates a feed in a parent project/folder/organization to listen to its
/// asset updates.
///
/// [request] - The metadata request object.
///
/// Request parameters:
///
/// [parent] - Required. The name of the project/folder/organization where
/// this feed should be created in. It can only be an organization number
/// (such as "organizations/123"), a folder number (such as "folders/123"), a
/// project ID (such as "projects/my-project-id"), or a project number (such
/// as "projects/12345").
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [Feed].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<Feed> create(
CreateFeedRequest request,
core.String parent, {
core.String? $fields,
}) async {
final body_ = convert.json.encode(request);
final queryParams_ = <core.String, core.List<core.String>>{
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$parent') + '/feeds';
final response_ = await _requester.request(
url_,
'POST',
body: body_,
queryParams: queryParams_,
);
return Feed.fromJson(response_ as core.Map<core.String, core.dynamic>);
}
/// Deletes an asset feed.
///
/// Request parameters:
///
/// [name] - Required. The name of the feed and it must be in the format of:
/// projects/project_number/feeds/feed_id folders/folder_number/feeds/feed_id
/// organizations/organization_number/feeds/feed_id
/// Value must have pattern `^\[^/\]+/\[^/\]+/feeds/\[^/\]+$`.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [Empty].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<Empty> delete(core.String name, {core.String? $fields}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$name');
final response_ = await _requester.request(
url_,
'DELETE',
queryParams: queryParams_,
);
return Empty.fromJson(response_ as core.Map<core.String, core.dynamic>);
}
/// Gets details about an asset feed.
///
/// Request parameters:
///
/// [name] - Required. The name of the Feed and it must be in the format of:
/// projects/project_number/feeds/feed_id folders/folder_number/feeds/feed_id
/// organizations/organization_number/feeds/feed_id
/// Value must have pattern `^\[^/\]+/\[^/\]+/feeds/\[^/\]+$`.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [Feed].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<Feed> get(core.String name, {core.String? $fields}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$name');
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return Feed.fromJson(response_ as core.Map<core.String, core.dynamic>);
}
/// Lists all asset feeds in a parent project/folder/organization.
///
/// Request parameters:
///
/// [parent] - Required. The parent project/folder/organization whose feeds
/// are to be listed. It can only be using project/folder/organization number
/// (such as "folders/12345")", or a project ID (such as
/// "projects/my-project-id").
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [ListFeedsResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<ListFeedsResponse> list(
core.String parent, {
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$parent') + '/feeds';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return ListFeedsResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Updates an asset feed configuration.
///
/// [request] - The metadata request object.
///
/// Request parameters:
///
/// [name] - Required. The format will be
/// projects/{project_number}/feeds/{client-assigned_feed_identifier} or
/// folders/{folder_number}/feeds/{client-assigned_feed_identifier} or
/// organizations/{organization_number}/feeds/{client-assigned_feed_identifier}
/// The client-assigned feed identifier must be unique within the parent
/// project/folder/organization.
/// Value must have pattern `^\[^/\]+/\[^/\]+/feeds/\[^/\]+$`.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [Feed].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<Feed> patch(
UpdateFeedRequest request,
core.String name, {
core.String? $fields,
}) async {
final body_ = convert.json.encode(request);
final queryParams_ = <core.String, core.List<core.String>>{
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$name');
final response_ = await _requester.request(
url_,
'PATCH',
body: body_,
queryParams: queryParams_,
);
return Feed.fromJson(response_ as core.Map<core.String, core.dynamic>);
}
}
class OperationsResource {
final commons.ApiRequester _requester;
OperationsResource(commons.ApiRequester client) : _requester = client;
/// Gets the latest state of a long-running operation.
///
/// Clients can use this method to poll the operation result at intervals as
/// recommended by the API service.
///
/// Request parameters:
///
/// [name] - The name of the operation resource.
/// Value must have pattern `^\[^/\]+/\[^/\]+/operations/\[^/\]+/.*$`.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [Operation].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<Operation> get(core.String name, {core.String? $fields}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$name');
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return Operation.fromJson(response_ as core.Map<core.String, core.dynamic>);
}
}
class SavedQueriesResource {
final commons.ApiRequester _requester;
SavedQueriesResource(commons.ApiRequester client) : _requester = client;
/// Creates a saved query in a parent project/folder/organization.
///
/// [request] - The metadata request object.
///
/// Request parameters:
///
/// [parent] - Required. The name of the project/folder/organization where
/// this saved_query should be created in. It can only be an organization
/// number (such as "organizations/123"), a folder number (such as
/// "folders/123"), a project ID (such as "projects/my-project-id"), or a
/// project number (such as "projects/12345").
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [savedQueryId] - Required. The ID to use for the saved query, which must
/// be unique in the specified parent. It will become the final component of
/// the saved query's resource name. This value should be 4-63 characters, and
/// valid characters are `a-z-`. Notice that this field is required in the
/// saved query creation, and the `name` field of the `saved_query` will be
/// ignored.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [SavedQuery].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<SavedQuery> create(
SavedQuery request,
core.String parent, {
core.String? savedQueryId,
core.String? $fields,
}) async {
final body_ = convert.json.encode(request);
final queryParams_ = <core.String, core.List<core.String>>{
'savedQueryId': ?savedQueryId == null ? null : [savedQueryId],
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$parent') + '/savedQueries';
final response_ = await _requester.request(
url_,
'POST',
body: body_,
queryParams: queryParams_,
);
return SavedQuery.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Deletes a saved query.
///
/// Request parameters:
///
/// [name] - Required. The name of the saved query to delete. It must be in
/// the format of: * projects/project_number/savedQueries/saved_query_id *
/// folders/folder_number/savedQueries/saved_query_id *
/// organizations/organization_number/savedQueries/saved_query_id
/// Value must have pattern `^\[^/\]+/\[^/\]+/savedQueries/\[^/\]+$`.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [Empty].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<Empty> delete(core.String name, {core.String? $fields}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$name');
final response_ = await _requester.request(
url_,
'DELETE',
queryParams: queryParams_,
);
return Empty.fromJson(response_ as core.Map<core.String, core.dynamic>);
}
/// Gets details about a saved query.
///
/// Request parameters:
///
/// [name] - Required. The name of the saved query and it must be in the
/// format of: * projects/project_number/savedQueries/saved_query_id *
/// folders/folder_number/savedQueries/saved_query_id *
/// organizations/organization_number/savedQueries/saved_query_id
/// Value must have pattern `^\[^/\]+/\[^/\]+/savedQueries/\[^/\]+$`.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [SavedQuery].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<SavedQuery> get(core.String name, {core.String? $fields}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$name');
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return SavedQuery.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Lists all saved queries in a parent project/folder/organization.
///
/// Request parameters:
///
/// [parent] - Required. The parent project/folder/organization whose
/// savedQueries are to be listed. It can only be using
/// project/folder/organization number (such as "folders/12345")", or a
/// project ID (such as "projects/my-project-id").
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [filter] - Optional. The expression to filter resources. The expression is
/// a list of zero or more restrictions combined via logical operators `AND`
/// and `OR`. When `AND` and `OR` are both used in the expression, parentheses
/// must be appropriately used to group the combinations. The expression may
/// also contain regular expressions. See https://google.aip.dev/160 for more
/// information on the grammar.
///
/// [pageSize] - Optional. The maximum number of saved queries to return per
/// page. The service may return fewer than this value. If unspecified, at
/// most 50 will be returned. The maximum value is 1000; values above 1000
/// will be coerced to 1000.
///
/// [pageToken] - Optional. A page token, received from a previous
/// `ListSavedQueries` call. Provide this to retrieve the subsequent page.
/// When paginating, all other parameters provided to `ListSavedQueries` must
/// match the call that provided the page token.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [ListSavedQueriesResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<ListSavedQueriesResponse> list(
core.String parent, {
core.String? filter,
core.int? pageSize,
core.String? pageToken,
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'filter': ?filter == null ? null : [filter],
'pageSize': ?pageSize == null ? null : ['${pageSize}'],
'pageToken': ?pageToken == null ? null : [pageToken],
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$parent') + '/savedQueries';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return ListSavedQueriesResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Updates a saved query.
///
/// [request] - The metadata request object.
///
/// Request parameters:
///
/// [name] - The resource name of the saved query. The format must be: *
/// projects/project_number/savedQueries/saved_query_id *
/// folders/folder_number/savedQueries/saved_query_id *
/// organizations/organization_number/savedQueries/saved_query_id
/// Value must have pattern `^\[^/\]+/\[^/\]+/savedQueries/\[^/\]+$`.
///
/// [updateMask] - Required. The list of fields to update.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [SavedQuery].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<SavedQuery> patch(
SavedQuery request,
core.String name, {
core.String? updateMask,
core.String? $fields,
}) async {
final body_ = convert.json.encode(request);
final queryParams_ = <core.String, core.List<core.String>>{
'updateMask': ?updateMask == null ? null : [updateMask],
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$name');
final response_ = await _requester.request(
url_,
'PATCH',
body: body_,
queryParams: queryParams_,
);
return SavedQuery.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
}
class V1Resource {
final commons.ApiRequester _requester;
V1Resource(commons.ApiRequester client) : _requester = client;
/// Analyzes IAM policies to answer which identities have what accesses on
/// which resources.
///
/// Request parameters:
///
/// [scope] - Required. The relative name of the root asset. Only resources
/// and IAM policies within the scope will be analyzed. This can only be an
/// organization number (such as "organizations/123"), a folder number (such
/// as "folders/123"), a project ID (such as "projects/my-project-id"), or a
/// project number (such as "projects/12345"). To know how to get organization
/// ID, visit
/// [here ](https://cloud.google.com/resource-manager/docs/creating-managing-organization#retrieving_your_organization_id).
/// To know how to get folder or project ID, visit
/// [here ](https://cloud.google.com/resource-manager/docs/creating-managing-folders#viewing_or_listing_folders_and_projects).
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [analysisQuery_accessSelector_permissions] - Optional. The permissions to
/// appear in result.
///
/// [analysisQuery_accessSelector_roles] - Optional. The roles to appear in
/// result.
///
/// [analysisQuery_conditionContext_accessTime] - The hypothetical access
/// timestamp to evaluate IAM conditions. Note that this value must not be
/// earlier than the current time; otherwise, an INVALID_ARGUMENT error will
/// be returned.
///
/// [analysisQuery_identitySelector_identity] - Required. The identity appear
/// in the form of principals in
/// [IAM policy binding](https://cloud.google.com/iam/reference/rest/v1/Binding).
/// The examples of supported forms are: "user:mike@example.com",
/// "group:admins@example.com", "domain:google.com",
/// "serviceAccount:my-project-id@appspot.gserviceaccount.com". Notice that
/// wildcard characters (such as * and ?) are not supported. You must give a
/// specific identity.
///
/// [analysisQuery_options_analyzeServiceAccountImpersonation] - Optional. If
/// true, the response will include access analysis from identities to
/// resources via service account impersonation. This is a very expensive
/// operation, because many derived queries will be executed. We highly
/// recommend you use AssetService.AnalyzeIamPolicyLongrunning RPC instead.
/// For example, if the request analyzes for which resources user A has
/// permission P, and there's an IAM policy states user A has
/// iam.serviceAccounts.getAccessToken permission to a service account SA, and
/// there's another IAM policy states service account SA has permission P to a
/// Google Cloud folder F, then user A potentially has access to the Google
/// Cloud folder F. And those advanced analysis results will be included in
/// AnalyzeIamPolicyResponse.service_account_impersonation_analysis. Another
/// example, if the request analyzes for who has permission P to a Google
/// Cloud folder F, and there's an IAM policy states user A has
/// iam.serviceAccounts.actAs permission to a service account SA, and there's
/// another IAM policy states service account SA has permission P to the
/// Google Cloud folder F, then user A potentially has access to the Google
/// Cloud folder F. And those advanced analysis results will be included in
/// AnalyzeIamPolicyResponse.service_account_impersonation_analysis. Only the
/// following permissions are considered in this analysis: *
/// `iam.serviceAccounts.actAs` * `iam.serviceAccounts.signBlob` *
/// `iam.serviceAccounts.signJwt` * `iam.serviceAccounts.getAccessToken` *
/// `iam.serviceAccounts.getOpenIdToken` *
/// `iam.serviceAccounts.implicitDelegation` Default is false.
///
/// [analysisQuery_options_expandGroups] - Optional. If true, the identities
/// section of the result will expand any Google groups appearing in an IAM
/// policy binding. If IamPolicyAnalysisQuery.identity_selector is specified,
/// the identity in the result will be determined by the selector, and this
/// flag is not allowed to set. If true, the default max expansion per group
/// is 1000 for AssetService.AnalyzeIamPolicy\]\[\]. Default is false.
///
/// [analysisQuery_options_expandResources] - Optional. If true and
/// IamPolicyAnalysisQuery.resource_selector is not specified, the resource
/// section of the result will expand any resource attached to an IAM policy
/// to include resources lower in the resource hierarchy. For example, if the
/// request analyzes for which resources user A has permission P, and the
/// results include an IAM policy with P on a Google Cloud folder, the results
/// will also include resources in that folder with permission P. If true and
/// IamPolicyAnalysisQuery.resource_selector is specified, the resource
/// section of the result will expand the specified resource to include
/// resources lower in the resource hierarchy. Only project or lower resources
/// are supported. Folder and organization resources cannot be used together
/// with this option. For example, if the request analyzes for which users
/// have permission P on a Google Cloud project with this option enabled, the
/// results will include all users who have permission P on that project or
/// any lower resource. If true, the default max expansion per resource is
/// 1000 for AssetService.AnalyzeIamPolicy\]\[\] and 100000 for
/// AssetService.AnalyzeIamPolicyLongrunning\]\[\]. Default is false.
///
/// [analysisQuery_options_expandRoles] - Optional. If true, the access
/// section of result will expand any roles appearing in IAM policy bindings
/// to include their permissions. If IamPolicyAnalysisQuery.access_selector is
/// specified, the access section of the result will be determined by the
/// selector, and this flag is not allowed to set. Default is false.
///
/// [analysisQuery_options_outputGroupEdges] - Optional. If true, the result
/// will output the relevant membership relationships between groups and other
/// groups, and between groups and principals. Default is false.
///
/// [analysisQuery_options_outputResourceEdges] - Optional. If true, the
/// result will output the relevant parent/child relationships between
/// resources. Default is false.
///
/// [analysisQuery_resourceSelector_fullResourceName] - Required. The
/// [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// of a resource of
/// [supported resource types](https://cloud.google.com/asset-inventory/docs/supported-asset-types#analyzable_asset_types).
///
/// [executionTimeout] - Optional. Amount of time executable has to complete.
/// See JSON representation of
/// [Duration](https://developers.google.com/protocol-buffers/docs/proto3#json).
/// If this field is set with a value less than the RPC deadline, and the
/// execution of your query hasn't finished in the specified execution
/// timeout, you will get a response with partial result. Otherwise, your
/// query's execution will continue until the RPC deadline. If it's not
/// finished until then, you will get a DEADLINE_EXCEEDED error. Default is
/// empty.
///
/// [savedAnalysisQuery] - Optional. The name of a saved query, which must be
/// in the format of: * projects/project_number/savedQueries/saved_query_id *
/// folders/folder_number/savedQueries/saved_query_id *
/// organizations/organization_number/savedQueries/saved_query_id If both
/// `analysis_query` and `saved_analysis_query` are provided, they will be
/// merged together with the `saved_analysis_query` as base and the
/// `analysis_query` as overrides. For more details of the merge behavior,
/// refer to the
/// [MergeFrom](https://developers.google.com/protocol-buffers/docs/reference/cpp/google.protobuf.message#Message.MergeFrom.details)
/// page. Note that you cannot override primitive fields with default value,
/// such as 0 or empty string, etc., because we use proto3, which doesn't
/// support field presence yet.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [AnalyzeIamPolicyResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<AnalyzeIamPolicyResponse> analyzeIamPolicy(
core.String scope, {
core.List<core.String>? analysisQuery_accessSelector_permissions,
core.List<core.String>? analysisQuery_accessSelector_roles,
core.String? analysisQuery_conditionContext_accessTime,
core.String? analysisQuery_identitySelector_identity,
core.bool? analysisQuery_options_analyzeServiceAccountImpersonation,
core.bool? analysisQuery_options_expandGroups,
core.bool? analysisQuery_options_expandResources,
core.bool? analysisQuery_options_expandRoles,
core.bool? analysisQuery_options_outputGroupEdges,
core.bool? analysisQuery_options_outputResourceEdges,
core.String? analysisQuery_resourceSelector_fullResourceName,
core.String? executionTimeout,
core.String? savedAnalysisQuery,
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'analysisQuery.accessSelector.permissions':
?analysisQuery_accessSelector_permissions,
'analysisQuery.accessSelector.roles': ?analysisQuery_accessSelector_roles,
'analysisQuery.conditionContext.accessTime':
?analysisQuery_conditionContext_accessTime == null
? null
: [analysisQuery_conditionContext_accessTime],
'analysisQuery.identitySelector.identity':
?analysisQuery_identitySelector_identity == null
? null
: [analysisQuery_identitySelector_identity],
'analysisQuery.options.analyzeServiceAccountImpersonation':
?analysisQuery_options_analyzeServiceAccountImpersonation == null
? null
: ['${analysisQuery_options_analyzeServiceAccountImpersonation}'],
'analysisQuery.options.expandGroups':
?analysisQuery_options_expandGroups == null
? null
: ['${analysisQuery_options_expandGroups}'],
'analysisQuery.options.expandResources':
?analysisQuery_options_expandResources == null
? null
: ['${analysisQuery_options_expandResources}'],
'analysisQuery.options.expandRoles':
?analysisQuery_options_expandRoles == null
? null
: ['${analysisQuery_options_expandRoles}'],
'analysisQuery.options.outputGroupEdges':
?analysisQuery_options_outputGroupEdges == null
? null
: ['${analysisQuery_options_outputGroupEdges}'],
'analysisQuery.options.outputResourceEdges':
?analysisQuery_options_outputResourceEdges == null
? null
: ['${analysisQuery_options_outputResourceEdges}'],
'analysisQuery.resourceSelector.fullResourceName':
?analysisQuery_resourceSelector_fullResourceName == null
? null
: [analysisQuery_resourceSelector_fullResourceName],
'executionTimeout': ?executionTimeout == null ? null : [executionTimeout],
'savedAnalysisQuery': ?savedAnalysisQuery == null
? null
: [savedAnalysisQuery],
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$scope') + ':analyzeIamPolicy';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return AnalyzeIamPolicyResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Analyzes IAM policies asynchronously to answer which identities have what
/// accesses on which resources, and writes the analysis results to a Google
/// Cloud Storage or a BigQuery destination.
///
/// For Cloud Storage destination, the output format is the JSON format that
/// represents a AnalyzeIamPolicyResponse. This method implements the
/// google.longrunning.Operation, which allows you to track the operation
/// status. We recommend intervals of at least 2 seconds with exponential
/// backoff retry to poll the operation result. The metadata contains the
/// metadata for the long-running operation.
///
/// [request] - The metadata request object.
///
/// Request parameters:
///
/// [scope] - Required. The relative name of the root asset. Only resources
/// and IAM policies within the scope will be analyzed. This can only be an
/// organization number (such as "organizations/123"), a folder number (such
/// as "folders/123"), a project ID (such as "projects/my-project-id"), or a
/// project number (such as "projects/12345"). To know how to get organization
/// ID, visit
/// [here ](https://cloud.google.com/resource-manager/docs/creating-managing-organization#retrieving_your_organization_id).
/// To know how to get folder or project ID, visit
/// [here ](https://cloud.google.com/resource-manager/docs/creating-managing-folders#viewing_or_listing_folders_and_projects).
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [Operation].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<Operation> analyzeIamPolicyLongrunning(
AnalyzeIamPolicyLongrunningRequest request,
core.String scope, {
core.String? $fields,
}) async {
final body_ = convert.json.encode(request);
final queryParams_ = <core.String, core.List<core.String>>{
'fields': ?$fields == null ? null : [$fields],
};
final url_ =
'v1/' + core.Uri.encodeFull('$scope') + ':analyzeIamPolicyLongrunning';
final response_ = await _requester.request(
url_,
'POST',
body: body_,
queryParams: queryParams_,
);
return Operation.fromJson(response_ as core.Map<core.String, core.dynamic>);
}
/// Analyze moving a resource to a specified destination without kicking off
/// the actual move.
///
/// The analysis is best effort depending on the user's permissions of viewing
/// different hierarchical policies and configurations. The policies and
/// configuration are subject to change before the actual resource migration
/// takes place.
///
/// Request parameters:
///
/// [resource] - Required. Name of the resource to perform the analysis
/// against. Only Google Cloud projects are supported as of today. Hence, this
/// can only be a project ID (such as "projects/my-project-id") or a project
/// number (such as "projects/12345").
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [destinationParent] - Required. Name of the Google Cloud folder or
/// organization to reparent the target resource. The analysis will be
/// performed against hypothetically moving the resource to this specified
/// destination parent. This can only be a folder number (such as
/// "folders/123") or an organization number (such as "organizations/123").
///
/// [view] - Analysis view indicating what information should be included in
/// the analysis response. If unspecified, the default view is FULL.
/// Possible string values are:
/// - "ANALYSIS_VIEW_UNSPECIFIED" : The default/unset value. The API will
/// default to the FULL view.
/// - "FULL" : Full analysis including all level of impacts of the specified
/// resource move.
/// - "BASIC" : Basic analysis only including blockers which will prevent the
/// specified resource move at runtime.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [AnalyzeMoveResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<AnalyzeMoveResponse> analyzeMove(
core.String resource, {
core.String? destinationParent,
core.String? view,
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'destinationParent': ?destinationParent == null
? null
: [destinationParent],
'view': ?view == null ? null : [view],
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$resource') + ':analyzeMove';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return AnalyzeMoveResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Analyzes organization policies under a scope.
///
/// Request parameters:
///
/// [scope] - Required. The organization to scope the request. Only
/// organization policies within the scope will be analyzed. *
/// organizations/{ORGANIZATION_NUMBER} (e.g., "organizations/123456")
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [constraint] - Required. The name of the constraint to analyze
/// organization policies for. The response only contains analyzed
/// organization policies for the provided constraint.
///
/// [filter] - The expression to filter
/// AnalyzeOrgPoliciesResponse.org_policy_results. Filtering is currently
/// available for bare literal values and the following fields: *
/// consolidated_policy.attached_resource * consolidated_policy.rules.enforce
/// When filtering by a specific field, the only supported operator is `=`.
/// For example, filtering by
/// consolidated_policy.attached_resource="//cloudresourcemanager.googleapis.com/folders/001"
/// will return all the Organization Policy results attached to "folders/001".
///
/// [pageSize] - The maximum number of items to return per page. If
/// unspecified, AnalyzeOrgPoliciesResponse.org_policy_results will contain 20
/// items with a maximum of 200.
///
/// [pageToken] - The pagination token to retrieve the next page.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [AnalyzeOrgPoliciesResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<AnalyzeOrgPoliciesResponse> analyzeOrgPolicies(
core.String scope, {
core.String? constraint,
core.String? filter,
core.int? pageSize,
core.String? pageToken,
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'constraint': ?constraint == null ? null : [constraint],
'filter': ?filter == null ? null : [filter],
'pageSize': ?pageSize == null ? null : ['${pageSize}'],
'pageToken': ?pageToken == null ? null : [pageToken],
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$scope') + ':analyzeOrgPolicies';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return AnalyzeOrgPoliciesResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Analyzes organization policies governed assets (Google Cloud resources or
/// policies) under a scope.
///
/// This RPC supports custom constraints and the following canned constraints:
/// * constraints/ainotebooks.accessMode *
/// constraints/ainotebooks.disableFileDownloads *
/// constraints/ainotebooks.disableRootAccess *
/// constraints/ainotebooks.disableTerminal *
/// constraints/ainotebooks.environmentOptions *
/// constraints/ainotebooks.requireAutoUpgradeSchedule *
/// constraints/ainotebooks.restrictVpcNetworks *
/// constraints/compute.disableGuestAttributesAccess *
/// constraints/compute.disableInstanceDataAccessApis *
/// constraints/compute.disableNestedVirtualization *
/// constraints/compute.disableSerialPortAccess *
/// constraints/compute.disableSerialPortLogging *
/// constraints/compute.disableVpcExternalIpv6 *
/// constraints/compute.requireOsLogin * constraints/compute.requireShieldedVm
/// * constraints/compute.restrictLoadBalancerCreationForTypes *
/// constraints/compute.restrictProtocolForwardingCreationForTypes *
/// constraints/compute.restrictXpnProjectLienRemoval *
/// constraints/compute.setNewProjectDefaultToZonalDNSOnly *
/// constraints/compute.skipDefaultNetworkCreation *
/// constraints/compute.trustedImageProjects *
/// constraints/compute.vmCanIpForward *
/// constraints/compute.vmExternalIpAccess *
/// constraints/gcp.detailedAuditLoggingMode *
/// constraints/gcp.resourceLocations *
/// constraints/iam.allowedPolicyMemberDomains *
/// constraints/iam.automaticIamGrantsForDefaultServiceAccounts *
/// constraints/iam.disableServiceAccountCreation *
/// constraints/iam.disableServiceAccountKeyCreation *
/// constraints/iam.disableServiceAccountKeyUpload *
/// constraints/iam.restrictCrossProjectServiceAccountLienRemoval *
/// constraints/iam.serviceAccountKeyExpiryHours *
/// constraints/resourcemanager.accessBoundaries *
/// constraints/resourcemanager.allowedExportDestinations *
/// constraints/sql.restrictAuthorizedNetworks *
/// constraints/sql.restrictNoncompliantDiagnosticDataAccess *
/// constraints/sql.restrictNoncompliantResourceCreation *
/// constraints/sql.restrictPublicIp *
/// constraints/storage.publicAccessPrevention *
/// constraints/storage.restrictAuthTypes *
/// constraints/storage.uniformBucketLevelAccess This RPC only returns either
/// resources of types
/// [supported by search APIs](https://cloud.google.com/asset-inventory/docs/supported-asset-types)
/// or IAM policies.
///
/// Request parameters:
///
/// [scope] - Required. The organization to scope the request. Only
/// organization policies within the scope will be analyzed. The output assets
/// will also be limited to the ones governed by those in-scope organization
/// policies. * organizations/{ORGANIZATION_NUMBER} (e.g.,
/// "organizations/123456")
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [constraint] - Required. The name of the constraint to analyze governed
/// assets for. The analysis only contains analyzed organization policies for
/// the provided constraint.
///
/// [filter] - The expression to filter
/// AnalyzeOrgPolicyGovernedAssetsResponse.governed_assets. For governed
/// resources, filtering is currently available for bare literal values and
/// the following fields: * governed_resource.project *
/// governed_resource.folders * consolidated_policy.rules.enforce When
/// filtering by `governed_resource.project` or
/// `consolidated_policy.rules.enforce`, the only supported operator is `=`.
/// When filtering by `governed_resource.folders`, the supported operators are
/// `=` and `:`. For example, filtering by
/// `governed_resource.project="projects/12345678"` will return all the
/// governed resources under "projects/12345678", including the project itself
/// if applicable. For governed IAM policies, filtering is currently available
/// for bare literal values and the following fields: *
/// governed_iam_policy.project * governed_iam_policy.folders *
/// consolidated_policy.rules.enforce When filtering by
/// `governed_iam_policy.project` or `consolidated_policy.rules.enforce`, the
/// only supported operator is `=`. When filtering by
/// `governed_iam_policy.folders`, the supported operators are `=` and `:`.
/// For example, filtering by `governed_iam_policy.folders:"folders/12345678"`
/// will return all the governed IAM policies under "folders/001".
///
/// [pageSize] - The maximum number of items to return per page. If
/// unspecified, AnalyzeOrgPolicyGovernedAssetsResponse.governed_assets will
/// contain 100 items with a maximum of 200.
///
/// [pageToken] - The pagination token to retrieve the next page.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [AnalyzeOrgPolicyGovernedAssetsResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<AnalyzeOrgPolicyGovernedAssetsResponse>
analyzeOrgPolicyGovernedAssets(
core.String scope, {
core.String? constraint,
core.String? filter,
core.int? pageSize,
core.String? pageToken,
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'constraint': ?constraint == null ? null : [constraint],
'filter': ?filter == null ? null : [filter],
'pageSize': ?pageSize == null ? null : ['${pageSize}'],
'pageToken': ?pageToken == null ? null : [pageToken],
'fields': ?$fields == null ? null : [$fields],
};
final url_ =
'v1/' +
core.Uri.encodeFull('$scope') +
':analyzeOrgPolicyGovernedAssets';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return AnalyzeOrgPolicyGovernedAssetsResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Analyzes organization policies governed containers (projects, folders or
/// organization) under a scope.
///
/// Request parameters:
///
/// [scope] - Required. The organization to scope the request. Only
/// organization policies within the scope will be analyzed. The output
/// containers will also be limited to the ones governed by those in-scope
/// organization policies. * organizations/{ORGANIZATION_NUMBER} (e.g.,
/// "organizations/123456")
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [constraint] - Required. The name of the constraint to analyze governed
/// containers for. The analysis only contains organization policies for the
/// provided constraint.
///
/// [filter] - The expression to filter
/// AnalyzeOrgPolicyGovernedContainersResponse.governed_containers. Filtering
/// is currently available for bare literal values and the following fields: *
/// parent * consolidated_policy.rules.enforce When filtering by a specific
/// field, the only supported operator is `=`. For example, filtering by
/// parent="//cloudresourcemanager.googleapis.com/folders/001" will return all
/// the containers under "folders/001".
///
/// [pageSize] - The maximum number of items to return per page. If
/// unspecified,
/// AnalyzeOrgPolicyGovernedContainersResponse.governed_containers will
/// contain 100 items with a maximum of 200.
///
/// [pageToken] - The pagination token to retrieve the next page.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [AnalyzeOrgPolicyGovernedContainersResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<AnalyzeOrgPolicyGovernedContainersResponse>
analyzeOrgPolicyGovernedContainers(
core.String scope, {
core.String? constraint,
core.String? filter,
core.int? pageSize,
core.String? pageToken,
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'constraint': ?constraint == null ? null : [constraint],
'filter': ?filter == null ? null : [filter],
'pageSize': ?pageSize == null ? null : ['${pageSize}'],
'pageToken': ?pageToken == null ? null : [pageToken],
'fields': ?$fields == null ? null : [$fields],
};
final url_ =
'v1/' +
core.Uri.encodeFull('$scope') +
':analyzeOrgPolicyGovernedContainers';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return AnalyzeOrgPolicyGovernedContainersResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Batch gets the update history of assets that overlap a time window.
///
/// For IAM_POLICY content, this API outputs history when the asset and its
/// attached IAM POLICY both exist. This can create gaps in the output
/// history. Otherwise, this API outputs history with asset in both non-delete
/// or deleted status. If a specified asset does not exist, this API returns
/// an INVALID_ARGUMENT error.
///
/// Request parameters:
///
/// [parent] - Required. The relative name of the root asset. It can only be
/// an organization number (such as "organizations/123"), a project ID (such
/// as "projects/my-project-id")", or a project number (such as
/// "projects/12345").
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [assetNames] - A list of the full names of the assets. See:
/// https://cloud.google.com/asset-inventory/docs/resource-name-format
/// Example:
/// `//compute.googleapis.com/projects/my_project_123/zones/zone1/instances/instance1`.
/// The request becomes a no-op if the asset name list is empty, and the max
/// size of the asset name list is 100 in one request.
///
/// [contentType] - Optional. The content type.
/// Possible string values are:
/// - "CONTENT_TYPE_UNSPECIFIED" : Unspecified content type.
/// - "RESOURCE" : Resource metadata.
/// - "IAM_POLICY" : The actual IAM policy set on a resource.
/// - "ORG_POLICY" : The organization policy set on an asset.
/// - "ACCESS_POLICY" : The Access Context Manager policy set on an asset.
/// - "OS_INVENTORY" : The runtime OS Inventory information.
/// - "RELATIONSHIP" : The related resources.
///
/// [readTimeWindow_endTime] - End time of the time window (inclusive). If not
/// specified, the current timestamp is used instead.
///
/// [readTimeWindow_startTime] - Start time of the time window (exclusive).
///
/// [relationshipTypes] - Optional. A list of relationship types to output,
/// for example: `INSTANCE_TO_INSTANCEGROUP`. This field should only be
/// specified if content_type=RELATIONSHIP. * If specified: it outputs
/// specified relationships' history on the \[asset_names\]. It returns an
/// error if any of the \[relationship_types\] doesn't belong to the supported
/// relationship types of the \[asset_names\] or if any of the
/// \[asset_names\]'s types doesn't belong to the source types of the
/// \[relationship_types\]. * Otherwise: it outputs the supported
/// relationships' history on the \[asset_names\] or returns an error if any
/// of the \[asset_names\]'s types has no relationship support. See
/// [Introduction to Cloud Asset Inventory](https://cloud.google.com/asset-inventory/docs/overview)
/// for all supported asset types and relationship types.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [BatchGetAssetsHistoryResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<BatchGetAssetsHistoryResponse> batchGetAssetsHistory(
core.String parent, {
core.List<core.String>? assetNames,
core.String? contentType,
core.String? readTimeWindow_endTime,
core.String? readTimeWindow_startTime,
core.List<core.String>? relationshipTypes,
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'assetNames': ?assetNames,
'contentType': ?contentType == null ? null : [contentType],
'readTimeWindow.endTime': ?readTimeWindow_endTime == null
? null
: [readTimeWindow_endTime],
'readTimeWindow.startTime': ?readTimeWindow_startTime == null
? null
: [readTimeWindow_startTime],
'relationshipTypes': ?relationshipTypes,
'fields': ?$fields == null ? null : [$fields],
};
final url_ =
'v1/' + core.Uri.encodeFull('$parent') + ':batchGetAssetsHistory';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return BatchGetAssetsHistoryResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Exports assets with time and resource types to a given Cloud Storage
/// location/BigQuery table.
///
/// For Cloud Storage location destinations, the output format is
/// newline-delimited JSON. Each line represents a google.cloud.asset.v1.Asset
/// in the JSON format; for BigQuery table destinations, the output table
/// stores the fields in asset Protobuf as columns. This API implements the
/// google.longrunning.Operation API, which allows you to keep track of the
/// export. We recommend intervals of at least 2 seconds with exponential
/// retry to poll the export operation result. For regular-size resource
/// parent, the export operation usually finishes within 5 minutes.
///
/// [request] - The metadata request object.
///
/// Request parameters:
///
/// [parent] - Required. The relative name of the root asset. This can only be
/// an organization number (such as "organizations/123"), a project ID (such
/// as "projects/my-project-id"), or a project number (such as
/// "projects/12345"), or a folder number (such as "folders/123").
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [Operation].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<Operation> exportAssets(
ExportAssetsRequest request,
core.String parent, {
core.String? $fields,
}) async {
final body_ = convert.json.encode(request);
final queryParams_ = <core.String, core.List<core.String>>{
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$parent') + ':exportAssets';
final response_ = await _requester.request(
url_,
'POST',
body: body_,
queryParams: queryParams_,
);
return Operation.fromJson(response_ as core.Map<core.String, core.dynamic>);
}
/// Issue a job that queries assets using a SQL statement compatible with
/// [BigQuery SQL](https://cloud.google.com/bigquery/docs/introduction-sql).
///
/// If the query execution finishes within timeout and there's no pagination,
/// the full query results will be returned in the `QueryAssetsResponse`.
/// Otherwise, full query results can be obtained by issuing extra requests
/// with the `job_reference` from the a previous `QueryAssets` call. Note, the
/// query result has approximately 10 GB limitation enforced by
/// [BigQuery](https://cloud.google.com/bigquery/docs/best-practices-performance-output).
/// Queries return larger results will result in errors.
///
/// [request] - The metadata request object.
///
/// Request parameters:
///
/// [parent] - Required. The relative name of the root asset. This can only be
/// an organization number (such as "organizations/123"), a project ID (such
/// as "projects/my-project-id"), or a project number (such as
/// "projects/12345"), or a folder number (such as "folders/123"). Only assets
/// belonging to the `parent` will be returned.
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [QueryAssetsResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<QueryAssetsResponse> queryAssets(
QueryAssetsRequest request,
core.String parent, {
core.String? $fields,
}) async {
final body_ = convert.json.encode(request);
final queryParams_ = <core.String, core.List<core.String>>{
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$parent') + ':queryAssets';
final response_ = await _requester.request(
url_,
'POST',
body: body_,
queryParams: queryParams_,
);
return QueryAssetsResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Searches all IAM policies within the specified scope, such as a project,
/// folder, or organization.
///
/// The caller must be granted the `cloudasset.assets.searchAllIamPolicies`
/// permission on the desired scope, otherwise the request will be rejected.
///
/// Request parameters:
///
/// [scope] - Required. A scope can be a project, a folder, or an
/// organization. The search is limited to the IAM policies within the
/// `scope`. The caller must be granted the
/// \[`cloudasset.assets.searchAllIamPolicies`\](https://cloud.google.com/asset-inventory/docs/access-control#required_permissions)
/// permission on the desired scope. The allowed values are: *
/// projects/{PROJECT_ID} (e.g., "projects/foo-bar") *
/// projects/{PROJECT_NUMBER} (e.g., "projects/12345678") *
/// folders/{FOLDER_NUMBER} (e.g., "folders/1234567") *
/// organizations/{ORGANIZATION_NUMBER} (e.g., "organizations/123456")
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [assetTypes] - Optional. A list of asset types that the IAM policies are
/// attached to. If empty, it will search the IAM policies that are attached
/// to all the asset types
/// [supported by search APIs](https://cloud.google.com/asset-inventory/docs/supported-asset-types)
/// Regular expressions are also supported. For example: *
/// "compute.googleapis.com.*" snapshots IAM policies attached to asset type
/// starts with "compute.googleapis.com". * ".*Instance" snapshots IAM
/// policies attached to asset type ends with "Instance". * ".*Instance.*"
/// snapshots IAM policies attached to asset type contains "Instance". See
/// [RE2](https://github.com/google/re2/wiki/Syntax) for all supported regular
/// expression syntax. If the regular expression does not match any supported
/// asset type, an INVALID_ARGUMENT error will be returned.
///
/// [orderBy] - Optional. A comma-separated list of fields specifying the
/// sorting order of the results. The default order is ascending. Add " DESC"
/// after the field name to indicate descending order. Redundant space
/// characters are ignored. Example: "assetType DESC, resource". Only singular
/// primitive fields in the response are sortable: * resource * assetType *
/// project All the other fields such as repeated fields (e.g., `folders`) and
/// non-primitive fields (e.g., `policy`) are not supported.
///
/// [pageSize] - Optional. The page size for search result pagination. Page
/// size is capped at 500 even if a larger value is given. If set to zero or a
/// negative value, server will pick an appropriate default. Returned results
/// may be fewer than requested. When this happens, there could be more
/// results as long as `next_page_token` is returned.
///
/// [pageToken] - Optional. If present, retrieve the next batch of results
/// from the preceding call to this method. `page_token` must be the value of
/// `next_page_token` from the previous response. The values of all other
/// method parameters must be identical to those in the previous call.
///
/// [query] - Optional. The query statement. See
/// [how to construct a query](https://cloud.google.com/asset-inventory/docs/searching-iam-policies#how_to_construct_a_query)
/// for more information. If not specified or empty, it will search all the
/// IAM policies within the specified `scope`. Note that the query string is
/// compared against each IAM policy binding, including its principals, roles,
/// and IAM conditions. The returned IAM policies will only contain the
/// bindings that match your query. To learn more about the IAM policy
/// structure, see the
/// [IAM policy documentation](https://cloud.google.com/iam/help/allow-policies/structure).
/// Examples: * `policy:amy@gmail.com` to find IAM policy bindings that
/// specify user "amy@gmail.com". * `policy:roles/compute.admin` to find IAM
/// policy bindings that specify the Compute Admin role. * `policy:comp*` to
/// find IAM policy bindings that contain "comp" as a prefix of any word in
/// the binding. * `policy.role.permissions:storage.buckets.update` to find
/// IAM policy bindings that specify a role containing
/// "storage.buckets.update" permission. Note that if callers don't have
/// `iam.roles.get` access to a role's included permissions, policy bindings
/// that specify this role will be dropped from the search results. *
/// `policy.role.permissions:upd*` to find IAM policy bindings that specify a
/// role containing "upd" as a prefix of any word in the role permission. Note
/// that if callers don't have `iam.roles.get` access to a role's included
/// permissions, policy bindings that specify this role will be dropped from
/// the search results. * `resource:organizations/123456` to find IAM policy
/// bindings that are set on "organizations/123456". *
/// `resource=//cloudresourcemanager.googleapis.com/projects/myproject` to
/// find IAM policy bindings that are set on the project named "myproject". *
/// `Important` to find IAM policy bindings that contain "Important" as a word
/// in any of the searchable fields (except for the included permissions). *
/// `resource:(instance1 OR instance2) policy:amy` to find IAM policy bindings
/// that are set on resources "instance1" or "instance2" and also specify user
/// "amy". * `roles:roles/compute.admin` to find IAM policy bindings that
/// specify the Compute Admin role. * `memberTypes:user` to find IAM policy
/// bindings that contain the principal type "user".
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [SearchAllIamPoliciesResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<SearchAllIamPoliciesResponse> searchAllIamPolicies(
core.String scope, {
core.List<core.String>? assetTypes,
core.String? orderBy,
core.int? pageSize,
core.String? pageToken,
core.String? query,
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'assetTypes': ?assetTypes,
'orderBy': ?orderBy == null ? null : [orderBy],
'pageSize': ?pageSize == null ? null : ['${pageSize}'],
'pageToken': ?pageToken == null ? null : [pageToken],
'query': ?query == null ? null : [query],
'fields': ?$fields == null ? null : [$fields],
};
final url_ =
'v1/' + core.Uri.encodeFull('$scope') + ':searchAllIamPolicies';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return SearchAllIamPoliciesResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
/// Searches all Google Cloud resources within the specified scope, such as a
/// project, folder, or organization.
///
/// The caller must be granted the `cloudasset.assets.searchAllResources`
/// permission on the desired scope, otherwise the request will be rejected.
///
/// Request parameters:
///
/// [scope] - Required. A scope can be a project, a folder, or an
/// organization. The search is limited to the resources within the `scope`.
/// The caller must be granted the
/// \[`cloudasset.assets.searchAllResources`\](https://cloud.google.com/asset-inventory/docs/access-control#required_permissions)
/// permission on the desired scope. The allowed values are: *
/// projects/{PROJECT_ID} (e.g., "projects/foo-bar") *
/// projects/{PROJECT_NUMBER} (e.g., "projects/12345678") *
/// folders/{FOLDER_NUMBER} (e.g., "folders/1234567") *
/// organizations/{ORGANIZATION_NUMBER} (e.g., "organizations/123456")
/// Value must have pattern `^\[^/\]+/\[^/\]+$`.
///
/// [assetTypes] - Optional. A list of asset types that this request searches
/// for. If empty, it will search all the asset types
/// [supported by search APIs](https://cloud.google.com/asset-inventory/docs/supported-asset-types).
/// Regular expressions are also supported. For example: *
/// "compute.googleapis.com.*" snapshots resources whose asset type starts
/// with "compute.googleapis.com". * ".*Instance" snapshots resources whose
/// asset type ends with "Instance". * ".*Instance.*" snapshots resources
/// whose asset type contains "Instance". See
/// [RE2](https://github.com/google/re2/wiki/Syntax) for all supported regular
/// expression syntax. If the regular expression does not match any supported
/// asset type, an INVALID_ARGUMENT error will be returned.
///
/// [orderBy] - Optional. A comma-separated list of fields specifying the
/// sorting order of the results. The default order is ascending. Add " DESC"
/// after the field name to indicate descending order. Redundant space
/// characters are ignored. Example: "location DESC, name". Only the following
/// fields in the response are sortable: * name * assetType * project *
/// displayName * description * location * createTime * updateTime * state *
/// parentFullResourceName * parentAssetType
///
/// [pageSize] - Optional. The page size for search result pagination. Page
/// size is capped at 500 even if a larger value is given. If set to zero or a
/// negative value, server will pick an appropriate default. Returned results
/// may be fewer than requested. When this happens, there could be more
/// results as long as `next_page_token` is returned.
///
/// [pageToken] - Optional. If present, then retrieve the next batch of
/// results from the preceding call to this method. `page_token` must be the
/// value of `next_page_token` from the previous response. The values of all
/// other method parameters, must be identical to those in the previous call.
///
/// [query] - Optional. The query statement. See
/// [how to construct a query](https://cloud.google.com/asset-inventory/docs/searching-resources#how_to_construct_a_query)
/// for more information. If not specified or empty, it will search all the
/// resources within the specified `scope`. Examples: * `name:Important` to
/// find Google Cloud resources whose name contains `Important` as a word. *
/// `name=Important` to find the Google Cloud resource whose name is exactly
/// `Important`. * `displayName:Impor*` to find Google Cloud resources whose
/// display name contains `Impor` as a prefix of any word in the field. *
/// `location:us-west*` to find Google Cloud resources whose location contains
/// both `us` and `west` as prefixes. * `labels:prod` to find Google Cloud
/// resources whose labels contain `prod` as a key or value. *
/// `labels.env:prod` to find Google Cloud resources that have a label `env`
/// and its value is `prod`. * `labels.env:*` to find Google Cloud resources
/// that have a label `env`. * `tagKeys:env` to find Google Cloud resources
/// that have directly attached tags where the
/// \[`TagKey.namespacedName`\](https://cloud.google.com/resource-manager/reference/rest/v3/tagKeys#resource:-tagkey)
/// contains `env`. * `tagValues:prod*` to find Google Cloud resources that
/// have directly attached tags where the
/// \[`TagValue.namespacedName`\](https://cloud.google.com/resource-manager/reference/rest/v3/tagValues#resource:-tagvalue)
/// contains a word prefixed by `prod`. * `tagValueIds=tagValues/123` to find
/// Google Cloud resources that have directly attached tags where the
/// \[`TagValue.name`\](https://cloud.google.com/resource-manager/reference/rest/v3/tagValues#resource:-tagvalue)
/// is exactly `tagValues/123`. * `effectiveTagKeys:env` to find Google Cloud
/// resources that have directly attached or inherited tags where the
/// \[`TagKey.namespacedName`\](https://cloud.google.com/resource-manager/reference/rest/v3/tagKeys#resource:-tagkey)
/// contains `env`. * `effectiveTagValues:prod*` to find Google Cloud
/// resources that have directly attached or inherited tags where the
/// \[`TagValue.namespacedName`\](https://cloud.google.com/resource-manager/reference/rest/v3/tagValues#resource:-tagvalue)
/// contains a word prefixed by `prod`. * `effectiveTagValueIds=tagValues/123`
/// to find Google Cloud resources that have directly attached or inherited
/// tags where the
/// \[`TagValue.name`\](https://cloud.google.com/resource-manager/reference/rest/v3/tagValues#resource:-tagvalue)
/// is exactly `tagValues/123`. * `kmsKey:key` to find Google Cloud resources
/// encrypted with a customer-managed encryption key whose name contains `key`
/// as a word. This field is deprecated. Use the `kmsKeys` field to retrieve
/// Cloud KMS key information. * `kmsKeys:key` to find Google Cloud resources
/// encrypted with customer-managed encryption keys whose name contains the
/// word `key`. * `relationships:instance-group-1` to find Google Cloud
/// resources that have relationships with `instance-group-1` in the related
/// resource name. * `relationships:INSTANCE_TO_INSTANCEGROUP` to find Compute
/// Engine instances that have relationships of type
/// `INSTANCE_TO_INSTANCEGROUP`. *
/// `relationships.INSTANCE_TO_INSTANCEGROUP:instance-group-1` to find Compute
/// Engine instances that have relationships with `instance-group-1` in the
/// Compute Engine instance group resource name, for relationship type
/// `INSTANCE_TO_INSTANCEGROUP`. * `sccSecurityMarks.key=value` to find Cloud
/// resources that are attached with security marks whose key is `key` and
/// value is `value`. * `sccSecurityMarks.key:*` to find Cloud resources that
/// are attached with security marks whose key is `key`. * `state:ACTIVE` to
/// find Google Cloud resources whose state contains `ACTIVE` as a word. *
/// `NOT state:ACTIVE` to find Google Cloud resources whose state doesn't
/// contain `ACTIVE` as a word. * `createTime<1609459200` to find Google Cloud
/// resources that were created before `2021-01-01 00:00:00 UTC`. `1609459200`
/// is the epoch timestamp of `2021-01-01 00:00:00 UTC` in seconds. *
/// `updateTime>1609459200` to find Google Cloud resources that were updated
/// after `2021-01-01 00:00:00 UTC`. `1609459200` is the epoch timestamp of
/// `2021-01-01 00:00:00 UTC` in seconds. * `Important` to find Google Cloud
/// resources that contain `Important` as a word in any of the searchable
/// fields. * `Impor*` to find Google Cloud resources that contain `Impor` as
/// a prefix of any word in any of the searchable fields. * `Important
/// location:(us-west1 OR global)` to find Google Cloud resources that contain
/// `Important` as a word in any of the searchable fields and are also located
/// in the `us-west1` region or the `global` location.
///
/// [readMask] - Optional. A comma-separated list of fields that you want
/// returned in the results. The following fields are returned by default if
/// not specified: * `name` * `assetType` * `project` * `folders` *
/// `organization` * `displayName` * `description` * `location` * `labels` *
/// `tags` * `effectiveTags` * `networkTags` * `kmsKeys` * `createTime` *
/// `updateTime` * `state` * `additionalAttributes` * `parentFullResourceName`
/// * `parentAssetType` Some fields of large size, such as
/// `versionedResources`, `attachedResources`, `effectiveTags` etc., are not
/// returned by default, but you can specify them in the `read_mask` parameter
/// if you want to include them. If `"*"` is specified, all
/// [available fields](https://cloud.google.com/asset-inventory/docs/reference/rest/v1/TopLevel/searchAllResources#resourcesearchresult)
/// are returned. Examples: `"name,location"`, `"name,versionedResources"`,
/// `"*"`. Any invalid field path will trigger INVALID_ARGUMENT error.
///
/// [$fields] - Selector specifying which fields to include in a partial
/// response.
///
/// Completes with a [SearchAllResourcesResponse].
///
/// Completes with a [commons.ApiRequestError] if the API endpoint returned an
/// error.
///
/// If the used [http.Client] completes with an error when making a REST call,
/// this method will complete with the same error.
async.Future<SearchAllResourcesResponse> searchAllResources(
core.String scope, {
core.List<core.String>? assetTypes,
core.String? orderBy,
core.int? pageSize,
core.String? pageToken,
core.String? query,
core.String? readMask,
core.String? $fields,
}) async {
final queryParams_ = <core.String, core.List<core.String>>{
'assetTypes': ?assetTypes,
'orderBy': ?orderBy == null ? null : [orderBy],
'pageSize': ?pageSize == null ? null : ['${pageSize}'],
'pageToken': ?pageToken == null ? null : [pageToken],
'query': ?query == null ? null : [query],
'readMask': ?readMask == null ? null : [readMask],
'fields': ?$fields == null ? null : [$fields],
};
final url_ = 'v1/' + core.Uri.encodeFull('$scope') + ':searchAllResources';
final response_ = await _requester.request(
url_,
'GET',
queryParams: queryParams_,
);
return SearchAllResourcesResponse.fromJson(
response_ as core.Map<core.String, core.dynamic>,
);
}
}
/// Specifies roles and/or permissions to analyze, to determine both the
/// identities possessing them and the resources they control.
///
/// If multiple values are specified, results will include roles or permissions
/// matching any of them. The total number of roles and permissions should be
/// equal or less than 10.
class AccessSelector {
/// The permissions to appear in result.
///
/// Optional.
core.List<core.String>? permissions;
/// The roles to appear in result.
///
/// Optional.
core.List<core.String>? roles;
AccessSelector({this.permissions, this.roles});
AccessSelector.fromJson(core.Map json_)
: this(
permissions: (json_['permissions'] as core.List?)
?.map((value) => value as core.String)
.toList(),
roles: (json_['roles'] as core.List?)
?.map((value) => value as core.String)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final permissions = this.permissions;
final roles = this.roles;
return {'permissions': ?permissions, 'roles': ?roles};
}
}
/// A request message for AssetService.AnalyzeIamPolicyLongrunning.
class AnalyzeIamPolicyLongrunningRequest {
/// The request query.
///
/// Required.
IamPolicyAnalysisQuery? analysisQuery;
/// Output configuration indicating where the results will be output to.
///
/// Required.
IamPolicyAnalysisOutputConfig? outputConfig;
/// The name of a saved query, which must be in the format of: *
/// projects/project_number/savedQueries/saved_query_id *
/// folders/folder_number/savedQueries/saved_query_id *
/// organizations/organization_number/savedQueries/saved_query_id If both
/// `analysis_query` and `saved_analysis_query` are provided, they will be
/// merged together with the `saved_analysis_query` as base and the
/// `analysis_query` as overrides.
///
/// For more details of the merge behavior, refer to the
/// [MergeFrom](https://developers.google.com/protocol-buffers/docs/reference/cpp/google.protobuf.message#Message.MergeFrom.details)
/// doc. Note that you cannot override primitive fields with default value,
/// such as 0 or empty string, etc., because we use proto3, which doesn't
/// support field presence yet.
///
/// Optional.
core.String? savedAnalysisQuery;
AnalyzeIamPolicyLongrunningRequest({
this.analysisQuery,
this.outputConfig,
this.savedAnalysisQuery,
});
AnalyzeIamPolicyLongrunningRequest.fromJson(core.Map json_)
: this(
analysisQuery: json_.containsKey('analysisQuery')
? IamPolicyAnalysisQuery.fromJson(
json_['analysisQuery'] as core.Map<core.String, core.dynamic>,
)
: null,
outputConfig: json_.containsKey('outputConfig')
? IamPolicyAnalysisOutputConfig.fromJson(
json_['outputConfig'] as core.Map<core.String, core.dynamic>,
)
: null,
savedAnalysisQuery: json_['savedAnalysisQuery'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final analysisQuery = this.analysisQuery;
final outputConfig = this.outputConfig;
final savedAnalysisQuery = this.savedAnalysisQuery;
return {
'analysisQuery': ?analysisQuery,
'outputConfig': ?outputConfig,
'savedAnalysisQuery': ?savedAnalysisQuery,
};
}
}
/// A response message for AssetService.AnalyzeIamPolicy.
class AnalyzeIamPolicyResponse {
/// Represents whether all entries in the main_analysis and
/// service_account_impersonation_analysis have been fully explored to answer
/// the query in the request.
core.bool? fullyExplored;
/// The main analysis that matches the original request.
IamPolicyAnalysis? mainAnalysis;
/// The service account impersonation analysis if
/// IamPolicyAnalysisQuery.Options.analyze_service_account_impersonation is
/// enabled.
core.List<IamPolicyAnalysis>? serviceAccountImpersonationAnalysis;
AnalyzeIamPolicyResponse({
this.fullyExplored,
this.mainAnalysis,
this.serviceAccountImpersonationAnalysis,
});
AnalyzeIamPolicyResponse.fromJson(core.Map json_)
: this(
fullyExplored: json_['fullyExplored'] as core.bool?,
mainAnalysis: json_.containsKey('mainAnalysis')
? IamPolicyAnalysis.fromJson(
json_['mainAnalysis'] as core.Map<core.String, core.dynamic>,
)
: null,
serviceAccountImpersonationAnalysis:
(json_['serviceAccountImpersonationAnalysis'] as core.List?)
?.map(
(value) => IamPolicyAnalysis.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final fullyExplored = this.fullyExplored;
final mainAnalysis = this.mainAnalysis;
final serviceAccountImpersonationAnalysis =
this.serviceAccountImpersonationAnalysis;
return {
'fullyExplored': ?fullyExplored,
'mainAnalysis': ?mainAnalysis,
'serviceAccountImpersonationAnalysis':
?serviceAccountImpersonationAnalysis,
};
}
}
/// The response message for resource move analysis.
class AnalyzeMoveResponse {
/// The list of analyses returned from performing the intended resource move
/// analysis.
///
/// The analysis is grouped by different Google Cloud services.
core.List<MoveAnalysis>? moveAnalysis;
AnalyzeMoveResponse({this.moveAnalysis});
AnalyzeMoveResponse.fromJson(core.Map json_)
: this(
moveAnalysis: (json_['moveAnalysis'] as core.List?)
?.map(
(value) => MoveAnalysis.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final moveAnalysis = this.moveAnalysis;
return {'moveAnalysis': ?moveAnalysis};
}
}
/// The response message for AssetService.AnalyzeOrgPolicies.
class AnalyzeOrgPoliciesResponse {
/// The definition of the constraint in the request.
AnalyzerOrgPolicyConstraint? constraint;
/// The page token to fetch the next page for
/// AnalyzeOrgPoliciesResponse.org_policy_results.
core.String? nextPageToken;
/// The organization policies under the AnalyzeOrgPoliciesRequest.scope with
/// the AnalyzeOrgPoliciesRequest.constraint.
core.List<OrgPolicyResult>? orgPolicyResults;
AnalyzeOrgPoliciesResponse({
this.constraint,
this.nextPageToken,
this.orgPolicyResults,
});
AnalyzeOrgPoliciesResponse.fromJson(core.Map json_)
: this(
constraint: json_.containsKey('constraint')
? AnalyzerOrgPolicyConstraint.fromJson(
json_['constraint'] as core.Map<core.String, core.dynamic>,
)
: null,
nextPageToken: json_['nextPageToken'] as core.String?,
orgPolicyResults: (json_['orgPolicyResults'] as core.List?)
?.map(
(value) => OrgPolicyResult.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final constraint = this.constraint;
final nextPageToken = this.nextPageToken;
final orgPolicyResults = this.orgPolicyResults;
return {
'constraint': ?constraint,
'nextPageToken': ?nextPageToken,
'orgPolicyResults': ?orgPolicyResults,
};
}
}
/// The response message for AssetService.AnalyzeOrgPolicyGovernedAssets.
class AnalyzeOrgPolicyGovernedAssetsResponse {
/// The definition of the constraint in the request.
AnalyzerOrgPolicyConstraint? constraint;
/// The list of the analyzed governed assets.
core.List<
GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedAsset
>?
governedAssets;
/// The page token to fetch the next page for
/// AnalyzeOrgPolicyGovernedAssetsResponse.governed_assets.
core.String? nextPageToken;
AnalyzeOrgPolicyGovernedAssetsResponse({
this.constraint,
this.governedAssets,
this.nextPageToken,
});
AnalyzeOrgPolicyGovernedAssetsResponse.fromJson(core.Map json_)
: this(
constraint: json_.containsKey('constraint')
? AnalyzerOrgPolicyConstraint.fromJson(
json_['constraint'] as core.Map<core.String, core.dynamic>,
)
: null,
governedAssets: (json_['governedAssets'] as core.List?)
?.map(
(value) =>
GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedAsset.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
nextPageToken: json_['nextPageToken'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final constraint = this.constraint;
final governedAssets = this.governedAssets;
final nextPageToken = this.nextPageToken;
return {
'constraint': ?constraint,
'governedAssets': ?governedAssets,
'nextPageToken': ?nextPageToken,
};
}
}
/// The response message for AssetService.AnalyzeOrgPolicyGovernedContainers.
class AnalyzeOrgPolicyGovernedContainersResponse {
/// The definition of the constraint in the request.
AnalyzerOrgPolicyConstraint? constraint;
/// The list of the analyzed governed containers.
core.List<GoogleCloudAssetV1GovernedContainer>? governedContainers;
/// The page token to fetch the next page for
/// AnalyzeOrgPolicyGovernedContainersResponse.governed_containers.
core.String? nextPageToken;
AnalyzeOrgPolicyGovernedContainersResponse({
this.constraint,
this.governedContainers,
this.nextPageToken,
});
AnalyzeOrgPolicyGovernedContainersResponse.fromJson(core.Map json_)
: this(
constraint: json_.containsKey('constraint')
? AnalyzerOrgPolicyConstraint.fromJson(
json_['constraint'] as core.Map<core.String, core.dynamic>,
)
: null,
governedContainers: (json_['governedContainers'] as core.List?)
?.map(
(value) => GoogleCloudAssetV1GovernedContainer.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
nextPageToken: json_['nextPageToken'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final constraint = this.constraint;
final governedContainers = this.governedContainers;
final nextPageToken = this.nextPageToken;
return {
'constraint': ?constraint,
'governedContainers': ?governedContainers,
'nextPageToken': ?nextPageToken,
};
}
}
/// This organization policy message is a modified version of the one defined in
/// the Organization Policy system.
///
/// This message contains several fields defined in the original organization
/// policy with some new fields for analysis purpose.
class AnalyzerOrgPolicy {
/// The
/// [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// of an organization/folder/project resource where this organization policy
/// applies to.
///
/// For any user defined org policies, this field has the same value as the
/// \[attached_resource\] field. Only for default policy, this field has the
/// different value.
core.String? appliedResource;
/// The
/// [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// of an organization/folder/project resource where this organization policy
/// is set.
///
/// Notice that some type of constraints are defined with default policy. This
/// field will be empty for them.
core.String? attachedResource;
/// If `inherit_from_parent` is true, Rules set higher up in the hierarchy (up
/// to the closest root) are inherited and present in the effective policy.
///
/// If it is false, then no rules are inherited, and this policy becomes the
/// effective root for evaluation.
core.bool? inheritFromParent;
/// Ignores policies set above this resource and restores the default behavior
/// of the constraint at this resource.
///
/// This field can be set in policies for either list or boolean constraints.
/// If set, `rules` must be empty and `inherit_from_parent` must be set to
/// false.
core.bool? reset;
/// List of rules for this organization policy.
core.List<GoogleCloudAssetV1Rule>? rules;
AnalyzerOrgPolicy({
this.appliedResource,
this.attachedResource,
this.inheritFromParent,
this.reset,
this.rules,
});
AnalyzerOrgPolicy.fromJson(core.Map json_)
: this(
appliedResource: json_['appliedResource'] as core.String?,
attachedResource: json_['attachedResource'] as core.String?,
inheritFromParent: json_['inheritFromParent'] as core.bool?,
reset: json_['reset'] as core.bool?,
rules: (json_['rules'] as core.List?)
?.map(
(value) => GoogleCloudAssetV1Rule.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final appliedResource = this.appliedResource;
final attachedResource = this.attachedResource;
final inheritFromParent = this.inheritFromParent;
final reset = this.reset;
final rules = this.rules;
return {
'appliedResource': ?appliedResource,
'attachedResource': ?attachedResource,
'inheritFromParent': ?inheritFromParent,
'reset': ?reset,
'rules': ?rules,
};
}
}
/// The organization policy constraint definition.
class AnalyzerOrgPolicyConstraint {
/// The definition of the custom constraint.
GoogleCloudAssetV1CustomConstraint? customConstraint;
/// The definition of the canned constraint defined by Google.
GoogleCloudAssetV1Constraint? googleDefinedConstraint;
AnalyzerOrgPolicyConstraint({
this.customConstraint,
this.googleDefinedConstraint,
});
AnalyzerOrgPolicyConstraint.fromJson(core.Map json_)
: this(
customConstraint: json_.containsKey('customConstraint')
? GoogleCloudAssetV1CustomConstraint.fromJson(
json_['customConstraint']
as core.Map<core.String, core.dynamic>,
)
: null,
googleDefinedConstraint: json_.containsKey('googleDefinedConstraint')
? GoogleCloudAssetV1Constraint.fromJson(
json_['googleDefinedConstraint']
as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final customConstraint = this.customConstraint;
final googleDefinedConstraint = this.googleDefinedConstraint;
return {
'customConstraint': ?customConstraint,
'googleDefinedConstraint': ?googleDefinedConstraint,
};
}
}
/// An asset in Google Cloud.
///
/// An asset can be any resource in the Google Cloud
/// [resource hierarchy](https://cloud.google.com/resource-manager/docs/cloud-platform-resource-hierarchy),
/// a resource outside the Google Cloud resource hierarchy (such as Google
/// Kubernetes Engine clusters and objects), or a policy (e.g. IAM policy), or a
/// relationship (e.g. an INSTANCE_TO_INSTANCEGROUP relationship). See
/// [Supported asset types](https://cloud.google.com/asset-inventory/docs/supported-asset-types)
/// for more information.
class Asset {
/// Also refer to the
/// [access level user guide](https://cloud.google.com/access-context-manager/docs/overview#access-levels).
GoogleIdentityAccesscontextmanagerV1AccessLevel? accessLevel;
/// Also refer to the
/// [access policy user guide](https://cloud.google.com/access-context-manager/docs/overview#access-policies).
GoogleIdentityAccesscontextmanagerV1AccessPolicy? accessPolicy;
/// The ancestry path of an asset in Google Cloud
/// [resource hierarchy](https://cloud.google.com/resource-manager/docs/cloud-platform-resource-hierarchy),
/// represented as a list of relative resource names.
///
/// An ancestry path starts with the closest ancestor in the hierarchy and
/// ends at root. If the asset is a project, folder, or organization, the
/// ancestry path starts from the asset itself. Example:
/// `["projects/123456789", "folders/5432", "organizations/1234"]`
core.List<core.String>? ancestors;
/// The exceptions of a resource.
core.List<AssetException>? assetExceptions;
/// The type of the asset.
///
/// Example: `compute.googleapis.com/Disk` See
/// [Supported asset types](https://cloud.google.com/asset-inventory/docs/supported-asset-types)
/// for more information.
core.String? assetType;
/// A representation of the IAM policy set on a Google Cloud resource.
///
/// There can be a maximum of one IAM policy set on any given resource. In
/// addition, IAM policies inherit their granted access scope from any
/// policies set on parent resources in the resource hierarchy. Therefore, the
/// effectively policy is the union of both the policy set on this resource
/// and each policy set on all of the resource's ancestry resource levels in
/// the hierarchy. See
/// [this topic](https://cloud.google.com/iam/help/allow-policies/inheritance)
/// for more information.
Policy? iamPolicy;
/// The full name of the asset.
///
/// Example:
/// `//compute.googleapis.com/projects/my_project_123/zones/zone1/instances/instance1`
/// See
/// [Resource names](https://cloud.google.com/apis/design/resource_names#full_resource_name)
/// for more information.
core.String? name;
/// A representation of an
/// [organization policy](https://cloud.google.com/resource-manager/docs/organization-policy/overview#organization_policy).
///
/// There can be more than one organization policy with different constraints
/// set on a given resource.
core.List<GoogleCloudOrgpolicyV1Policy>? orgPolicy;
/// A representation of runtime OS Inventory information.
///
/// See
/// [this topic](https://cloud.google.com/compute/docs/instances/os-inventory-management)
/// for more information.
Inventory? osInventory;
/// One related asset of the current asset.
RelatedAsset? relatedAsset;
/// This field only presents for the purpose of backward-compatibility.
///
/// The server will never generate responses with this field. The related
/// assets of the asset of one relationship type. One asset only represents
/// one type of relationship.
///
/// Deprecated.
@core.Deprecated(
'Not supported. Member documentation may have more information.',
)
RelatedAssets? relatedAssets;
/// A representation of the resource.
Resource? resource;
/// Also refer to the
/// [service perimeter user guide](https://cloud.google.com/vpc-service-controls/docs/overview).
GoogleIdentityAccesscontextmanagerV1ServicePerimeter? servicePerimeter;
/// The last update timestamp of an asset.
///
/// update_time is updated when create/update/delete operation is performed.
core.String? updateTime;
Asset({
this.accessLevel,
this.accessPolicy,
this.ancestors,
this.assetExceptions,
this.assetType,
this.iamPolicy,
this.name,
this.orgPolicy,
this.osInventory,
this.relatedAsset,
this.relatedAssets,
this.resource,
this.servicePerimeter,
this.updateTime,
});
Asset.fromJson(core.Map json_)
: this(
accessLevel: json_.containsKey('accessLevel')
? GoogleIdentityAccesscontextmanagerV1AccessLevel.fromJson(
json_['accessLevel'] as core.Map<core.String, core.dynamic>,
)
: null,
accessPolicy: json_.containsKey('accessPolicy')
? GoogleIdentityAccesscontextmanagerV1AccessPolicy.fromJson(
json_['accessPolicy'] as core.Map<core.String, core.dynamic>,
)
: null,
ancestors: (json_['ancestors'] as core.List?)
?.map((value) => value as core.String)
.toList(),
assetExceptions: (json_['assetExceptions'] as core.List?)
?.map(
(value) => AssetException.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
assetType: json_['assetType'] as core.String?,
iamPolicy: json_.containsKey('iamPolicy')
? Policy.fromJson(
json_['iamPolicy'] as core.Map<core.String, core.dynamic>,
)
: null,
name: json_['name'] as core.String?,
orgPolicy: (json_['orgPolicy'] as core.List?)
?.map(
(value) => GoogleCloudOrgpolicyV1Policy.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
osInventory: json_.containsKey('osInventory')
? Inventory.fromJson(
json_['osInventory'] as core.Map<core.String, core.dynamic>,
)
: null,
relatedAsset: json_.containsKey('relatedAsset')
? RelatedAsset.fromJson(
json_['relatedAsset'] as core.Map<core.String, core.dynamic>,
)
: null,
relatedAssets: json_.containsKey('relatedAssets')
? RelatedAssets.fromJson(
json_['relatedAssets'] as core.Map<core.String, core.dynamic>,
)
: null,
resource: json_.containsKey('resource')
? Resource.fromJson(
json_['resource'] as core.Map<core.String, core.dynamic>,
)
: null,
servicePerimeter: json_.containsKey('servicePerimeter')
? GoogleIdentityAccesscontextmanagerV1ServicePerimeter.fromJson(
json_['servicePerimeter']
as core.Map<core.String, core.dynamic>,
)
: null,
updateTime: json_['updateTime'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final accessLevel = this.accessLevel;
final accessPolicy = this.accessPolicy;
final ancestors = this.ancestors;
final assetExceptions = this.assetExceptions;
final assetType = this.assetType;
final iamPolicy = this.iamPolicy;
final name = this.name;
final orgPolicy = this.orgPolicy;
final osInventory = this.osInventory;
final relatedAsset = this.relatedAsset;
final relatedAssets = this.relatedAssets;
final resource = this.resource;
final servicePerimeter = this.servicePerimeter;
final updateTime = this.updateTime;
return {
'accessLevel': ?accessLevel,
'accessPolicy': ?accessPolicy,
'ancestors': ?ancestors,
'assetExceptions': ?assetExceptions,
'assetType': ?assetType,
'iamPolicy': ?iamPolicy,
'name': ?name,
'orgPolicy': ?orgPolicy,
'osInventory': ?osInventory,
'relatedAsset': ?relatedAsset,
'relatedAssets': ?relatedAssets,
'resource': ?resource,
'servicePerimeter': ?servicePerimeter,
'updateTime': ?updateTime,
};
}
}
/// The enhanced metadata information for a resource.
class AssetEnrichment {
/// The resource owners for a resource.
///
/// Note that this field only contains the members that have "roles/owner"
/// role in the resource's IAM Policy.
ResourceOwners? resourceOwners;
AssetEnrichment({this.resourceOwners});
AssetEnrichment.fromJson(core.Map json_)
: this(
resourceOwners: json_.containsKey('resourceOwners')
? ResourceOwners.fromJson(
json_['resourceOwners'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final resourceOwners = this.resourceOwners;
return {'resourceOwners': ?resourceOwners};
}
}
/// An exception of an asset.
class AssetException {
/// The details of the exception.
core.String? details;
/// The type of exception.
/// Possible string values are:
/// - "EXCEPTION_TYPE_UNSPECIFIED" : exception_type is not applicable for the
/// current asset.
/// - "TRUNCATION" : The asset content is truncated.
core.String? exceptionType;
AssetException({this.details, this.exceptionType});
AssetException.fromJson(core.Map json_)
: this(
details: json_['details'] as core.String?,
exceptionType: json_['exceptionType'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final details = this.details;
final exceptionType = this.exceptionType;
return {'details': ?details, 'exceptionType': ?exceptionType};
}
}
/// Attached resource representation, which is defined by the corresponding
/// service provider.
///
/// It represents an attached resource's payload.
class AttachedResource {
/// The type of this attached resource.
///
/// Example: `osconfig.googleapis.com/Inventory` You can find the supported
/// attached asset types of each resource in this table:
/// `https://cloud.google.com/asset-inventory/docs/supported-asset-types`
core.String? assetType;
/// Versioned resource representations of this attached resource.
///
/// This is repeated because there could be multiple versions of the attached
/// resource representations during version migration.
core.List<VersionedResource>? versionedResources;
AttachedResource({this.assetType, this.versionedResources});
AttachedResource.fromJson(core.Map json_)
: this(
assetType: json_['assetType'] as core.String?,
versionedResources: (json_['versionedResources'] as core.List?)
?.map(
(value) => VersionedResource.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final assetType = this.assetType;
final versionedResources = this.versionedResources;
return {'assetType': ?assetType, 'versionedResources': ?versionedResources};
}
}
/// Specifies the audit configuration for a service.
///
/// The configuration determines which permission types are logged, and what
/// identities, if any, are exempted from logging. An AuditConfig must have one
/// or more AuditLogConfigs. If there are AuditConfigs for both `allServices`
/// and a specific service, the union of the two AuditConfigs is used for that
/// service: the log_types specified in each AuditConfig are enabled, and the
/// exempted_members in each AuditLogConfig are exempted. Example Policy with
/// multiple AuditConfigs: { "audit_configs": \[ { "service": "allServices",
/// "audit_log_configs": \[ { "log_type": "DATA_READ", "exempted_members": \[
/// "user:jose@example.com" \] }, { "log_type": "DATA_WRITE" }, { "log_type":
/// "ADMIN_READ" } \] }, { "service": "sampleservice.googleapis.com",
/// "audit_log_configs": \[ { "log_type": "DATA_READ" }, { "log_type":
/// "DATA_WRITE", "exempted_members": \[ "user:aliya@example.com" \] } \] } \] }
/// For sampleservice, this policy enables DATA_READ, DATA_WRITE and ADMIN_READ
/// logging. It also exempts `jose@example.com` from DATA_READ logging, and
/// `aliya@example.com` from DATA_WRITE logging.
class AuditConfig {
/// The configuration for logging of each type of permission.
core.List<AuditLogConfig>? auditLogConfigs;
/// Specifies a service that will be enabled for audit logging.
///
/// For example, `storage.googleapis.com`, `cloudsql.googleapis.com`.
/// `allServices` is a special value that covers all services.
core.String? service;
AuditConfig({this.auditLogConfigs, this.service});
AuditConfig.fromJson(core.Map json_)
: this(
auditLogConfigs: (json_['auditLogConfigs'] as core.List?)
?.map(
(value) => AuditLogConfig.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
service: json_['service'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final auditLogConfigs = this.auditLogConfigs;
final service = this.service;
return {'auditLogConfigs': ?auditLogConfigs, 'service': ?service};
}
}
/// Provides the configuration for logging a type of permissions.
///
/// Example: { "audit_log_configs": \[ { "log_type": "DATA_READ",
/// "exempted_members": \[ "user:jose@example.com" \] }, { "log_type":
/// "DATA_WRITE" } \] } This enables 'DATA_READ' and 'DATA_WRITE' logging, while
/// exempting jose@example.com from DATA_READ logging.
typedef AuditLogConfig = $AuditLogConfig;
/// Batch get assets history response.
class BatchGetAssetsHistoryResponse {
/// A list of assets with valid time windows.
core.List<TemporalAsset>? assets;
BatchGetAssetsHistoryResponse({this.assets});
BatchGetAssetsHistoryResponse.fromJson(core.Map json_)
: this(
assets: (json_['assets'] as core.List?)
?.map(
(value) => TemporalAsset.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final assets = this.assets;
return {'assets': ?assets};
}
}
/// A response message for AssetService.BatchGetEffectiveIamPolicies.
class BatchGetEffectiveIamPoliciesResponse {
/// The effective policies for a batch of resources.
///
/// Note that the results order is the same as the order of
/// BatchGetEffectiveIamPoliciesRequest.names. When a resource does not have
/// any effective IAM policies, its corresponding policy_result will contain
/// empty EffectiveIamPolicy.policies.
core.List<EffectiveIamPolicy>? policyResults;
BatchGetEffectiveIamPoliciesResponse({this.policyResults});
BatchGetEffectiveIamPoliciesResponse.fromJson(core.Map json_)
: this(
policyResults: (json_['policyResults'] as core.List?)
?.map(
(value) => EffectiveIamPolicy.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final policyResults = this.policyResults;
return {'policyResults': ?policyResults};
}
}
/// A BigQuery destination for exporting assets to.
class BigQueryDestination {
/// The BigQuery dataset in format "projects/projectId/datasets/datasetId", to
/// which the snapshot result should be exported.
///
/// If this dataset does not exist, the export call returns an
/// INVALID_ARGUMENT error. Setting the `contentType` for `exportAssets`
/// determines the
/// \[schema\](/asset-inventory/docs/exporting-to-bigquery#bigquery-schema) of
/// the BigQuery table. Setting `separateTablesPerAssetType` to `TRUE` also
/// influences the schema.
///
/// Required.
core.String? dataset;
/// If the destination table already exists and this flag is `TRUE`, the table
/// will be overwritten by the contents of assets snapshot.
///
/// If the flag is `FALSE` or unset and the destination table already exists,
/// the export call returns an INVALID_ARGUMENT error.
core.bool? force;
/// \[partition_spec\] determines whether to export to partitioned table(s)
/// and how to partition the data.
///
/// If \[partition_spec\] is unset or \[partition_spec.partition_key\] is
/// unset or `PARTITION_KEY_UNSPECIFIED`, the snapshot results will be
/// exported to non-partitioned table(s). \[force\] will decide whether to
/// overwrite existing table(s). If \[partition_spec\] is specified. First,
/// the snapshot results will be written to partitioned table(s) with two
/// additional timestamp columns, readTime and requestTime, one of which will
/// be the partition key. Secondly, in the case when any destination table
/// already exists, it will first try to update existing table's schema as
/// necessary by appending additional columns. Then, if \[force\] is `TRUE`,
/// the corresponding partition will be overwritten by the snapshot results
/// (data in different partitions will remain intact); if \[force\] is unset
/// or `FALSE`, it will append the data. An error will be returned if the
/// schema update or data appension fails.
PartitionSpec? partitionSpec;
/// If this flag is `TRUE`, the snapshot results will be written to one or
/// multiple tables, each of which contains results of one asset type.
///
/// The \[force\] and \[partition_spec\] fields will apply to each of them.
/// Field \[table\] will be concatenated with "_" and the asset type names
/// (see https://cloud.google.com/asset-inventory/docs/supported-asset-types
/// for supported asset types) to construct per-asset-type table names, in
/// which all non-alphanumeric characters like "." and "/" will be substituted
/// by "_". Example: if field \[table\] is "mytable" and snapshot results
/// contain "storage.googleapis.com/Bucket" assets, the corresponding table
/// name will be "mytable_storage_googleapis_com_Bucket". If any of these
/// tables does not exist, a new table with the concatenated name will be
/// created. When \[content_type\] in the ExportAssetsRequest is `RESOURCE`,
/// the schema of each table will include RECORD-type columns mapped to the
/// nested fields in the Asset.resource.data field of that asset type (up to
/// the 15 nested level BigQuery supports
/// (https://cloud.google.com/bigquery/docs/nested-repeated#limitations)). The
/// fields in \>15 nested levels will be stored in JSON format string as a
/// child column of its parent RECORD column. If error occurs when exporting
/// to any table, the whole export call will return an error but the export
/// results that already succeed will persist. Example: if exporting to
/// table_type_A succeeds when exporting to table_type_B fails during one
/// export call, the results in table_type_A will persist and there will not
/// be partial results persisting in a table.
core.bool? separateTablesPerAssetType;
/// The BigQuery table to which the snapshot result should be written.
///
/// If this table does not exist, a new table with the given name will be
/// created.
///
/// Required.
core.String? table;
BigQueryDestination({
this.dataset,
this.force,
this.partitionSpec,
this.separateTablesPerAssetType,
this.table,
});
BigQueryDestination.fromJson(core.Map json_)
: this(
dataset: json_['dataset'] as core.String?,
force: json_['force'] as core.bool?,
partitionSpec: json_.containsKey('partitionSpec')
? PartitionSpec.fromJson(
json_['partitionSpec'] as core.Map<core.String, core.dynamic>,
)
: null,
separateTablesPerAssetType:
json_['separateTablesPerAssetType'] as core.bool?,
table: json_['table'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final dataset = this.dataset;
final force = this.force;
final partitionSpec = this.partitionSpec;
final separateTablesPerAssetType = this.separateTablesPerAssetType;
final table = this.table;
return {
'dataset': ?dataset,
'force': ?force,
'partitionSpec': ?partitionSpec,
'separateTablesPerAssetType': ?separateTablesPerAssetType,
'table': ?table,
};
}
}
/// Associates `members`, or principals, with a `role`.
class Binding {
/// The condition that is associated with this binding.
///
/// If the condition evaluates to `true`, then this binding applies to the
/// current request. If the condition evaluates to `false`, then this binding
/// does not apply to the current request. However, a different role binding
/// might grant the same role to one or more of the principals in this
/// binding. To learn which resources support conditions in their IAM
/// policies, see the
/// [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).
Expr? condition;
/// Specifies the principals requesting access for a Google Cloud resource.
///
/// `members` can have the following values: * `allUsers`: A special
/// identifier that represents anyone who is on the internet; with or without
/// a Google account. * `allAuthenticatedUsers`: A special identifier that
/// represents anyone who is authenticated with a Google account or a service
/// account. Does not include identities that come from external identity
/// providers (IdPs) through identity federation. * `user:{emailid}`: An email
/// address that represents a specific Google account. For example,
/// `alice@example.com` . * `serviceAccount:{emailid}`: An email address that
/// represents a Google service account. For example,
/// `my-other-app@appspot.gserviceaccount.com`. *
/// `serviceAccount:{projectid}.svc.id.goog[{namespace}/{kubernetes-sa}]`: An
/// identifier for a
/// [Kubernetes service account](https://cloud.google.com/kubernetes-engine/docs/how-to/kubernetes-service-accounts).
/// For example, `my-project.svc.id.goog[my-namespace/my-kubernetes-sa]`. *
/// `group:{emailid}`: An email address that represents a Google group. For
/// example, `admins@example.com`. * `domain:{domain}`: The G Suite domain
/// (primary) that represents all the users of that domain. For example,
/// `google.com` or `example.com`. *
/// `principal://iam.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`:
/// A single identity in a workforce identity pool. *
/// `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/group/{group_id}`:
/// All workforce identities in a group. *
/// `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}/attribute.{attribute_name}/{attribute_value}`:
/// All workforce identities with a specific attribute value. *
/// `principalSet://iam.googleapis.com/locations/global/workforcePools/{pool_id}
/// / * `: All identities in a workforce identity pool. *
/// `principal://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/subject/{subject_attribute_value}`:
/// A single identity in a workload identity pool. *
/// `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/group/{group_id}`:
/// A workload identity pool group. *
/// `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}/attribute.{attribute_name}/{attribute_value}`:
/// All identities in a workload identity pool with a certain attribute. *
/// `principalSet://iam.googleapis.com/projects/{project_number}/locations/global/workloadIdentityPools/{pool_id}
/// / * `: All identities in a workload identity pool. *
/// `deleted:user:{emailid}?uid={uniqueid}`: An email address (plus unique
/// identifier) representing a user that has been recently deleted. For
/// example, `alice@example.com?uid=123456789012345678901`. If the user is
/// recovered, this value reverts to `user:{emailid}` and the recovered user
/// retains the role in the binding. *
/// `deleted:serviceAccount:{emailid}?uid={uniqueid}`: An email address (plus
/// unique identifier) representing a service account that has been recently
/// deleted. For example,
/// `my-other-app@appspot.gserviceaccount.com?uid=123456789012345678901`. If
/// the service account is undeleted, this value reverts to
/// `serviceAccount:{emailid}` and the undeleted service account retains the
/// role in the binding. * `deleted:group:{emailid}?uid={uniqueid}`: An email
/// address (plus unique identifier) representing a Google group that has been
/// recently deleted. For example,
/// `admins@example.com?uid=123456789012345678901`. If the group is recovered,
/// this value reverts to `group:{emailid}` and the recovered group retains
/// the role in the binding. *
/// `deleted:principal://iam.googleapis.com/locations/global/workforcePools/{pool_id}/subject/{subject_attribute_value}`:
/// Deleted single identity in a workforce identity pool. For example,
/// `deleted:principal://iam.googleapis.com/locations/global/workforcePools/my-pool-id/subject/my-subject-attribute-value`.
core.List<core.String>? members;
/// Role that is assigned to the list of `members`, or principals.
///
/// For example, `roles/viewer`, `roles/editor`, or `roles/owner`. For an
/// overview of the IAM roles and permissions, see the
/// [IAM documentation](https://cloud.google.com/iam/docs/roles-overview). For
/// a list of the available pre-defined roles, see
/// [here](https://cloud.google.com/iam/docs/understanding-roles).
core.String? role;
Binding({this.condition, this.members, this.role});
Binding.fromJson(core.Map json_)
: this(
condition: json_.containsKey('condition')
? Expr.fromJson(
json_['condition'] as core.Map<core.String, core.dynamic>,
)
: null,
members: (json_['members'] as core.List?)
?.map((value) => value as core.String)
.toList(),
role: json_['role'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final condition = this.condition;
final members = this.members;
final role = this.role;
return {'condition': ?condition, 'members': ?members, 'role': ?role};
}
}
/// The IAM conditions context.
class ConditionContext {
/// The hypothetical access timestamp to evaluate IAM conditions.
///
/// Note that this value must not be earlier than the current time; otherwise,
/// an INVALID_ARGUMENT error will be returned.
core.String? accessTime;
ConditionContext({this.accessTime});
ConditionContext.fromJson(core.Map json_)
: this(accessTime: json_['accessTime'] as core.String?);
core.Map<core.String, core.dynamic> toJson() {
final accessTime = this.accessTime;
return {'accessTime': ?accessTime};
}
}
/// The condition evaluation.
class ConditionEvaluation {
/// The evaluation result.
/// Possible string values are:
/// - "EVALUATION_VALUE_UNSPECIFIED" : Reserved for future use.
/// - "TRUE" : The evaluation result is `true`.
/// - "FALSE" : The evaluation result is `false`.
/// - "CONDITIONAL" : The evaluation result is `conditional` when the
/// condition expression contains variables that are either missing input
/// values or have not been supported by Policy Analyzer yet.
core.String? evaluationValue;
ConditionEvaluation({this.evaluationValue});
ConditionEvaluation.fromJson(core.Map json_)
: this(evaluationValue: json_['evaluationValue'] as core.String?);
core.Map<core.String, core.dynamic> toJson() {
final evaluationValue = this.evaluationValue;
return {'evaluationValue': ?evaluationValue};
}
}
/// Create asset feed request.
class CreateFeedRequest {
/// The feed details.
///
/// The field `name` must be empty and it will be generated in the format of:
/// projects/project_number/feeds/feed_id folders/folder_number/feeds/feed_id
/// organizations/organization_number/feeds/feed_id
///
/// Required.
Feed? feed;
/// This is the client-assigned asset feed identifier and it needs to be
/// unique under a specific parent project/folder/organization.
///
/// Required.
core.String? feedId;
CreateFeedRequest({this.feed, this.feedId});
CreateFeedRequest.fromJson(core.Map json_)
: this(
feed: json_.containsKey('feed')
? Feed.fromJson(
json_['feed'] as core.Map<core.String, core.dynamic>,
)
: null,
feedId: json_['feedId'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final feed = this.feed;
final feedId = this.feedId;
return {'feed': ?feed, 'feedId': ?feedId};
}
}
/// Represents a whole or partial calendar date, such as a birthday.
///
/// The time of day and time zone are either specified elsewhere or are
/// insignificant. The date is relative to the Gregorian Calendar. This can
/// represent one of the following: * A full date, with non-zero year, month,
/// and day values. * A month and day, with a zero year (for example, an
/// anniversary). * A year on its own, with a zero month and a zero day. * A
/// year and month, with a zero day (for example, a credit card expiration
/// date). Related types: * google.type.TimeOfDay * google.type.DateTime *
/// google.protobuf.Timestamp
typedef Date = $Date;
/// The effective IAM policies on one resource.
class EffectiveIamPolicy {
/// The
/// [full_resource_name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// for which the policies are computed.
///
/// This is one of the BatchGetEffectiveIamPoliciesRequest.names the caller
/// provides in the request.
core.String? fullResourceName;
/// The effective policies for the full_resource_name.
///
/// These policies include the policy set on the full_resource_name and those
/// set on its parents and ancestors up to the
/// BatchGetEffectiveIamPoliciesRequest.scope. Note that these policies are
/// not filtered according to the resource type of the full_resource_name.
/// These policies are hierarchically ordered by PolicyInfo.attached_resource
/// starting from full_resource_name itself to its parents and ancestors, such
/// that policies\[i\]'s PolicyInfo.attached_resource is the child of
/// policies\[i+1\]'s PolicyInfo.attached_resource, if policies\[i+1\] exists.
core.List<PolicyInfo>? policies;
EffectiveIamPolicy({this.fullResourceName, this.policies});
EffectiveIamPolicy.fromJson(core.Map json_)
: this(
fullResourceName: json_['fullResourceName'] as core.String?,
policies: (json_['policies'] as core.List?)
?.map(
(value) => PolicyInfo.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final fullResourceName = this.fullResourceName;
final policies = this.policies;
return {'fullResourceName': ?fullResourceName, 'policies': ?policies};
}
}
/// The effective tags and the ancestor resources from which they were
/// inherited.
class EffectiveTagDetails {
/// The
/// [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// of the ancestor from which effective_tags are inherited, according to
/// [tag inheritance](https://cloud.google.com/resource-manager/docs/tags/tags-overview#inheritance).
core.String? attachedResource;
/// The effective tags inherited from the attached_resource.
///
/// Note that tags with the same key but different values may attach to
/// resources at a different hierarchy levels. The lower hierarchy tag value
/// will overwrite the higher hierarchy tag value of the same tag key. In this
/// case, the tag value at the higher hierarchy level will be removed. For
/// more information, see
/// [tag inheritance](https://cloud.google.com/resource-manager/docs/tags/tags-overview#inheritance).
core.List<Tag>? effectiveTags;
EffectiveTagDetails({this.attachedResource, this.effectiveTags});
EffectiveTagDetails.fromJson(core.Map json_)
: this(
attachedResource: json_['attachedResource'] as core.String?,
effectiveTags: (json_['effectiveTags'] as core.List?)
?.map(
(value) =>
Tag.fromJson(value as core.Map<core.String, core.dynamic>),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final attachedResource = this.attachedResource;
final effectiveTags = this.effectiveTags;
return {
'attachedResource': ?attachedResource,
'effectiveTags': ?effectiveTags,
};
}
}
/// A generic empty message that you can re-use to avoid defining duplicated
/// empty messages in your APIs.
///
/// A typical example is to use it as the request or the response type of an API
/// method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns
/// (google.protobuf.Empty); }
typedef Empty = $Empty;
/// Explanation about the IAM policy search result.
class Explanation {
/// The map from roles to their included permissions that match the permission
/// query (i.e., a query containing `policy.role.permissions:`).
///
/// Example: if query `policy.role.permissions:compute.disk.get` matches a
/// policy binding that contains owner role, the matched_permissions will be
/// `{"roles/owner": ["compute.disk.get"]}`. The roles can also be found in
/// the returned `policy` bindings. Note that the map is populated only for
/// requests with permission queries.
core.Map<core.String, Permissions>? matchedPermissions;
Explanation({this.matchedPermissions});
Explanation.fromJson(core.Map json_)
: this(
matchedPermissions:
(json_['matchedPermissions']
as core.Map<core.String, core.dynamic>?)
?.map(
(key, value) => core.MapEntry(
key,
Permissions.fromJson(
value as core.Map<core.String, core.dynamic>,
),
),
),
);
core.Map<core.String, core.dynamic> toJson() {
final matchedPermissions = this.matchedPermissions;
return {'matchedPermissions': ?matchedPermissions};
}
}
/// Export asset request.
class ExportAssetsRequest {
/// A list of asset types to take a snapshot for.
///
/// For example: "compute.googleapis.com/Disk". Regular expressions are also
/// supported. For example: * "compute.googleapis.com.*" snapshots resources
/// whose asset type starts with "compute.googleapis.com". * ".*Instance"
/// snapshots resources whose asset type ends with "Instance". *
/// ".*Instance.*" snapshots resources whose asset type contains "Instance".
/// See [RE2](https://github.com/google/re2/wiki/Syntax) for all supported
/// regular expression syntax. If the regular expression does not match any
/// supported asset type, an INVALID_ARGUMENT error will be returned. If
/// specified, only matching assets will be returned, otherwise, it will
/// snapshot all asset types. See
/// [Introduction to Cloud Asset Inventory](https://cloud.google.com/asset-inventory/docs/overview)
/// for all supported asset types.
core.List<core.String>? assetTypes;
/// Asset content type.
///
/// If not specified, no content but the asset name will be returned.
/// Possible string values are:
/// - "CONTENT_TYPE_UNSPECIFIED" : Unspecified content type.
/// - "RESOURCE" : Resource metadata.
/// - "IAM_POLICY" : The actual IAM policy set on a resource.
/// - "ORG_POLICY" : The organization policy set on an asset.
/// - "ACCESS_POLICY" : The Access Context Manager policy set on an asset.
/// - "OS_INVENTORY" : The runtime OS Inventory information.
/// - "RELATIONSHIP" : The related resources.
core.String? contentType;
/// Output configuration indicating where the results will be output to.
///
/// Required.
OutputConfig? outputConfig;
/// Timestamp to take an asset snapshot.
///
/// This can only be set to a timestamp between the current time and the
/// current time minus 35 days (inclusive). If not specified, the current time
/// will be used. Due to delays in resource data collection and indexing,
/// there is a volatile window during which running the same query may get
/// different results.
core.String? readTime;
/// A list of relationship types to export, for example:
/// `INSTANCE_TO_INSTANCEGROUP`.
///
/// This field should only be specified if content_type=RELATIONSHIP. * If
/// specified: it snapshots specified relationships. It returns an error if
/// any of the \[relationship_types\] doesn't belong to the supported
/// relationship types of the \[asset_types\] or if any of the \[asset_types\]
/// doesn't belong to the source types of the \[relationship_types\]. *
/// Otherwise: it snapshots the supported relationships for all
/// \[asset_types\] or returns an error if any of the \[asset_types\] has no
/// relationship support. An unspecified asset types field means all supported
/// asset_types. See
/// [Introduction to Cloud Asset Inventory](https://cloud.google.com/asset-inventory/docs/overview)
/// for all supported asset types and relationship types.
core.List<core.String>? relationshipTypes;
ExportAssetsRequest({
this.assetTypes,
this.contentType,
this.outputConfig,
this.readTime,
this.relationshipTypes,
});
ExportAssetsRequest.fromJson(core.Map json_)
: this(
assetTypes: (json_['assetTypes'] as core.List?)
?.map((value) => value as core.String)
.toList(),
contentType: json_['contentType'] as core.String?,
outputConfig: json_.containsKey('outputConfig')
? OutputConfig.fromJson(
json_['outputConfig'] as core.Map<core.String, core.dynamic>,
)
: null,
readTime: json_['readTime'] as core.String?,
relationshipTypes: (json_['relationshipTypes'] as core.List?)
?.map((value) => value as core.String)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final assetTypes = this.assetTypes;
final contentType = this.contentType;
final outputConfig = this.outputConfig;
final readTime = this.readTime;
final relationshipTypes = this.relationshipTypes;
return {
'assetTypes': ?assetTypes,
'contentType': ?contentType,
'outputConfig': ?outputConfig,
'readTime': ?readTime,
'relationshipTypes': ?relationshipTypes,
};
}
}
/// Represents a textual expression in the Common Expression Language (CEL)
/// syntax.
///
/// CEL is a C-like expression language. The syntax and semantics of CEL are
/// documented at https://github.com/google/cel-spec. Example (Comparison):
/// title: "Summary size limit" description: "Determines if a summary is less
/// than 100 chars" expression: "document.summary.size() \< 100" Example
/// (Equality): title: "Requestor is owner" description: "Determines if
/// requestor is the document owner" expression: "document.owner ==
/// request.auth.claims.email" Example (Logic): title: "Public documents"
/// description: "Determine whether the document should be publicly visible"
/// expression: "document.type != 'private' && document.type != 'internal'"
/// Example (Data Manipulation): title: "Notification string" description:
/// "Create a notification string with a timestamp." expression: "'New message
/// received at ' + string(document.create_time)" The exact variables and
/// functions that may be referenced within an expression are determined by the
/// service that evaluates it. See the service documentation for additional
/// information.
typedef Expr = $Expr;
/// An asset feed used to export asset updates to a destinations.
///
/// An asset feed filter controls what updates are exported. The asset feed must
/// be created within a project, organization, or folder. Supported destinations
/// are: Pub/Sub topics.
class Feed {
/// A list of the full names of the assets to receive updates.
///
/// You must specify either or both of asset_names and asset_types. Only asset
/// updates matching specified asset_names or asset_types are exported to the
/// feed. Example:
/// `//compute.googleapis.com/projects/my_project_123/zones/zone1/instances/instance1`.
/// For a list of the full names for supported asset types, see \[Resource
/// name format\](/asset-inventory/docs/resource-name-format).
core.List<core.String>? assetNames;
/// A list of types of the assets to receive updates.
///
/// You must specify either or both of asset_names and asset_types. Only asset
/// updates matching specified asset_names or asset_types are exported to the
/// feed. Example: `"compute.googleapis.com/Disk"` For a list of all supported
/// asset types, see \[Supported asset
/// types\](/asset-inventory/docs/supported-asset-types).
core.List<core.String>? assetTypes;
/// A condition which determines whether an asset update should be published.
///
/// If specified, an asset will be returned only when the expression evaluates
/// to true. When set, `expression` field in the `Expr` must be a valid
/// [CEL expression](https://github.com/google/cel-spec) on a TemporalAsset
/// with name `temporal_asset`. Example: a Feed with expression
/// ("temporal_asset.deleted == true") will only publish Asset deletions.
/// Other fields of `Expr` are optional. See our
/// [user guide](https://cloud.google.com/asset-inventory/docs/monitoring-asset-changes-with-condition)
/// for detailed instructions.
Expr? condition;
/// Asset content type.
///
/// If not specified, no content but the asset name and type will be returned.
/// Possible string values are:
/// - "CONTENT_TYPE_UNSPECIFIED" : Unspecified content type.
/// - "RESOURCE" : Resource metadata.
/// - "IAM_POLICY" : The actual IAM policy set on a resource.
/// - "ORG_POLICY" : The organization policy set on an asset.
/// - "ACCESS_POLICY" : The Access Context Manager policy set on an asset.
/// - "OS_INVENTORY" : The runtime OS Inventory information.
/// - "RELATIONSHIP" : The related resources.
core.String? contentType;
/// Feed output configuration defining where the asset updates are published
/// to.
///
/// Required.
FeedOutputConfig? feedOutputConfig;
/// The format will be
/// projects/{project_number}/feeds/{client-assigned_feed_identifier} or
/// folders/{folder_number}/feeds/{client-assigned_feed_identifier} or
/// organizations/{organization_number}/feeds/{client-assigned_feed_identifier}
/// The client-assigned feed identifier must be unique within the parent
/// project/folder/organization.
///
/// Required.
core.String? name;
/// A list of relationship types to output, for example:
/// `INSTANCE_TO_INSTANCEGROUP`.
///
/// This field should only be specified if content_type=RELATIONSHIP. * If
/// specified: it outputs specified relationship updates on the
/// \[asset_names\] or the \[asset_types\]. It returns an error if any of the
/// \[relationship_types\] doesn't belong to the supported relationship types
/// of the \[asset_names\] or \[asset_types\], or any of the \[asset_names\]
/// or the \[asset_types\] doesn't belong to the source types of the
/// \[relationship_types\]. * Otherwise: it outputs the supported
/// relationships of the types of \[asset_names\] and \[asset_types\] or
/// returns an error if any of the \[asset_names\] or the \[asset_types\] has
/// no replationship support. See
/// [Introduction to Cloud Asset Inventory](https://cloud.google.com/asset-inventory/docs/overview)
/// for all supported asset types and relationship types.
core.List<core.String>? relationshipTypes;
Feed({
this.assetNames,
this.assetTypes,
this.condition,
this.contentType,
this.feedOutputConfig,
this.name,
this.relationshipTypes,
});
Feed.fromJson(core.Map json_)
: this(
assetNames: (json_['assetNames'] as core.List?)
?.map((value) => value as core.String)
.toList(),
assetTypes: (json_['assetTypes'] as core.List?)
?.map((value) => value as core.String)
.toList(),
condition: json_.containsKey('condition')
? Expr.fromJson(
json_['condition'] as core.Map<core.String, core.dynamic>,
)
: null,
contentType: json_['contentType'] as core.String?,
feedOutputConfig: json_.containsKey('feedOutputConfig')
? FeedOutputConfig.fromJson(
json_['feedOutputConfig']
as core.Map<core.String, core.dynamic>,
)
: null,
name: json_['name'] as core.String?,
relationshipTypes: (json_['relationshipTypes'] as core.List?)
?.map((value) => value as core.String)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final assetNames = this.assetNames;
final assetTypes = this.assetTypes;
final condition = this.condition;
final contentType = this.contentType;
final feedOutputConfig = this.feedOutputConfig;
final name = this.name;
final relationshipTypes = this.relationshipTypes;
return {
'assetNames': ?assetNames,
'assetTypes': ?assetTypes,
'condition': ?condition,
'contentType': ?contentType,
'feedOutputConfig': ?feedOutputConfig,
'name': ?name,
'relationshipTypes': ?relationshipTypes,
};
}
}
/// Output configuration for asset feed destination.
class FeedOutputConfig {
/// Destination on Pub/Sub.
PubsubDestination? pubsubDestination;
FeedOutputConfig({this.pubsubDestination});
FeedOutputConfig.fromJson(core.Map json_)
: this(
pubsubDestination: json_.containsKey('pubsubDestination')
? PubsubDestination.fromJson(
json_['pubsubDestination']
as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final pubsubDestination = this.pubsubDestination;
return {'pubsubDestination': ?pubsubDestination};
}
}
/// A Cloud Storage location.
class GcsDestination {
/// The URI of the Cloud Storage object.
///
/// It's the same URI that is used by gcloud storage. Example:
/// "gs://bucket_name/object_name". See
/// [Viewing and Editing Object Metadata](https://cloud.google.com/storage/docs/viewing-editing-metadata)
/// for more information. If the specified Cloud Storage object already exists
/// and there is no
/// [hold](https://cloud.google.com/storage/docs/object-holds), it will be
/// overwritten with the exported result.
core.String? uri;
/// The URI prefix of all generated Cloud Storage objects.
///
/// Example: "gs://bucket_name/object_name_prefix". Each object URI is in
/// format: "gs://bucket_name/object_name_prefix// and only contains assets
/// for that type. starts from 0. Example:
/// "gs://bucket_name/object_name_prefix/compute.googleapis.com/Disk/0" is the
/// first shard of output objects containing all compute.googleapis.com/Disk
/// assets. An INVALID_ARGUMENT error will be returned if file with the same
/// name "gs://bucket_name/object_name_prefix" already exists.
core.String? uriPrefix;
GcsDestination({this.uri, this.uriPrefix});
GcsDestination.fromJson(core.Map json_)
: this(
uri: json_['uri'] as core.String?,
uriPrefix: json_['uriPrefix'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final uri = this.uri;
final uriPrefix = this.uriPrefix;
return {'uri': ?uri, 'uriPrefix': ?uriPrefix};
}
}
/// An IAM role or permission under analysis.
class GoogleCloudAssetV1Access {
/// The analysis state of this access.
IamPolicyAnalysisState? analysisState;
/// The permission.
core.String? permission;
/// The role.
core.String? role;
GoogleCloudAssetV1Access({this.analysisState, this.permission, this.role});
GoogleCloudAssetV1Access.fromJson(core.Map json_)
: this(
analysisState: json_.containsKey('analysisState')
? IamPolicyAnalysisState.fromJson(
json_['analysisState'] as core.Map<core.String, core.dynamic>,
)
: null,
permission: json_['permission'] as core.String?,
role: json_['role'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final analysisState = this.analysisState;
final permission = this.permission;
final role = this.role;
return {
'analysisState': ?analysisState,
'permission': ?permission,
'role': ?role,
};
}
}
/// An access control list, derived from the above IAM policy binding, which
/// contains a set of resources and accesses.
///
/// May include one item from each set to compose an access control entry.
/// NOTICE that there could be multiple access control lists for one IAM policy
/// binding. The access control lists are created based on resource and access
/// combinations. For example, assume we have the following cases in one IAM
/// policy binding: - Permission P1 and P2 apply to resource R1 and R2; -
/// Permission P3 applies to resource R2 and R3; This will result in the
/// following access control lists: - AccessControlList 1: \[R1, R2\], \[P1,
/// P2\] - AccessControlList 2: \[R2, R3\], \[P3\]
class GoogleCloudAssetV1AccessControlList {
/// The accesses that match one of the following conditions: - The
/// access_selector, if it is specified in request; - Otherwise, access
/// specifiers reachable from the policy binding's role.
core.List<GoogleCloudAssetV1Access>? accesses;
/// Condition evaluation for this AccessControlList, if there is a condition
/// defined in the above IAM policy binding.
ConditionEvaluation? conditionEvaluation;
/// Resource edges of the graph starting from the policy attached resource to
/// any descendant resources.
///
/// The Edge.source_node contains the full resource name of a parent resource
/// and Edge.target_node contains the full resource name of a child resource.
/// This field is present only if the output_resource_edges option is enabled
/// in request.
core.List<GoogleCloudAssetV1Edge>? resourceEdges;
/// The resources that match one of the following conditions: - The
/// resource_selector, if it is specified in request; - Otherwise, resources
/// reachable from the policy attached resource.
core.List<GoogleCloudAssetV1Resource>? resources;
GoogleCloudAssetV1AccessControlList({
this.accesses,
this.conditionEvaluation,
this.resourceEdges,
this.resources,
});
GoogleCloudAssetV1AccessControlList.fromJson(core.Map json_)
: this(
accesses: (json_['accesses'] as core.List?)
?.map(
(value) => GoogleCloudAssetV1Access.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
conditionEvaluation: json_.containsKey('conditionEvaluation')
? ConditionEvaluation.fromJson(
json_['conditionEvaluation']
as core.Map<core.String, core.dynamic>,
)
: null,
resourceEdges: (json_['resourceEdges'] as core.List?)
?.map(
(value) => GoogleCloudAssetV1Edge.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
resources: (json_['resources'] as core.List?)
?.map(
(value) => GoogleCloudAssetV1Resource.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final accesses = this.accesses;
final conditionEvaluation = this.conditionEvaluation;
final resourceEdges = this.resourceEdges;
final resources = this.resources;
return {
'accesses': ?accesses,
'conditionEvaluation': ?conditionEvaluation,
'resourceEdges': ?resourceEdges,
'resources': ?resources,
};
}
}
/// Represents a Google Cloud asset(resource or IAM policy) governed by the
/// organization policies of the
/// AnalyzeOrgPolicyGovernedAssetsRequest.constraint.
class GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedAsset {
/// The consolidated policy for the analyzed asset.
///
/// The consolidated policy is computed by merging and evaluating
/// AnalyzeOrgPolicyGovernedAssetsResponse.GovernedAsset.policy_bundle. The
/// evaluation will respect the organization policy
/// [hierarchy rules](https://cloud.google.com/resource-manager/docs/organization-policy/understanding-hierarchy).
AnalyzerOrgPolicy? consolidatedPolicy;
/// An IAM policy governed by the organization policies of the
/// AnalyzeOrgPolicyGovernedAssetsRequest.constraint.
GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedIamPolicy?
governedIamPolicy;
/// A Google Cloud resource governed by the organization policies of the
/// AnalyzeOrgPolicyGovernedAssetsRequest.constraint.
GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedResource?
governedResource;
/// The ordered list of all organization policies from the
/// consolidated_policy.attached_resource to the scope specified in the
/// request.
///
/// If the constraint is defined with default policy, it will also appear in
/// the list.
core.List<AnalyzerOrgPolicy>? policyBundle;
GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedAsset({
this.consolidatedPolicy,
this.governedIamPolicy,
this.governedResource,
this.policyBundle,
});
GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedAsset.fromJson(
core.Map json_,
) : this(
consolidatedPolicy: json_.containsKey('consolidatedPolicy')
? AnalyzerOrgPolicy.fromJson(
json_['consolidatedPolicy']
as core.Map<core.String, core.dynamic>,
)
: null,
governedIamPolicy: json_.containsKey('governedIamPolicy')
? GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedIamPolicy.fromJson(
json_['governedIamPolicy']
as core.Map<core.String, core.dynamic>,
)
: null,
governedResource: json_.containsKey('governedResource')
? GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedResource.fromJson(
json_['governedResource']
as core.Map<core.String, core.dynamic>,
)
: null,
policyBundle: (json_['policyBundle'] as core.List?)
?.map(
(value) => AnalyzerOrgPolicy.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final consolidatedPolicy = this.consolidatedPolicy;
final governedIamPolicy = this.governedIamPolicy;
final governedResource = this.governedResource;
final policyBundle = this.policyBundle;
return {
'consolidatedPolicy': ?consolidatedPolicy,
'governedIamPolicy': ?governedIamPolicy,
'governedResource': ?governedResource,
'policyBundle': ?policyBundle,
};
}
}
/// The IAM policies governed by the organization policies of the
/// AnalyzeOrgPolicyGovernedAssetsRequest.constraint.
class GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedIamPolicy {
/// The asset type of the
/// AnalyzeOrgPolicyGovernedAssetsResponse.GovernedIamPolicy.attached_resource.
///
/// Example: `cloudresourcemanager.googleapis.com/Project` See
/// [Cloud Asset Inventory Supported Asset Types](https://cloud.google.com/asset-inventory/docs/supported-asset-types)
/// for all supported asset types.
core.String? assetType;
/// The full resource name of the resource on which this IAM policy is set.
///
/// Example:
/// `//compute.googleapis.com/projects/my_project_123/zones/zone1/instances/instance1`.
/// See
/// [Cloud Asset Inventory Resource Name Format](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// for more information.
core.String? attachedResource;
/// The folder(s) that this IAM policy belongs to, in the format of
/// folders/{FOLDER_NUMBER}.
///
/// This field is available when the IAM policy belongs (directly or
/// cascadingly) to one or more folders.
core.List<core.String>? folders;
/// The organization that this IAM policy belongs to, in the format of
/// organizations/{ORGANIZATION_NUMBER}.
///
/// This field is available when the IAM policy belongs (directly or
/// cascadingly) to an organization.
core.String? organization;
/// The IAM policy directly set on the given resource.
Policy? policy;
/// The project that this IAM policy belongs to, in the format of
/// projects/{PROJECT_NUMBER}.
///
/// This field is available when the IAM policy belongs to a project.
core.String? project;
GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedIamPolicy({
this.assetType,
this.attachedResource,
this.folders,
this.organization,
this.policy,
this.project,
});
GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedIamPolicy.fromJson(
core.Map json_,
) : this(
assetType: json_['assetType'] as core.String?,
attachedResource: json_['attachedResource'] as core.String?,
folders: (json_['folders'] as core.List?)
?.map((value) => value as core.String)
.toList(),
organization: json_['organization'] as core.String?,
policy: json_.containsKey('policy')
? Policy.fromJson(
json_['policy'] as core.Map<core.String, core.dynamic>,
)
: null,
project: json_['project'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final assetType = this.assetType;
final attachedResource = this.attachedResource;
final folders = this.folders;
final organization = this.organization;
final policy = this.policy;
final project = this.project;
return {
'assetType': ?assetType,
'attachedResource': ?attachedResource,
'folders': ?folders,
'organization': ?organization,
'policy': ?policy,
'project': ?project,
};
}
}
/// The Google Cloud resources governed by the organization policies of the
/// AnalyzeOrgPolicyGovernedAssetsRequest.constraint.
class GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedResource {
/// The asset type of the
/// AnalyzeOrgPolicyGovernedAssetsResponse.GovernedResource.full_resource_name
/// Example: `cloudresourcemanager.googleapis.com/Project` See
/// [Cloud Asset Inventory Supported Asset Types](https://cloud.google.com/asset-inventory/docs/supported-asset-types)
/// for all supported asset types.
core.String? assetType;
/// The effective tags on this resource.
core.List<EffectiveTagDetails>? effectiveTags;
/// The folder(s) that this resource belongs to, in the format of
/// folders/{FOLDER_NUMBER}.
///
/// This field is available when the resource belongs (directly or
/// cascadingly) to one or more folders.
core.List<core.String>? folders;
/// The
/// [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// of the Google Cloud resource.
core.String? fullResourceName;
/// The organization that this resource belongs to, in the format of
/// organizations/{ORGANIZATION_NUMBER}.
///
/// This field is available when the resource belongs (directly or
/// cascadingly) to an organization.
core.String? organization;
/// The
/// [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// of the parent of
/// AnalyzeOrgPolicyGovernedAssetsResponse.GovernedResource.full_resource_name.
core.String? parent;
/// The project that this resource belongs to, in the format of
/// projects/{PROJECT_NUMBER}.
///
/// This field is available when the resource belongs to a project.
core.String? project;
GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedResource({
this.assetType,
this.effectiveTags,
this.folders,
this.fullResourceName,
this.organization,
this.parent,
this.project,
});
GoogleCloudAssetV1AnalyzeOrgPolicyGovernedAssetsResponseGovernedResource.fromJson(
core.Map json_,
) : this(
assetType: json_['assetType'] as core.String?,
effectiveTags: (json_['effectiveTags'] as core.List?)
?.map(
(value) => EffectiveTagDetails.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
folders: (json_['folders'] as core.List?)
?.map((value) => value as core.String)
.toList(),
fullResourceName: json_['fullResourceName'] as core.String?,
organization: json_['organization'] as core.String?,
parent: json_['parent'] as core.String?,
project: json_['project'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final assetType = this.assetType;
final effectiveTags = this.effectiveTags;
final folders = this.folders;
final fullResourceName = this.fullResourceName;
final organization = this.organization;
final parent = this.parent;
final project = this.project;
return {
'assetType': ?assetType,
'effectiveTags': ?effectiveTags,
'folders': ?folders,
'fullResourceName': ?fullResourceName,
'organization': ?organization,
'parent': ?parent,
'project': ?project,
};
}
}
/// A BigQuery destination.
class GoogleCloudAssetV1BigQueryDestination {
/// The BigQuery dataset in format "projects/projectId/datasets/datasetId", to
/// which the analysis results should be exported.
///
/// If this dataset does not exist, the export call will return an
/// INVALID_ARGUMENT error.
///
/// Required.
core.String? dataset;
/// The partition key for BigQuery partitioned table.
/// Possible string values are:
/// - "PARTITION_KEY_UNSPECIFIED" : Unspecified partition key. Tables won't be
/// partitioned using this option.
/// - "REQUEST_TIME" : The time when the request is received. If specified as
/// partition key, the result table(s) is partitioned by the RequestTime
/// column, an additional timestamp column representing when the request was
/// received.
core.String? partitionKey;
/// The prefix of the BigQuery tables to which the analysis results will be
/// written.
///
/// Tables will be created based on this table_prefix if not exist: *
/// _analysis table will contain export operation's metadata. *
/// _analysis_result will contain all the IamPolicyAnalysisResult. When
/// \[partition_key\] is specified, both tables will be partitioned based on
/// the \[partition_key\].
///
/// Required.
core.String? tablePrefix;
/// Specifies the action that occurs if the destination table or partition
/// already exists.
///
/// The following values are supported: * WRITE_TRUNCATE: If the table or
/// partition already exists, BigQuery overwrites the entire table or all the
/// partitions data. * WRITE_APPEND: If the table or partition already exists,
/// BigQuery appends the data to the table or the latest partition. *
/// WRITE_EMPTY: If the table already exists and contains data, an error is
/// returned. The default value is WRITE_APPEND. Each action is atomic and
/// only occurs if BigQuery is able to complete the job successfully. Details
/// are at
/// https://cloud.google.com/bigquery/docs/loading-data-local#appending_to_or_overwriting_a_table_using_a_local_file.
///
/// Optional.
core.String? writeDisposition;
GoogleCloudAssetV1BigQueryDestination({
this.dataset,
this.partitionKey,
this.tablePrefix,
this.writeDisposition,
});
GoogleCloudAssetV1BigQueryDestination.fromJson(core.Map json_)
: this(
dataset: json_['dataset'] as core.String?,
partitionKey: json_['partitionKey'] as core.String?,
tablePrefix: json_['tablePrefix'] as core.String?,
writeDisposition: json_['writeDisposition'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final dataset = this.dataset;
final partitionKey = this.partitionKey;
final tablePrefix = this.tablePrefix;
final writeDisposition = this.writeDisposition;
return {
'dataset': ?dataset,
'partitionKey': ?partitionKey,
'tablePrefix': ?tablePrefix,
'writeDisposition': ?writeDisposition,
};
}
}
/// A `Constraint` that is either enforced or not.
///
/// For example a constraint `constraints/compute.disableSerialPortAccess`. If
/// it is enforced on a VM instance, serial port connections will not be opened
/// to that instance.
typedef GoogleCloudAssetV1BooleanConstraint = $Empty;
/// The definition of a constraint.
class GoogleCloudAssetV1Constraint {
/// Defines this constraint as being a BooleanConstraint.
GoogleCloudAssetV1BooleanConstraint? booleanConstraint;
/// The evaluation behavior of this constraint in the absence of 'Policy'.
/// Possible string values are:
/// - "CONSTRAINT_DEFAULT_UNSPECIFIED" : This is only used for distinguishing
/// unset values and should never be used.
/// - "ALLOW" : Indicates that all values are allowed for list constraints.
/// Indicates that enforcement is off for boolean constraints.
/// - "DENY" : Indicates that all values are denied for list constraints.
/// Indicates that enforcement is on for boolean constraints.
core.String? constraintDefault;
/// Detailed description of what this `Constraint` controls as well as how and
/// where it is enforced.
core.String? description;
/// The human readable name of the constraint.
core.String? displayName;
/// Defines this constraint as being a ListConstraint.
GoogleCloudAssetV1ListConstraint? listConstraint;
/// The unique name of the constraint.
///
/// Format of the name should be * `constraints/{constraint_name}` For
/// example, `constraints/compute.disableSerialPortAccess`.
core.String? name;
GoogleCloudAssetV1Constraint({
this.booleanConstraint,
this.constraintDefault,
this.description,
this.displayName,
this.listConstraint,
this.name,
});
GoogleCloudAssetV1Constraint.fromJson(core.Map json_)
: this(
booleanConstraint: json_.containsKey('booleanConstraint')
? GoogleCloudAssetV1BooleanConstraint.fromJson(
json_['booleanConstraint']
as core.Map<core.String, core.dynamic>,
)
: null,
constraintDefault: json_['constraintDefault'] as core.String?,
description: json_['description'] as core.String?,
displayName: json_['displayName'] as core.String?,
listConstraint: json_.containsKey('listConstraint')
? GoogleCloudAssetV1ListConstraint.fromJson(
json_['listConstraint'] as core.Map<core.String, core.dynamic>,
)
: null,
name: json_['name'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final booleanConstraint = this.booleanConstraint;
final constraintDefault = this.constraintDefault;
final description = this.description;
final displayName = this.displayName;
final listConstraint = this.listConstraint;
final name = this.name;
return {
'booleanConstraint': ?booleanConstraint,
'constraintDefault': ?constraintDefault,
'description': ?description,
'displayName': ?displayName,
'listConstraint': ?listConstraint,
'name': ?name,
};
}
}
/// The definition of a custom constraint.
class GoogleCloudAssetV1CustomConstraint {
/// Allow or deny type.
/// Possible string values are:
/// - "ACTION_TYPE_UNSPECIFIED" : Unspecified. Will results in user error.
/// - "ALLOW" : Allowed action type.
/// - "DENY" : Deny action type.
core.String? actionType;
/// Organization Policy condition/expression.
///
/// For example:
/// `resource.instanceName.matches("(production|test)_(.+_)?[\d]+")'` or,
/// `resource.management.auto_upgrade == true`
core.String? condition;
/// Detailed information about this custom policy constraint.
core.String? description;
/// One line display name for the UI.
core.String? displayName;
/// All the operations being applied for this constraint.
core.List<core.String>? methodTypes;
/// Name of the constraint.
///
/// This is unique within the organization. Format of the name should be *
/// `organizations/{organization_id}/customConstraints/{custom_constraint_id}`
/// Example : "organizations/123/customConstraints/custom.createOnlyE2TypeVms"
core.String? name;
/// The Resource Instance type on which this policy applies to.
///
/// Format will be of the form : "/" Example: *
/// `compute.googleapis.com/Instance`.
core.List<core.String>? resourceTypes;
GoogleCloudAssetV1CustomConstraint({
this.actionType,
this.condition,
this.description,
this.displayName,
this.methodTypes,
this.name,
this.resourceTypes,
});
GoogleCloudAssetV1CustomConstraint.fromJson(core.Map json_)
: this(
actionType: json_['actionType'] as core.String?,
condition: json_['condition'] as core.String?,
description: json_['description'] as core.String?,
displayName: json_['displayName'] as core.String?,
methodTypes: (json_['methodTypes'] as core.List?)
?.map((value) => value as core.String)
.toList(),
name: json_['name'] as core.String?,
resourceTypes: (json_['resourceTypes'] as core.List?)
?.map((value) => value as core.String)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final actionType = this.actionType;
final condition = this.condition;
final description = this.description;
final displayName = this.displayName;
final methodTypes = this.methodTypes;
final name = this.name;
final resourceTypes = this.resourceTypes;
return {
'actionType': ?actionType,
'condition': ?condition,
'description': ?description,
'displayName': ?displayName,
'methodTypes': ?methodTypes,
'name': ?name,
'resourceTypes': ?resourceTypes,
};
}
}
/// A directional edge.
class GoogleCloudAssetV1Edge {
/// The source node of the edge.
///
/// For example, it could be a full resource name for a resource node or an
/// email of an identity.
core.String? sourceNode;
/// The target node of the edge.
///
/// For example, it could be a full resource name for a resource node or an
/// email of an identity.
core.String? targetNode;
GoogleCloudAssetV1Edge({this.sourceNode, this.targetNode});
GoogleCloudAssetV1Edge.fromJson(core.Map json_)
: this(
sourceNode: json_['sourceNode'] as core.String?,
targetNode: json_['targetNode'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final sourceNode = this.sourceNode;
final targetNode = this.targetNode;
return {'sourceNode': ?sourceNode, 'targetNode': ?targetNode};
}
}
/// A Cloud Storage location.
class GoogleCloudAssetV1GcsDestination {
/// The URI of the Cloud Storage object.
///
/// It's the same URI that is used by gcloud storage. Example:
/// "gs://bucket_name/object_name". See
/// [Viewing and Editing Object Metadata](https://cloud.google.com/storage/docs/viewing-editing-metadata)
/// for more information. If the specified Cloud Storage object already exists
/// and there is no
/// [hold](https://cloud.google.com/storage/docs/object-holds), it will be
/// overwritten with the analysis result.
///
/// Required.
core.String? uri;
GoogleCloudAssetV1GcsDestination({this.uri});
GoogleCloudAssetV1GcsDestination.fromJson(core.Map json_)
: this(uri: json_['uri'] as core.String?);
core.Map<core.String, core.dynamic> toJson() {
final uri = this.uri;
return {'uri': ?uri};
}
}
/// The organization/folder/project resource governed by organization policies
/// of AnalyzeOrgPolicyGovernedContainersRequest.constraint.
class GoogleCloudAssetV1GovernedContainer {
/// The consolidated organization policy for the analyzed resource.
///
/// The consolidated organization policy is computed by merging and evaluating
/// AnalyzeOrgPolicyGovernedContainersResponse.GovernedContainer.policy_bundle.
/// The evaluation will respect the organization policy
/// [hierarchy rules](https://cloud.google.com/resource-manager/docs/organization-policy/understanding-hierarchy).
AnalyzerOrgPolicy? consolidatedPolicy;
/// The effective tags on this resource.
core.List<EffectiveTagDetails>? effectiveTags;
/// The folder(s) that this resource belongs to, in the format of
/// folders/{FOLDER_NUMBER}.
///
/// This field is available when the resource belongs (directly or
/// cascadingly) to one or more folders.
core.List<core.String>? folders;
/// The
/// [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// of an organization/folder/project resource.
core.String? fullResourceName;
/// The organization that this resource belongs to, in the format of
/// organizations/{ORGANIZATION_NUMBER}.
///
/// This field is available when the resource belongs (directly or
/// cascadingly) to an organization.
core.String? organization;
/// The
/// [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// of the parent of
/// AnalyzeOrgPolicyGovernedContainersResponse.GovernedContainer.full_resource_name.
core.String? parent;
/// The ordered list of all organization policies from the
/// consolidated_policy.attached_resource.
///
/// to the scope specified in the request. If the constraint is defined with
/// default policy, it will also appear in the list.
core.List<AnalyzerOrgPolicy>? policyBundle;
/// The project that this resource belongs to, in the format of
/// projects/{PROJECT_NUMBER}.
///
/// This field is available when the resource belongs to a project.
core.String? project;
GoogleCloudAssetV1GovernedContainer({
this.consolidatedPolicy,
this.effectiveTags,
this.folders,
this.fullResourceName,
this.organization,
this.parent,
this.policyBundle,
this.project,
});
GoogleCloudAssetV1GovernedContainer.fromJson(core.Map json_)
: this(
consolidatedPolicy: json_.containsKey('consolidatedPolicy')
? AnalyzerOrgPolicy.fromJson(
json_['consolidatedPolicy']
as core.Map<core.String, core.dynamic>,
)
: null,
effectiveTags: (json_['effectiveTags'] as core.List?)
?.map(
(value) => EffectiveTagDetails.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
folders: (json_['folders'] as core.List?)
?.map((value) => value as core.String)
.toList(),
fullResourceName: json_['fullResourceName'] as core.String?,
organization: json_['organization'] as core.String?,
parent: json_['parent'] as core.String?,
policyBundle: (json_['policyBundle'] as core.List?)
?.map(
(value) => AnalyzerOrgPolicy.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
project: json_['project'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final consolidatedPolicy = this.consolidatedPolicy;
final effectiveTags = this.effectiveTags;
final folders = this.folders;
final fullResourceName = this.fullResourceName;
final organization = this.organization;
final parent = this.parent;
final policyBundle = this.policyBundle;
final project = this.project;
return {
'consolidatedPolicy': ?consolidatedPolicy,
'effectiveTags': ?effectiveTags,
'folders': ?folders,
'fullResourceName': ?fullResourceName,
'organization': ?organization,
'parent': ?parent,
'policyBundle': ?policyBundle,
'project': ?project,
};
}
}
/// An identity under analysis.
class GoogleCloudAssetV1Identity {
/// The analysis state of this identity.
IamPolicyAnalysisState? analysisState;
/// The identity of members, formatted as appear in an
/// [IAM policy binding](https://cloud.google.com/iam/reference/rest/v1/Binding).
///
/// For example, they might be formatted like the following: -
/// user:foo@google.com - group:group1@google.com -
/// serviceAccount:s1@prj1.iam.gserviceaccount.com -
/// projectOwner:some_project_id - domain:google.com - allUsers
core.String? name;
GoogleCloudAssetV1Identity({this.analysisState, this.name});
GoogleCloudAssetV1Identity.fromJson(core.Map json_)
: this(
analysisState: json_.containsKey('analysisState')
? IamPolicyAnalysisState.fromJson(
json_['analysisState'] as core.Map<core.String, core.dynamic>,
)
: null,
name: json_['name'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final analysisState = this.analysisState;
final name = this.name;
return {'analysisState': ?analysisState, 'name': ?name};
}
}
/// The identities and group edges.
class GoogleCloudAssetV1IdentityList {
/// Group identity edges of the graph starting from the binding's group
/// members to any node of the identities.
///
/// The Edge.source_node contains a group, such as `group:parent@google.com`.
/// The Edge.target_node contains a member of the group, such as
/// `group:child@google.com` or `user:foo@google.com`. This field is present
/// only if the output_group_edges option is enabled in request.
core.List<GoogleCloudAssetV1Edge>? groupEdges;
/// Only the identities that match one of the following conditions will be
/// presented: - The identity_selector, if it is specified in request; -
/// Otherwise, identities reachable from the policy binding's members.
core.List<GoogleCloudAssetV1Identity>? identities;
GoogleCloudAssetV1IdentityList({this.groupEdges, this.identities});
GoogleCloudAssetV1IdentityList.fromJson(core.Map json_)
: this(
groupEdges: (json_['groupEdges'] as core.List?)
?.map(
(value) => GoogleCloudAssetV1Edge.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
identities: (json_['identities'] as core.List?)
?.map(
(value) => GoogleCloudAssetV1Identity.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final groupEdges = this.groupEdges;
final identities = this.identities;
return {'groupEdges': ?groupEdges, 'identities': ?identities};
}
}
/// A `Constraint` that allows or disallows a list of string values, which are
/// configured by an organization's policy administrator with a `Policy`.
class GoogleCloudAssetV1ListConstraint {
/// Indicates whether values grouped into categories can be used in
/// `Policy.allowed_values` and `Policy.denied_values`.
///
/// For example, `"in:Python"` would match any value in the 'Python' group.
core.bool? supportsIn;
/// Indicates whether subtrees of Cloud Resource Manager resource hierarchy
/// can be used in `Policy.allowed_values` and `Policy.denied_values`.
///
/// For example, `"under:folders/123"` would match any resource under the
/// 'folders/123' folder.
core.bool? supportsUnder;
GoogleCloudAssetV1ListConstraint({this.supportsIn, this.supportsUnder});
GoogleCloudAssetV1ListConstraint.fromJson(core.Map json_)
: this(
supportsIn: json_['supportsIn'] as core.bool?,
supportsUnder: json_['supportsUnder'] as core.bool?,
);
core.Map<core.String, core.dynamic> toJson() {
final supportsIn = this.supportsIn;
final supportsUnder = this.supportsUnder;
return {'supportsIn': ?supportsIn, 'supportsUnder': ?supportsUnder};
}
}
/// BigQuery destination.
class GoogleCloudAssetV1QueryAssetsOutputConfigBigQueryDestination {
/// The BigQuery dataset where the query results will be saved.
///
/// It has the format of "projects/{projectId}/datasets/{datasetId}".
///
/// Required.
core.String? dataset;
/// The BigQuery table where the query results will be saved.
///
/// If this table does not exist, a new table with the given name will be
/// created.
///
/// Required.
core.String? table;
/// Specifies the action that occurs if the destination table or partition
/// already exists.
///
/// The following values are supported: * WRITE_TRUNCATE: If the table or
/// partition already exists, BigQuery overwrites the entire table or all the
/// partitions data. * WRITE_APPEND: If the table or partition already exists,
/// BigQuery appends the data to the table or the latest partition. *
/// WRITE_EMPTY: If the table already exists and contains data, a 'duplicate'
/// error is returned in the job result. The default value is WRITE_EMPTY.
core.String? writeDisposition;
GoogleCloudAssetV1QueryAssetsOutputConfigBigQueryDestination({
this.dataset,
this.table,
this.writeDisposition,
});
GoogleCloudAssetV1QueryAssetsOutputConfigBigQueryDestination.fromJson(
core.Map json_,
) : this(
dataset: json_['dataset'] as core.String?,
table: json_['table'] as core.String?,
writeDisposition: json_['writeDisposition'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final dataset = this.dataset;
final table = this.table;
final writeDisposition = this.writeDisposition;
return {
'dataset': ?dataset,
'table': ?table,
'writeDisposition': ?writeDisposition,
};
}
}
/// A Google Cloud resource under analysis.
class GoogleCloudAssetV1Resource {
/// The analysis state of this resource.
IamPolicyAnalysisState? analysisState;
/// The
/// [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
core.String? fullResourceName;
GoogleCloudAssetV1Resource({this.analysisState, this.fullResourceName});
GoogleCloudAssetV1Resource.fromJson(core.Map json_)
: this(
analysisState: json_.containsKey('analysisState')
? IamPolicyAnalysisState.fromJson(
json_['analysisState'] as core.Map<core.String, core.dynamic>,
)
: null,
fullResourceName: json_['fullResourceName'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final analysisState = this.analysisState;
final fullResourceName = this.fullResourceName;
return {
'analysisState': ?analysisState,
'fullResourceName': ?fullResourceName,
};
}
}
/// This rule message is a customized version of the one defined in the
/// Organization Policy system.
///
/// In addition to the fields defined in the original organization policy, it
/// contains additional field(s) under specific circumstances to support
/// analysis results.
class GoogleCloudAssetV1Rule {
/// Setting this to true means that all values are allowed.
///
/// This field can be set only in Policies for list constraints.
core.bool? allowAll;
/// The evaluating condition for this rule.
Expr? condition;
/// The condition evaluation result for this rule.
///
/// Only populated if it meets all the following criteria: * There is a
/// condition defined for this rule. * This rule is within
/// AnalyzeOrgPolicyGovernedContainersResponse.GovernedContainer.consolidated_policy,
/// or
/// AnalyzeOrgPolicyGovernedAssetsResponse.GovernedAsset.consolidated_policy
/// when the AnalyzeOrgPolicyGovernedAssetsResponse.GovernedAsset has
/// AnalyzeOrgPolicyGovernedAssetsResponse.GovernedAsset.governed_resource.
ConditionEvaluation? conditionEvaluation;
/// Setting this to true means that all values are denied.
///
/// This field can be set only in Policies for list constraints.
core.bool? denyAll;
/// If `true`, then the `Policy` is enforced.
///
/// If `false`, then any configuration is acceptable. This field can be set
/// only in Policies for boolean constraints.
core.bool? enforce;
/// List of values to be used for this policy rule.
///
/// This field can be set only in policies for list constraints.
GoogleCloudAssetV1StringValues? values;
GoogleCloudAssetV1Rule({
this.allowAll,
this.condition,
this.conditionEvaluation,
this.denyAll,
this.enforce,
this.values,
});
GoogleCloudAssetV1Rule.fromJson(core.Map json_)
: this(
allowAll: json_['allowAll'] as core.bool?,
condition: json_.containsKey('condition')
? Expr.fromJson(
json_['condition'] as core.Map<core.String, core.dynamic>,
)
: null,
conditionEvaluation: json_.containsKey('conditionEvaluation')
? ConditionEvaluation.fromJson(
json_['conditionEvaluation']
as core.Map<core.String, core.dynamic>,
)
: null,
denyAll: json_['denyAll'] as core.bool?,
enforce: json_['enforce'] as core.bool?,
values: json_.containsKey('values')
? GoogleCloudAssetV1StringValues.fromJson(
json_['values'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final allowAll = this.allowAll;
final condition = this.condition;
final conditionEvaluation = this.conditionEvaluation;
final denyAll = this.denyAll;
final enforce = this.enforce;
final values = this.values;
return {
'allowAll': ?allowAll,
'condition': ?condition,
'conditionEvaluation': ?conditionEvaluation,
'denyAll': ?denyAll,
'enforce': ?enforce,
'values': ?values,
};
}
}
/// The string values for the list constraints.
typedef GoogleCloudAssetV1StringValues = $StringValues;
/// Used in `policy_type` to specify how `boolean_policy` will behave at this
/// resource.
typedef GoogleCloudOrgpolicyV1BooleanPolicy = $BooleanPolicy;
/// Used in `policy_type` to specify how `list_policy` behaves at this resource.
///
/// `ListPolicy` can define specific values and subtrees of Cloud Resource
/// Manager resource hierarchy (`Organizations`, `Folders`, `Projects`) that are
/// allowed or denied by setting the `allowed_values` and `denied_values`
/// fields. This is achieved by using the `under:` and optional `is:` prefixes.
/// The `under:` prefix is used to denote resource subtree values. The `is:`
/// prefix is used to denote specific values, and is required only if the value
/// contains a ":". Values prefixed with "is:" are treated the same as values
/// with no prefix. Ancestry subtrees must be in one of the following formats: -
/// "projects/", e.g. "projects/tokyo-rain-123" - "folders/", e.g.
/// "folders/1234" - "organizations/", e.g. "organizations/1234" The
/// `supports_under` field of the associated `Constraint` defines whether
/// ancestry prefixes can be used. You can set `allowed_values` and
/// `denied_values` in the same `Policy` if `all_values` is
/// `ALL_VALUES_UNSPECIFIED`. `ALLOW` or `DENY` are used to allow or deny all
/// values. If `all_values` is set to either `ALLOW` or `DENY`, `allowed_values`
/// and `denied_values` must be unset.
typedef GoogleCloudOrgpolicyV1ListPolicy = $ListPolicy;
/// Defines a Cloud Organization `Policy` which is used to specify `Constraints`
/// for configurations of Cloud Platform resources.
class GoogleCloudOrgpolicyV1Policy {
/// For boolean `Constraints`, whether to enforce the `Constraint` or not.
GoogleCloudOrgpolicyV1BooleanPolicy? booleanPolicy;
/// The name of the `Constraint` the `Policy` is configuring, for example,
/// `constraints/serviceuser.services`.
///
/// A \[list of available
/// constraints\](/resource-manager/docs/organization-policy/org-policy-constraints)
/// is available. Immutable after creation.
core.String? constraint;
/// An opaque tag indicating the current version of the `Policy`, used for
/// concurrency control.
///
/// When the `Policy` is returned from either a `GetPolicy` or a
/// `ListOrgPolicy` request, this `etag` indicates the version of the current
/// `Policy` to use when executing a read-modify-write loop. When the `Policy`
/// is returned from a `GetEffectivePolicy` request, the `etag` will be unset.
/// When the `Policy` is used in a `SetOrgPolicy` method, use the `etag` value
/// that was returned from a `GetOrgPolicy` request as part of a
/// read-modify-write loop for concurrency control. Not setting the `etag`in a
/// `SetOrgPolicy` request will result in an unconditional write of the
/// `Policy`.
core.String? etag;
core.List<core.int> get etagAsBytes => convert.base64.decode(etag!);
set etagAsBytes(core.List<core.int> bytes_) {
etag = convert.base64
.encode(bytes_)
.replaceAll('/', '_')
.replaceAll('+', '-');
}
/// List of values either allowed or disallowed.
GoogleCloudOrgpolicyV1ListPolicy? listPolicy;
/// Restores the default behavior of the constraint; independent of
/// `Constraint` type.
GoogleCloudOrgpolicyV1RestoreDefault? restoreDefault;
/// The time stamp the `Policy` was previously updated.
///
/// This is set by the server, not specified by the caller, and represents the
/// last time a call to `SetOrgPolicy` was made for that `Policy`. Any value
/// set by the client will be ignored.
core.String? updateTime;
/// Version of the `Policy`.
///
/// Default version is 0;
core.int? version;
GoogleCloudOrgpolicyV1Policy({
this.booleanPolicy,
this.constraint,
this.etag,
this.listPolicy,
this.restoreDefault,
this.updateTime,
this.version,
});
GoogleCloudOrgpolicyV1Policy.fromJson(core.Map json_)
: this(
booleanPolicy: json_.containsKey('booleanPolicy')
? GoogleCloudOrgpolicyV1BooleanPolicy.fromJson(
json_['booleanPolicy'] as core.Map<core.String, core.dynamic>,
)
: null,
constraint: json_['constraint'] as core.String?,
etag: json_['etag'] as core.String?,
listPolicy: json_.containsKey('listPolicy')
? GoogleCloudOrgpolicyV1ListPolicy.fromJson(
json_['listPolicy'] as core.Map<core.String, core.dynamic>,
)
: null,
restoreDefault: json_.containsKey('restoreDefault')
? GoogleCloudOrgpolicyV1RestoreDefault.fromJson(
json_['restoreDefault'] as core.Map<core.String, core.dynamic>,
)
: null,
updateTime: json_['updateTime'] as core.String?,
version: json_['version'] as core.int?,
);
core.Map<core.String, core.dynamic> toJson() {
final booleanPolicy = this.booleanPolicy;
final constraint = this.constraint;
final etag = this.etag;
final listPolicy = this.listPolicy;
final restoreDefault = this.restoreDefault;
final updateTime = this.updateTime;
final version = this.version;
return {
'booleanPolicy': ?booleanPolicy,
'constraint': ?constraint,
'etag': ?etag,
'listPolicy': ?listPolicy,
'restoreDefault': ?restoreDefault,
'updateTime': ?updateTime,
'version': ?version,
};
}
}
/// Ignores policies set above this resource and restores the
/// `constraint_default` enforcement behavior of the specific `Constraint` at
/// this resource.
///
/// Suppose that `constraint_default` is set to `ALLOW` for the `Constraint`
/// `constraints/serviceuser.services`. Suppose that organization foo.com sets a
/// `Policy` at their Organization resource node that restricts the allowed
/// service activations to deny all service activations. They could then set a
/// `Policy` with the `policy_type` `restore_default` on several experimental
/// projects, restoring the `constraint_default` enforcement of the `Constraint`
/// for only those projects, allowing those projects to have all services
/// activated.
typedef GoogleCloudOrgpolicyV1RestoreDefault = $Empty;
/// An `AccessLevel` is a label that can be applied to requests to Google Cloud
/// services, along with a list of requirements necessary for the label to be
/// applied.
class GoogleIdentityAccesscontextmanagerV1AccessLevel {
/// A `BasicLevel` composed of `Conditions`.
GoogleIdentityAccesscontextmanagerV1BasicLevel? basic;
/// A `CustomLevel` written in the Common Expression Language.
GoogleIdentityAccesscontextmanagerV1CustomLevel? custom;
/// Description of the `AccessLevel` and its use.
///
/// Does not affect behavior.
core.String? description;
/// Identifier.
///
/// Resource name for the `AccessLevel`. Format:
/// `accessPolicies/{access_policy}/accessLevels/{access_level}`. The
/// `access_level` component must begin with a letter, followed by
/// alphanumeric characters or `_`. Its maximum length is 50 characters. After
/// you create an `AccessLevel`, you cannot change its `name`.
core.String? name;
/// Human readable title.
///
/// Must be unique within the Policy.
core.String? title;
GoogleIdentityAccesscontextmanagerV1AccessLevel({
this.basic,
this.custom,
this.description,
this.name,
this.title,
});
GoogleIdentityAccesscontextmanagerV1AccessLevel.fromJson(core.Map json_)
: this(
basic: json_.containsKey('basic')
? GoogleIdentityAccesscontextmanagerV1BasicLevel.fromJson(
json_['basic'] as core.Map<core.String, core.dynamic>,
)
: null,
custom: json_.containsKey('custom')
? GoogleIdentityAccesscontextmanagerV1CustomLevel.fromJson(
json_['custom'] as core.Map<core.String, core.dynamic>,
)
: null,
description: json_['description'] as core.String?,
name: json_['name'] as core.String?,
title: json_['title'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final basic = this.basic;
final custom = this.custom;
final description = this.description;
final name = this.name;
final title = this.title;
return {
'basic': ?basic,
'custom': ?custom,
'description': ?description,
'name': ?name,
'title': ?title,
};
}
}
/// `AccessPolicy` is a container for `AccessLevels` (which define the necessary
/// attributes to use Google Cloud services) and `ServicePerimeters` (which
/// define regions of services able to freely pass data within a perimeter).
///
/// An access policy is globally visible within an organization, and the
/// restrictions it specifies apply to all projects within an organization.
typedef GoogleIdentityAccesscontextmanagerV1AccessPolicy = $AccessPolicy;
/// Identification for an API Operation.
class GoogleIdentityAccesscontextmanagerV1ApiOperation {
/// API methods or permissions to allow.
///
/// Method or permission must belong to the service specified by
/// `service_name` field. A single MethodSelector entry with `*` specified for
/// the `method` field will allow all methods AND permissions for the service
/// specified in `service_name`.
core.List<GoogleIdentityAccesscontextmanagerV1MethodSelector>?
methodSelectors;
/// The name of the API whose methods or permissions the IngressPolicy or
/// EgressPolicy want to allow.
///
/// A single ApiOperation with `service_name` field set to `*` will allow all
/// methods AND permissions for all services.
core.String? serviceName;
GoogleIdentityAccesscontextmanagerV1ApiOperation({
this.methodSelectors,
this.serviceName,
});
GoogleIdentityAccesscontextmanagerV1ApiOperation.fromJson(core.Map json_)
: this(
methodSelectors: (json_['methodSelectors'] as core.List?)
?.map(
(value) =>
GoogleIdentityAccesscontextmanagerV1MethodSelector.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
serviceName: json_['serviceName'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final methodSelectors = this.methodSelectors;
final serviceName = this.serviceName;
return {'methodSelectors': ?methodSelectors, 'serviceName': ?serviceName};
}
}
/// `BasicLevel` is an `AccessLevel` using a set of recommended features.
class GoogleIdentityAccesscontextmanagerV1BasicLevel {
/// How the `conditions` list should be combined to determine if a request is
/// granted this `AccessLevel`.
///
/// If AND is used, each `Condition` in `conditions` must be satisfied for the
/// `AccessLevel` to be applied. If OR is used, at least one `Condition` in
/// `conditions` must be satisfied for the `AccessLevel` to be applied.
/// Default behavior is AND.
/// Possible string values are:
/// - "AND" : All `Conditions` must be true for the `BasicLevel` to be true.
/// - "OR" : If at least one `Condition` is true, then the `BasicLevel` is
/// true.
core.String? combiningFunction;
/// A list of requirements for the `AccessLevel` to be granted.
///
/// Required.
core.List<GoogleIdentityAccesscontextmanagerV1Condition>? conditions;
GoogleIdentityAccesscontextmanagerV1BasicLevel({
this.combiningFunction,
this.conditions,
});
GoogleIdentityAccesscontextmanagerV1BasicLevel.fromJson(core.Map json_)
: this(
combiningFunction: json_['combiningFunction'] as core.String?,
conditions: (json_['conditions'] as core.List?)
?.map(
(value) => GoogleIdentityAccesscontextmanagerV1Condition.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final combiningFunction = this.combiningFunction;
final conditions = this.conditions;
return {'combiningFunction': ?combiningFunction, 'conditions': ?conditions};
}
}
/// A condition necessary for an `AccessLevel` to be granted.
///
/// The Condition is an AND over its fields. So a Condition is true if: 1) the
/// request IP is from one of the listed subnetworks AND 2) the originating
/// device complies with the listed device policy AND 3) all listed access
/// levels are granted AND 4) the request was sent at a time allowed by the
/// DateTimeRestriction.
class GoogleIdentityAccesscontextmanagerV1Condition {
/// Device specific restrictions, all restrictions must hold for the Condition
/// to be true.
///
/// If not specified, all devices are allowed.
GoogleIdentityAccesscontextmanagerV1DevicePolicy? devicePolicy;
/// CIDR block IP subnetwork specification.
///
/// May be IPv4 or IPv6. Note that for a CIDR IP address block, the specified
/// IP address portion must be properly truncated (i.e. all the host bits must
/// be zero) or the input is considered malformed. For example, "192.0.2.0/24"
/// is accepted but "192.0.2.1/24" is not. Similarly, for IPv6,
/// "2001:db8::/32" is accepted whereas "2001:db8::1/32" is not. The
/// originating IP of a request must be in one of the listed subnets in order
/// for this Condition to be true. If empty, all IP addresses are allowed.
core.List<core.String>? ipSubnetworks;
/// The request must be made by one of the provided user or service accounts.
///
/// Groups are not supported. Syntax: `user:{emailid}`
/// `serviceAccount:{emailid}` If not specified, a request may come from any
/// user.
core.List<core.String>? members;
/// Whether to negate the Condition.
///
/// If true, the Condition becomes a NAND over its non-empty fields. Any
/// non-empty field criteria evaluating to false will result in the Condition
/// to be satisfied. Defaults to false.
core.bool? negate;
/// The request must originate from one of the provided countries/regions.
///
/// Must be valid ISO 3166-1 alpha-2 codes.
core.List<core.String>? regions;
/// A list of other access levels defined in the same `Policy`, referenced by
/// resource name.
///
/// Referencing an `AccessLevel` which does not exist is an error. All access
/// levels listed must be granted for the Condition to be true. Example:
/// "`accessPolicies/MY_POLICY/accessLevels/LEVEL_NAME"`
core.List<core.String>? requiredAccessLevels;
/// The request must originate from one of the provided VPC networks in Google
/// Cloud.
///
/// Cannot specify this field together with `ip_subnetworks`.
core.List<GoogleIdentityAccesscontextmanagerV1VpcNetworkSource>?
vpcNetworkSources;
GoogleIdentityAccesscontextmanagerV1Condition({
this.devicePolicy,
this.ipSubnetworks,
this.members,
this.negate,
this.regions,
this.requiredAccessLevels,
this.vpcNetworkSources,
});
GoogleIdentityAccesscontextmanagerV1Condition.fromJson(core.Map json_)
: this(
devicePolicy: json_.containsKey('devicePolicy')
? GoogleIdentityAccesscontextmanagerV1DevicePolicy.fromJson(
json_['devicePolicy'] as core.Map<core.String, core.dynamic>,
)
: null,
ipSubnetworks: (json_['ipSubnetworks'] as core.List?)
?.map((value) => value as core.String)
.toList(),
members: (json_['members'] as core.List?)
?.map((value) => value as core.String)
.toList(),
negate: json_['negate'] as core.bool?,
regions: (json_['regions'] as core.List?)
?.map((value) => value as core.String)
.toList(),
requiredAccessLevels: (json_['requiredAccessLevels'] as core.List?)
?.map((value) => value as core.String)
.toList(),
vpcNetworkSources: (json_['vpcNetworkSources'] as core.List?)
?.map(
(value) =>
GoogleIdentityAccesscontextmanagerV1VpcNetworkSource.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final devicePolicy = this.devicePolicy;
final ipSubnetworks = this.ipSubnetworks;
final members = this.members;
final negate = this.negate;
final regions = this.regions;
final requiredAccessLevels = this.requiredAccessLevels;
final vpcNetworkSources = this.vpcNetworkSources;
return {
'devicePolicy': ?devicePolicy,
'ipSubnetworks': ?ipSubnetworks,
'members': ?members,
'negate': ?negate,
'regions': ?regions,
'requiredAccessLevels': ?requiredAccessLevels,
'vpcNetworkSources': ?vpcNetworkSources,
};
}
}
/// `CustomLevel` is an `AccessLevel` using the Cloud Common Expression Language
/// to represent the necessary conditions for the level to apply to a request.
///
/// See CEL spec at: https://github.com/google/cel-spec
class GoogleIdentityAccesscontextmanagerV1CustomLevel {
/// A Cloud CEL expression evaluating to a boolean.
///
/// Required.
Expr? expr;
GoogleIdentityAccesscontextmanagerV1CustomLevel({this.expr});
GoogleIdentityAccesscontextmanagerV1CustomLevel.fromJson(core.Map json_)
: this(
expr: json_.containsKey('expr')
? Expr.fromJson(
json_['expr'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final expr = this.expr;
return {'expr': ?expr};
}
}
/// `DevicePolicy` specifies device specific restrictions necessary to acquire a
/// given access level.
///
/// A `DevicePolicy` specifies requirements for requests from devices to be
/// granted access levels, it does not do any enforcement on the device.
/// `DevicePolicy` acts as an AND over all specified fields, and each repeated
/// field is an OR over its elements. Any unset fields are ignored. For example,
/// if the proto is { os_type : DESKTOP_WINDOWS, os_type : DESKTOP_LINUX,
/// encryption_status: ENCRYPTED}, then the DevicePolicy will be true for
/// requests originating from encrypted Linux desktops and encrypted Windows
/// desktops.
class GoogleIdentityAccesscontextmanagerV1DevicePolicy {
/// Allowed device management levels, an empty list allows all management
/// levels.
core.List<core.String>? allowedDeviceManagementLevels;
/// Allowed encryptions statuses, an empty list allows all statuses.
core.List<core.String>? allowedEncryptionStatuses;
/// Allowed OS versions, an empty list allows all types and all versions.
core.List<GoogleIdentityAccesscontextmanagerV1OsConstraint>? osConstraints;
/// Whether the device needs to be approved by the customer admin.
core.bool? requireAdminApproval;
/// Whether the device needs to be corp owned.
core.bool? requireCorpOwned;
/// Whether or not screenlock is required for the DevicePolicy to be true.
///
/// Defaults to `false`.
core.bool? requireScreenlock;
GoogleIdentityAccesscontextmanagerV1DevicePolicy({
this.allowedDeviceManagementLevels,
this.allowedEncryptionStatuses,
this.osConstraints,
this.requireAdminApproval,
this.requireCorpOwned,
this.requireScreenlock,
});
GoogleIdentityAccesscontextmanagerV1DevicePolicy.fromJson(core.Map json_)
: this(
allowedDeviceManagementLevels:
(json_['allowedDeviceManagementLevels'] as core.List?)
?.map((value) => value as core.String)
.toList(),
allowedEncryptionStatuses:
(json_['allowedEncryptionStatuses'] as core.List?)
?.map((value) => value as core.String)
.toList(),
osConstraints: (json_['osConstraints'] as core.List?)
?.map(
(value) =>
GoogleIdentityAccesscontextmanagerV1OsConstraint.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
requireAdminApproval: json_['requireAdminApproval'] as core.bool?,
requireCorpOwned: json_['requireCorpOwned'] as core.bool?,
requireScreenlock: json_['requireScreenlock'] as core.bool?,
);
core.Map<core.String, core.dynamic> toJson() {
final allowedDeviceManagementLevels = this.allowedDeviceManagementLevels;
final allowedEncryptionStatuses = this.allowedEncryptionStatuses;
final osConstraints = this.osConstraints;
final requireAdminApproval = this.requireAdminApproval;
final requireCorpOwned = this.requireCorpOwned;
final requireScreenlock = this.requireScreenlock;
return {
'allowedDeviceManagementLevels': ?allowedDeviceManagementLevels,
'allowedEncryptionStatuses': ?allowedEncryptionStatuses,
'osConstraints': ?osConstraints,
'requireAdminApproval': ?requireAdminApproval,
'requireCorpOwned': ?requireCorpOwned,
'requireScreenlock': ?requireScreenlock,
};
}
}
/// Defines the conditions under which an EgressPolicy matches a request.
///
/// Conditions based on information about the source of the request. Note that
/// if the destination of the request is also protected by a ServicePerimeter,
/// then that ServicePerimeter must have an IngressPolicy which allows access in
/// order for this request to succeed.
class GoogleIdentityAccesscontextmanagerV1EgressFrom {
/// A list of identities that are allowed access through \[EgressPolicy\].
///
/// Identities can be an individual user, service account, Google group,
/// third-party identity, or agent identity. For the list of supported
/// identity types, see
/// https://docs.cloud.google.com/vpc-service-controls/docs/supported-identities.
core.List<core.String>? identities;
/// Specifies the type of identities that are allowed access to outside the
/// perimeter.
///
/// If left unspecified, then members of `identities` field will be allowed
/// access.
/// Possible string values are:
/// - "IDENTITY_TYPE_UNSPECIFIED" : No blanket identity group specified.
/// - "ANY_IDENTITY" : Authorize access from all identities outside the
/// perimeter.
/// - "ANY_USER_ACCOUNT" : Authorize access from all human users outside the
/// perimeter.
/// - "ANY_SERVICE_ACCOUNT" : Authorize access from all service accounts
/// outside the perimeter.
core.String? identityType;
/// Whether to enforce traffic restrictions based on `sources` field.
///
/// If the `sources` fields is non-empty, then this field must be set to
/// `SOURCE_RESTRICTION_ENABLED`.
/// Possible string values are:
/// - "SOURCE_RESTRICTION_UNSPECIFIED" : Enforcement preference unspecified,
/// will not enforce traffic restrictions based on `sources` in EgressFrom.
/// - "SOURCE_RESTRICTION_ENABLED" : Enforcement preference enabled, traffic
/// restrictions will be enforced based on `sources` in EgressFrom.
/// - "SOURCE_RESTRICTION_DISABLED" : Enforcement preference disabled, will
/// not enforce traffic restrictions based on `sources` in EgressFrom.
core.String? sourceRestriction;
/// Sources that this EgressPolicy authorizes access from.
///
/// If this field is not empty, then `source_restriction` must be set to
/// `SOURCE_RESTRICTION_ENABLED`.
core.List<GoogleIdentityAccesscontextmanagerV1EgressSource>? sources;
GoogleIdentityAccesscontextmanagerV1EgressFrom({
this.identities,
this.identityType,
this.sourceRestriction,
this.sources,
});
GoogleIdentityAccesscontextmanagerV1EgressFrom.fromJson(core.Map json_)
: this(
identities: (json_['identities'] as core.List?)
?.map((value) => value as core.String)
.toList(),
identityType: json_['identityType'] as core.String?,
sourceRestriction: json_['sourceRestriction'] as core.String?,
sources: (json_['sources'] as core.List?)
?.map(
(value) =>
GoogleIdentityAccesscontextmanagerV1EgressSource.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final identities = this.identities;
final identityType = this.identityType;
final sourceRestriction = this.sourceRestriction;
final sources = this.sources;
return {
'identities': ?identities,
'identityType': ?identityType,
'sourceRestriction': ?sourceRestriction,
'sources': ?sources,
};
}
}
/// Policy for egress from perimeter.
///
/// EgressPolicies match requests based on `egress_from` and `egress_to`
/// stanzas. For an EgressPolicy to match, both `egress_from` and `egress_to`
/// stanzas must be matched. If an EgressPolicy matches a request, the request
/// is allowed to span the ServicePerimeter boundary. For example, an
/// EgressPolicy can be used to allow VMs on networks within the
/// ServicePerimeter to access a defined set of projects outside the perimeter
/// in certain contexts (e.g. to read data from a Cloud Storage bucket or query
/// against a BigQuery dataset). EgressPolicies are concerned with the
/// *resources* that a request relates as well as the API services and API
/// actions being used. They do not related to the direction of data movement.
/// More detailed documentation for this concept can be found in the
/// descriptions of EgressFrom and EgressTo.
class GoogleIdentityAccesscontextmanagerV1EgressPolicy {
/// Defines conditions on the source of a request causing this EgressPolicy to
/// apply.
GoogleIdentityAccesscontextmanagerV1EgressFrom? egressFrom;
/// Defines the conditions on the ApiOperation and destination resources that
/// cause this EgressPolicy to apply.
GoogleIdentityAccesscontextmanagerV1EgressTo? egressTo;
/// Human-readable title for the egress rule.
///
/// The title must be unique within the perimeter and can not exceed 100
/// characters. Within the access policy, the combined length of all rule
/// titles must not exceed 240,000 characters.
///
/// Optional.
core.String? title;
GoogleIdentityAccesscontextmanagerV1EgressPolicy({
this.egressFrom,
this.egressTo,
this.title,
});
GoogleIdentityAccesscontextmanagerV1EgressPolicy.fromJson(core.Map json_)
: this(
egressFrom: json_.containsKey('egressFrom')
? GoogleIdentityAccesscontextmanagerV1EgressFrom.fromJson(
json_['egressFrom'] as core.Map<core.String, core.dynamic>,
)
: null,
egressTo: json_.containsKey('egressTo')
? GoogleIdentityAccesscontextmanagerV1EgressTo.fromJson(
json_['egressTo'] as core.Map<core.String, core.dynamic>,
)
: null,
title: json_['title'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final egressFrom = this.egressFrom;
final egressTo = this.egressTo;
final title = this.title;
return {'egressFrom': ?egressFrom, 'egressTo': ?egressTo, 'title': ?title};
}
}
/// The source that EgressPolicy authorizes access from inside the
/// ServicePerimeter to somewhere outside the ServicePerimeter boundaries.
typedef GoogleIdentityAccesscontextmanagerV1EgressSource = $EgressSource;
/// Defines the conditions under which an EgressPolicy matches a request.
///
/// Conditions are based on information about the ApiOperation intended to be
/// performed on the `resources` specified. Note that if the destination of the
/// request is also protected by a ServicePerimeter, then that ServicePerimeter
/// must have an IngressPolicy which allows access in order for this request to
/// succeed. The request must match `operations` AND `resources` fields in order
/// to be allowed egress out of the perimeter.
class GoogleIdentityAccesscontextmanagerV1EgressTo {
/// A list of external resources that are allowed to be accessed.
///
/// Only AWS and Azure resources are supported. For Amazon S3, the supported
/// formats are s3://BUCKET_NAME, s3a://BUCKET_NAME, and s3n://BUCKET_NAME.
/// For Azure Storage, the supported format is
/// azure://myaccount.blob.core.windows.net/CONTAINER_NAME. A request matches
/// if it contains an external resource in this list (Example:
/// s3://bucket/path). Currently '*' is not allowed.
core.List<core.String>? externalResources;
/// A list of ApiOperations allowed to be performed by the sources specified
/// in the corresponding EgressFrom.
///
/// A request matches if it uses an operation/service in this list.
core.List<GoogleIdentityAccesscontextmanagerV1ApiOperation>? operations;
/// A list of resources, currently only projects in the form `projects/`, that
/// are allowed to be accessed by sources defined in the corresponding
/// EgressFrom.
///
/// A request matches if it contains a resource in this list. If `*` is
/// specified for `resources`, then this EgressTo rule will authorize access
/// to all resources outside the perimeter.
core.List<core.String>? resources;
/// IAM roles that represent the set of operations that the sources specified
/// in the corresponding EgressFrom.
///
/// are allowed to perform in this ServicePerimeter.
core.List<core.String>? roles;
GoogleIdentityAccesscontextmanagerV1EgressTo({
this.externalResources,
this.operations,
this.resources,
this.roles,
});
GoogleIdentityAccesscontextmanagerV1EgressTo.fromJson(core.Map json_)
: this(
externalResources: (json_['externalResources'] as core.List?)
?.map((value) => value as core.String)
.toList(),
operations: (json_['operations'] as core.List?)
?.map(
(value) =>
GoogleIdentityAccesscontextmanagerV1ApiOperation.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
resources: (json_['resources'] as core.List?)
?.map((value) => value as core.String)
.toList(),
roles: (json_['roles'] as core.List?)
?.map((value) => value as core.String)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final externalResources = this.externalResources;
final operations = this.operations;
final resources = this.resources;
final roles = this.roles;
return {
'externalResources': ?externalResources,
'operations': ?operations,
'resources': ?resources,
'roles': ?roles,
};
}
}
/// Defines the conditions under which an IngressPolicy matches a request.
///
/// Conditions are based on information about the source of the request. The
/// request must satisfy what is defined in `sources` AND identity related
/// fields in order to match.
class GoogleIdentityAccesscontextmanagerV1IngressFrom {
/// A list of identities that are allowed access through \[IngressPolicy\].
///
/// Identities can be an individual user, service account, Google group,
/// third-party identity, or agent identity. For the list of supported
/// identity types, see
/// https://docs.cloud.google.com/vpc-service-controls/docs/supported-identities.
core.List<core.String>? identities;
/// Specifies the type of identities that are allowed access from outside the
/// perimeter.
///
/// If left unspecified, then members of `identities` field will be allowed
/// access.
/// Possible string values are:
/// - "IDENTITY_TYPE_UNSPECIFIED" : No blanket identity group specified.
/// - "ANY_IDENTITY" : Authorize access from all identities outside the
/// perimeter.
/// - "ANY_USER_ACCOUNT" : Authorize access from all human users outside the
/// perimeter.
/// - "ANY_SERVICE_ACCOUNT" : Authorize access from all service accounts
/// outside the perimeter.
core.String? identityType;
/// Sources that this IngressPolicy authorizes access from.
core.List<GoogleIdentityAccesscontextmanagerV1IngressSource>? sources;
GoogleIdentityAccesscontextmanagerV1IngressFrom({
this.identities,
this.identityType,
this.sources,
});
GoogleIdentityAccesscontextmanagerV1IngressFrom.fromJson(core.Map json_)
: this(
identities: (json_['identities'] as core.List?)
?.map((value) => value as core.String)
.toList(),
identityType: json_['identityType'] as core.String?,
sources: (json_['sources'] as core.List?)
?.map(
(value) =>
GoogleIdentityAccesscontextmanagerV1IngressSource.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final identities = this.identities;
final identityType = this.identityType;
final sources = this.sources;
return {
'identities': ?identities,
'identityType': ?identityType,
'sources': ?sources,
};
}
}
/// Policy for ingress into ServicePerimeter.
///
/// IngressPolicies match requests based on `ingress_from` and `ingress_to`
/// stanzas. For an ingress policy to match, both the `ingress_from` and
/// `ingress_to` stanzas must be matched. If an IngressPolicy matches a request,
/// the request is allowed through the perimeter boundary from outside the
/// perimeter. For example, access from the internet can be allowed either based
/// on an AccessLevel or, for traffic hosted on Google Cloud, the project of the
/// source network. For access from private networks, using the project of the
/// hosting network is required. Individual ingress policies can be limited by
/// restricting which services and/or actions they match using the `ingress_to`
/// field.
class GoogleIdentityAccesscontextmanagerV1IngressPolicy {
/// Defines the conditions on the source of a request causing this
/// IngressPolicy to apply.
GoogleIdentityAccesscontextmanagerV1IngressFrom? ingressFrom;
/// Defines the conditions on the ApiOperation and request destination that
/// cause this IngressPolicy to apply.
GoogleIdentityAccesscontextmanagerV1IngressTo? ingressTo;
/// Human-readable title for the ingress rule.
///
/// The title must be unique within the perimeter and can not exceed 100
/// characters. Within the access policy, the combined length of all rule
/// titles must not exceed 240,000 characters.
///
/// Optional.
core.String? title;
GoogleIdentityAccesscontextmanagerV1IngressPolicy({
this.ingressFrom,
this.ingressTo,
this.title,
});
GoogleIdentityAccesscontextmanagerV1IngressPolicy.fromJson(core.Map json_)
: this(
ingressFrom: json_.containsKey('ingressFrom')
? GoogleIdentityAccesscontextmanagerV1IngressFrom.fromJson(
json_['ingressFrom'] as core.Map<core.String, core.dynamic>,
)
: null,
ingressTo: json_.containsKey('ingressTo')
? GoogleIdentityAccesscontextmanagerV1IngressTo.fromJson(
json_['ingressTo'] as core.Map<core.String, core.dynamic>,
)
: null,
title: json_['title'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final ingressFrom = this.ingressFrom;
final ingressTo = this.ingressTo;
final title = this.title;
return {
'ingressFrom': ?ingressFrom,
'ingressTo': ?ingressTo,
'title': ?title,
};
}
}
/// The source that IngressPolicy authorizes access from.
typedef GoogleIdentityAccesscontextmanagerV1IngressSource = $IngressSource;
/// Defines the conditions under which an IngressPolicy matches a request.
///
/// Conditions are based on information about the ApiOperation intended to be
/// performed on the target resource of the request. The request must satisfy
/// what is defined in `operations` AND `resources` in order to match.
class GoogleIdentityAccesscontextmanagerV1IngressTo {
/// A list of ApiOperations allowed to be performed by the sources specified
/// in corresponding IngressFrom in this ServicePerimeter.
core.List<GoogleIdentityAccesscontextmanagerV1ApiOperation>? operations;
/// A list of resources, currently only projects in the form `projects/`,
/// protected by this ServicePerimeter that are allowed to be accessed by
/// sources defined in the corresponding IngressFrom.
///
/// If a single `*` is specified, then access to all resources inside the
/// perimeter are allowed.
core.List<core.String>? resources;
/// IAM roles that represent the set of operations that the sources specified
/// in the corresponding IngressFrom are allowed to perform in this
/// ServicePerimeter.
core.List<core.String>? roles;
GoogleIdentityAccesscontextmanagerV1IngressTo({
this.operations,
this.resources,
this.roles,
});
GoogleIdentityAccesscontextmanagerV1IngressTo.fromJson(core.Map json_)
: this(
operations: (json_['operations'] as core.List?)
?.map(
(value) =>
GoogleIdentityAccesscontextmanagerV1ApiOperation.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
resources: (json_['resources'] as core.List?)
?.map((value) => value as core.String)
.toList(),
roles: (json_['roles'] as core.List?)
?.map((value) => value as core.String)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final operations = this.operations;
final resources = this.resources;
final roles = this.roles;
return {
'operations': ?operations,
'resources': ?resources,
'roles': ?roles,
};
}
}
/// An allowed method or permission of a service specified in ApiOperation.
typedef GoogleIdentityAccesscontextmanagerV1MethodSelector = $MethodSelector;
/// A restriction on the OS type and version of devices making requests.
typedef GoogleIdentityAccesscontextmanagerV1OsConstraint = $OsConstraint;
/// `ServicePerimeter` describes a set of Google Cloud resources which can
/// freely import and export data amongst themselves, but not export outside of
/// the `ServicePerimeter`.
///
/// If a request with a source within this `ServicePerimeter` has a target
/// outside of the `ServicePerimeter`, the request will be blocked. Otherwise
/// the request is allowed. There are two types of Service Perimeter - Regular
/// and Bridge. Regular Service Perimeters cannot overlap, a single Google Cloud
/// project or VPC network can only belong to a single regular Service
/// Perimeter. Service Perimeter Bridges can contain only Google Cloud projects
/// as members, a single Google Cloud project may belong to multiple Service
/// Perimeter Bridges.
class GoogleIdentityAccesscontextmanagerV1ServicePerimeter {
/// Description of the `ServicePerimeter` and its use.
///
/// Does not affect behavior.
core.String? description;
/// An opaque identifier for the current version of the `ServicePerimeter`.
///
/// This identifier does not follow any specific format. If an etag is not
/// provided, the operation will be performed as if a valid etag is provided.
///
/// Optional.
core.String? etag;
/// Identifier.
///
/// Resource name for the `ServicePerimeter`. Format:
/// `accessPolicies/{access_policy}/servicePerimeters/{service_perimeter}`.
/// The `service_perimeter` component must begin with a letter, followed by
/// alphanumeric characters or `_`. After you create a `ServicePerimeter`, you
/// cannot change its `name`.
core.String? name;
/// Perimeter type indicator.
///
/// A single project or VPC network is allowed to be a member of single
/// regular perimeter, but multiple service perimeter bridges. A project
/// cannot be a included in a perimeter bridge without being included in
/// regular perimeter. For perimeter bridges, the restricted service list as
/// well as access level lists must be empty.
/// Possible string values are:
/// - "PERIMETER_TYPE_REGULAR" : Regular Perimeter. When no value is
/// specified, the perimeter uses this type.
/// - "PERIMETER_TYPE_BRIDGE" : Perimeter Bridge.
core.String? perimeterType;
/// Proposed (or dry run) ServicePerimeter configuration.
///
/// This configuration allows to specify and test ServicePerimeter
/// configuration without enforcing actual access restrictions. Only allowed
/// to be set when the "use_explicit_dry_run_spec" flag is set.
GoogleIdentityAccesscontextmanagerV1ServicePerimeterConfig? spec;
/// Current ServicePerimeter configuration.
///
/// Specifies sets of resources, restricted services and access levels that
/// determine perimeter content and boundaries.
GoogleIdentityAccesscontextmanagerV1ServicePerimeterConfig? status;
/// Human readable title.
///
/// Must be unique within the Policy.
core.String? title;
/// Use explicit dry run spec flag.
///
/// Ordinarily, a dry-run spec implicitly exists for all Service Perimeters,
/// and that spec is identical to the status for those Service Perimeters.
/// When this flag is set, it inhibits the generation of the implicit spec,
/// thereby allowing the user to explicitly provide a configuration ("spec")
/// to use in a dry-run version of the Service Perimeter. This allows the user
/// to test changes to the enforced config ("status") without actually
/// enforcing them. This testing is done through analyzing the differences
/// between currently enforced and suggested restrictions.
/// use_explicit_dry_run_spec must bet set to True if any of the fields in the
/// spec are set to non-default values.
core.bool? useExplicitDryRunSpec;
GoogleIdentityAccesscontextmanagerV1ServicePerimeter({
this.description,
this.etag,
this.name,
this.perimeterType,
this.spec,
this.status,
this.title,
this.useExplicitDryRunSpec,
});
GoogleIdentityAccesscontextmanagerV1ServicePerimeter.fromJson(core.Map json_)
: this(
description: json_['description'] as core.String?,
etag: json_['etag'] as core.String?,
name: json_['name'] as core.String?,
perimeterType: json_['perimeterType'] as core.String?,
spec: json_.containsKey('spec')
? GoogleIdentityAccesscontextmanagerV1ServicePerimeterConfig.fromJson(
json_['spec'] as core.Map<core.String, core.dynamic>,
)
: null,
status: json_.containsKey('status')
? GoogleIdentityAccesscontextmanagerV1ServicePerimeterConfig.fromJson(
json_['status'] as core.Map<core.String, core.dynamic>,
)
: null,
title: json_['title'] as core.String?,
useExplicitDryRunSpec: json_['useExplicitDryRunSpec'] as core.bool?,
);
core.Map<core.String, core.dynamic> toJson() {
final description = this.description;
final etag = this.etag;
final name = this.name;
final perimeterType = this.perimeterType;
final spec = this.spec;
final status = this.status;
final title = this.title;
final useExplicitDryRunSpec = this.useExplicitDryRunSpec;
return {
'description': ?description,
'etag': ?etag,
'name': ?name,
'perimeterType': ?perimeterType,
'spec': ?spec,
'status': ?status,
'title': ?title,
'useExplicitDryRunSpec': ?useExplicitDryRunSpec,
};
}
}
/// `ServicePerimeterConfig` specifies a set of Google Cloud resources that
/// describe specific Service Perimeter configuration.
class GoogleIdentityAccesscontextmanagerV1ServicePerimeterConfig {
/// A list of `AccessLevel` resource names that allow resources within the
/// `ServicePerimeter` to be accessed from the internet.
///
/// `AccessLevels` listed must be in the same policy as this
/// `ServicePerimeter`. Referencing a nonexistent `AccessLevel` is a syntax
/// error. If no `AccessLevel` names are listed, resources within the
/// perimeter can only be accessed via Google Cloud calls with request origins
/// within the perimeter. Example:
/// `"accessPolicies/MY_POLICY/accessLevels/MY_LEVEL"`. For Service Perimeter
/// Bridge, must be empty.
core.List<core.String>? accessLevels;
/// List of EgressPolicies to apply to the perimeter.
///
/// A perimeter may have multiple EgressPolicies, each of which is evaluated
/// separately. Access is granted if any EgressPolicy grants it. Must be empty
/// for a perimeter bridge.
core.List<GoogleIdentityAccesscontextmanagerV1EgressPolicy>? egressPolicies;
/// List of IngressPolicies to apply to the perimeter.
///
/// A perimeter may have multiple IngressPolicies, each of which is evaluated
/// separately. Access is granted if any Ingress Policy grants it. Must be
/// empty for a perimeter bridge.
core.List<GoogleIdentityAccesscontextmanagerV1IngressPolicy>? ingressPolicies;
/// A list of Google Cloud resources that are inside of the service perimeter.
///
/// Currently only projects and VPCs are allowed. Project format:
/// `projects/{project_number}` VPC network format:
/// `//compute.googleapis.com/projects/{PROJECT_ID}/global/networks/{NAME}`.
core.List<core.String>? resources;
/// Google Cloud services that are subject to the Service Perimeter
/// restrictions.
///
/// For example, if `storage.googleapis.com` is specified, access to the
/// storage buckets inside the perimeter must meet the perimeter's access
/// restrictions.
core.List<core.String>? restrictedServices;
/// Configuration for APIs allowed within Perimeter.
GoogleIdentityAccesscontextmanagerV1VpcAccessibleServices?
vpcAccessibleServices;
GoogleIdentityAccesscontextmanagerV1ServicePerimeterConfig({
this.accessLevels,
this.egressPolicies,
this.ingressPolicies,
this.resources,
this.restrictedServices,
this.vpcAccessibleServices,
});
GoogleIdentityAccesscontextmanagerV1ServicePerimeterConfig.fromJson(
core.Map json_,
) : this(
accessLevels: (json_['accessLevels'] as core.List?)
?.map((value) => value as core.String)
.toList(),
egressPolicies: (json_['egressPolicies'] as core.List?)
?.map(
(value) =>
GoogleIdentityAccesscontextmanagerV1EgressPolicy.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
ingressPolicies: (json_['ingressPolicies'] as core.List?)
?.map(
(value) =>
GoogleIdentityAccesscontextmanagerV1IngressPolicy.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
resources: (json_['resources'] as core.List?)
?.map((value) => value as core.String)
.toList(),
restrictedServices: (json_['restrictedServices'] as core.List?)
?.map((value) => value as core.String)
.toList(),
vpcAccessibleServices: json_.containsKey('vpcAccessibleServices')
? GoogleIdentityAccesscontextmanagerV1VpcAccessibleServices.fromJson(
json_['vpcAccessibleServices']
as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final accessLevels = this.accessLevels;
final egressPolicies = this.egressPolicies;
final ingressPolicies = this.ingressPolicies;
final resources = this.resources;
final restrictedServices = this.restrictedServices;
final vpcAccessibleServices = this.vpcAccessibleServices;
return {
'accessLevels': ?accessLevels,
'egressPolicies': ?egressPolicies,
'ingressPolicies': ?ingressPolicies,
'resources': ?resources,
'restrictedServices': ?restrictedServices,
'vpcAccessibleServices': ?vpcAccessibleServices,
};
}
}
/// Specifies how APIs are allowed to communicate within the Service Perimeter.
typedef GoogleIdentityAccesscontextmanagerV1VpcAccessibleServices =
$VpcAccessibleServices;
/// The originating network source in Google Cloud.
class GoogleIdentityAccesscontextmanagerV1VpcNetworkSource {
/// Sub-segment ranges of a VPC network.
GoogleIdentityAccesscontextmanagerV1VpcSubNetwork? vpcSubnetwork;
GoogleIdentityAccesscontextmanagerV1VpcNetworkSource({this.vpcSubnetwork});
GoogleIdentityAccesscontextmanagerV1VpcNetworkSource.fromJson(core.Map json_)
: this(
vpcSubnetwork: json_.containsKey('vpcSubnetwork')
? GoogleIdentityAccesscontextmanagerV1VpcSubNetwork.fromJson(
json_['vpcSubnetwork'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final vpcSubnetwork = this.vpcSubnetwork;
return {'vpcSubnetwork': ?vpcSubnetwork};
}
}
/// Sub-segment ranges inside of a VPC Network.
typedef GoogleIdentityAccesscontextmanagerV1VpcSubNetwork = $VpcSubNetwork;
/// An analysis message to group the query and results.
class IamPolicyAnalysis {
/// The analysis query.
IamPolicyAnalysisQuery? analysisQuery;
/// A list of IamPolicyAnalysisResult that matches the analysis query, or
/// empty if no result is found.
core.List<IamPolicyAnalysisResult>? analysisResults;
/// Represents whether all entries in the analysis_results have been fully
/// explored to answer the query.
core.bool? fullyExplored;
/// A list of non-critical errors happened during the query handling.
core.List<IamPolicyAnalysisState>? nonCriticalErrors;
IamPolicyAnalysis({
this.analysisQuery,
this.analysisResults,
this.fullyExplored,
this.nonCriticalErrors,
});
IamPolicyAnalysis.fromJson(core.Map json_)
: this(
analysisQuery: json_.containsKey('analysisQuery')
? IamPolicyAnalysisQuery.fromJson(
json_['analysisQuery'] as core.Map<core.String, core.dynamic>,
)
: null,
analysisResults: (json_['analysisResults'] as core.List?)
?.map(
(value) => IamPolicyAnalysisResult.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
fullyExplored: json_['fullyExplored'] as core.bool?,
nonCriticalErrors: (json_['nonCriticalErrors'] as core.List?)
?.map(
(value) => IamPolicyAnalysisState.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final analysisQuery = this.analysisQuery;
final analysisResults = this.analysisResults;
final fullyExplored = this.fullyExplored;
final nonCriticalErrors = this.nonCriticalErrors;
return {
'analysisQuery': ?analysisQuery,
'analysisResults': ?analysisResults,
'fullyExplored': ?fullyExplored,
'nonCriticalErrors': ?nonCriticalErrors,
};
}
}
/// Output configuration for export IAM policy analysis destination.
class IamPolicyAnalysisOutputConfig {
/// Destination on BigQuery.
GoogleCloudAssetV1BigQueryDestination? bigqueryDestination;
/// Destination on Cloud Storage.
GoogleCloudAssetV1GcsDestination? gcsDestination;
IamPolicyAnalysisOutputConfig({
this.bigqueryDestination,
this.gcsDestination,
});
IamPolicyAnalysisOutputConfig.fromJson(core.Map json_)
: this(
bigqueryDestination: json_.containsKey('bigqueryDestination')
? GoogleCloudAssetV1BigQueryDestination.fromJson(
json_['bigqueryDestination']
as core.Map<core.String, core.dynamic>,
)
: null,
gcsDestination: json_.containsKey('gcsDestination')
? GoogleCloudAssetV1GcsDestination.fromJson(
json_['gcsDestination'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final bigqueryDestination = this.bigqueryDestination;
final gcsDestination = this.gcsDestination;
return {
'bigqueryDestination': ?bigqueryDestination,
'gcsDestination': ?gcsDestination,
};
}
}
/// IAM policy analysis query message.
class IamPolicyAnalysisQuery {
/// Specifies roles or permissions for analysis.
///
/// This is optional.
///
/// Optional.
AccessSelector? accessSelector;
/// The hypothetical context for IAM conditions evaluation.
///
/// Optional.
ConditionContext? conditionContext;
/// Specifies an identity for analysis.
///
/// Optional.
IdentitySelector? identitySelector;
/// The query options.
///
/// Optional.
Options? options;
/// Specifies a resource for analysis.
///
/// Optional.
ResourceSelector? resourceSelector;
/// The relative name of the root asset.
///
/// Only resources and IAM policies within the scope will be analyzed. This
/// can only be an organization number (such as "organizations/123"), a folder
/// number (such as "folders/123"), a project ID (such as
/// "projects/my-project-id"), or a project number (such as "projects/12345").
/// To know how to get organization ID, visit
/// [here ](https://cloud.google.com/resource-manager/docs/creating-managing-organization#retrieving_your_organization_id).
/// To know how to get folder or project ID, visit
/// [here ](https://cloud.google.com/resource-manager/docs/creating-managing-folders#viewing_or_listing_folders_and_projects).
///
/// Required.
core.String? scope;
IamPolicyAnalysisQuery({
this.accessSelector,
this.conditionContext,
this.identitySelector,
this.options,
this.resourceSelector,
this.scope,
});
IamPolicyAnalysisQuery.fromJson(core.Map json_)
: this(
accessSelector: json_.containsKey('accessSelector')
? AccessSelector.fromJson(
json_['accessSelector'] as core.Map<core.String, core.dynamic>,
)
: null,
conditionContext: json_.containsKey('conditionContext')
? ConditionContext.fromJson(
json_['conditionContext']
as core.Map<core.String, core.dynamic>,
)
: null,
identitySelector: json_.containsKey('identitySelector')
? IdentitySelector.fromJson(
json_['identitySelector']
as core.Map<core.String, core.dynamic>,
)
: null,
options: json_.containsKey('options')
? Options.fromJson(
json_['options'] as core.Map<core.String, core.dynamic>,
)
: null,
resourceSelector: json_.containsKey('resourceSelector')
? ResourceSelector.fromJson(
json_['resourceSelector']
as core.Map<core.String, core.dynamic>,
)
: null,
scope: json_['scope'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final accessSelector = this.accessSelector;
final conditionContext = this.conditionContext;
final identitySelector = this.identitySelector;
final options = this.options;
final resourceSelector = this.resourceSelector;
final scope = this.scope;
return {
'accessSelector': ?accessSelector,
'conditionContext': ?conditionContext,
'identitySelector': ?identitySelector,
'options': ?options,
'resourceSelector': ?resourceSelector,
'scope': ?scope,
};
}
}
/// IAM Policy analysis result, consisting of one IAM policy binding and derived
/// access control lists.
class IamPolicyAnalysisResult {
/// The access control lists derived from the iam_binding that match or
/// potentially match resource and access selectors specified in the request.
core.List<GoogleCloudAssetV1AccessControlList>? accessControlLists;
/// The
/// [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// of the resource to which the iam_binding policy attaches.
core.String? attachedResourceFullName;
/// Represents whether all analyses on the iam_binding have successfully
/// finished.
core.bool? fullyExplored;
/// The IAM policy binding under analysis.
Binding? iamBinding;
/// The identity list derived from members of the iam_binding that match or
/// potentially match identity selector specified in the request.
GoogleCloudAssetV1IdentityList? identityList;
IamPolicyAnalysisResult({
this.accessControlLists,
this.attachedResourceFullName,
this.fullyExplored,
this.iamBinding,
this.identityList,
});
IamPolicyAnalysisResult.fromJson(core.Map json_)
: this(
accessControlLists: (json_['accessControlLists'] as core.List?)
?.map(
(value) => GoogleCloudAssetV1AccessControlList.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
attachedResourceFullName:
json_['attachedResourceFullName'] as core.String?,
fullyExplored: json_['fullyExplored'] as core.bool?,
iamBinding: json_.containsKey('iamBinding')
? Binding.fromJson(
json_['iamBinding'] as core.Map<core.String, core.dynamic>,
)
: null,
identityList: json_.containsKey('identityList')
? GoogleCloudAssetV1IdentityList.fromJson(
json_['identityList'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final accessControlLists = this.accessControlLists;
final attachedResourceFullName = this.attachedResourceFullName;
final fullyExplored = this.fullyExplored;
final iamBinding = this.iamBinding;
final identityList = this.identityList;
return {
'accessControlLists': ?accessControlLists,
'attachedResourceFullName': ?attachedResourceFullName,
'fullyExplored': ?fullyExplored,
'iamBinding': ?iamBinding,
'identityList': ?identityList,
};
}
}
/// Represents the detailed state of an entity under analysis, such as a
/// resource, an identity or an access.
class IamPolicyAnalysisState {
/// The human-readable description of the cause of failure.
core.String? cause;
/// The Google standard error code that best describes the state.
///
/// For example: - OK means the analysis on this entity has been successfully
/// finished; - PERMISSION_DENIED means an access denied error is encountered;
/// - DEADLINE_EXCEEDED means the analysis on this entity hasn't been started
/// in time;
/// Possible string values are:
/// - "OK" : Not an error; returned on success. HTTP Mapping: 200 OK
/// - "CANCELLED" : The operation was cancelled, typically by the caller. HTTP
/// Mapping: 499 Client Closed Request
/// - "UNKNOWN" : Unknown error. For example, this error may be returned when
/// a `Status` value received from another address space belongs to an error
/// space that is not known in this address space. Also errors raised by APIs
/// that do not return enough error information may be converted to this
/// error. HTTP Mapping: 500 Internal Server Error
/// - "INVALID_ARGUMENT" : The client specified an invalid argument. Note that
/// this differs from `FAILED_PRECONDITION`. `INVALID_ARGUMENT` indicates
/// arguments that are problematic regardless of the state of the system
/// (e.g., a malformed file name). HTTP Mapping: 400 Bad Request
/// - "DEADLINE_EXCEEDED" : The deadline expired before the operation could
/// complete. For operations that change the state of the system, this error
/// may be returned even if the operation has completed successfully. For
/// example, a successful response from a server could have been delayed long
/// enough for the deadline to expire. HTTP Mapping: 504 Gateway Timeout
/// - "NOT_FOUND" : Some requested entity (e.g., file or directory) was not
/// found. Note to server developers: if a request is denied for an entire
/// class of users, such as gradual feature rollout or undocumented allowlist,
/// `NOT_FOUND` may be used. If a request is denied for some users within a
/// class of users, such as user-based access control, `PERMISSION_DENIED`
/// must be used. HTTP Mapping: 404 Not Found
/// - "ALREADY_EXISTS" : The entity that a client attempted to create (e.g.,
/// file or directory) already exists. HTTP Mapping: 409 Conflict
/// - "PERMISSION_DENIED" : The caller does not have permission to execute the
/// specified operation. `PERMISSION_DENIED` must not be used for rejections
/// caused by exhausting some resource (use `RESOURCE_EXHAUSTED` instead for
/// those errors). `PERMISSION_DENIED` must not be used if the caller can not
/// be identified (use `UNAUTHENTICATED` instead for those errors). This error
/// code does not imply the request is valid or the requested entity exists or
/// satisfies other pre-conditions. HTTP Mapping: 403 Forbidden
/// - "UNAUTHENTICATED" : The request does not have valid authentication
/// credentials for the operation. HTTP Mapping: 401 Unauthorized
/// - "RESOURCE_EXHAUSTED" : Some resource has been exhausted, perhaps a
/// per-user quota, or perhaps the entire file system is out of space. HTTP
/// Mapping: 429 Too Many Requests
/// - "FAILED_PRECONDITION" : The operation was rejected because the system is
/// not in a state required for the operation's execution. For example, the
/// directory to be deleted is non-empty, an rmdir operation is applied to a
/// non-directory, etc. Service implementors can use the following guidelines
/// to decide between `FAILED_PRECONDITION`, `ABORTED`, and `UNAVAILABLE`: (a)
/// Use `UNAVAILABLE` if the client can retry just the failing call. (b) Use
/// `ABORTED` if the client should retry at a higher level. For example, when
/// a client-specified test-and-set fails, indicating the client should
/// restart a read-modify-write sequence. (c) Use `FAILED_PRECONDITION` if the
/// client should not retry until the system state has been explicitly fixed.
/// For example, if an "rmdir" fails because the directory is non-empty,
/// `FAILED_PRECONDITION` should be returned since the client should not retry
/// unless the files are deleted from the directory. HTTP Mapping: 400 Bad
/// Request
/// - "ABORTED" : The operation was aborted, typically due to a concurrency
/// issue such as a sequencer check failure or transaction abort. See the
/// guidelines above for deciding between `FAILED_PRECONDITION`, `ABORTED`,
/// and `UNAVAILABLE`. HTTP Mapping: 409 Conflict
/// - "OUT_OF_RANGE" : The operation was attempted past the valid range. E.g.,
/// seeking or reading past end-of-file. Unlike `INVALID_ARGUMENT`, this error
/// indicates a problem that may be fixed if the system state changes. For
/// example, a 32-bit file system will generate `INVALID_ARGUMENT` if asked to
/// read at an offset that is not in the range \[0,2^32-1\], but it will
/// generate `OUT_OF_RANGE` if asked to read from an offset past the current
/// file size. There is a fair bit of overlap between `FAILED_PRECONDITION`
/// and `OUT_OF_RANGE`. We recommend using `OUT_OF_RANGE` (the more specific
/// error) when it applies so that callers who are iterating through a space
/// can easily look for an `OUT_OF_RANGE` error to detect when they are done.
/// HTTP Mapping: 400 Bad Request
/// - "UNIMPLEMENTED" : The operation is not implemented or is not
/// supported/enabled in this service. HTTP Mapping: 501 Not Implemented
/// - "INTERNAL" : Internal errors. This means that some invariants expected
/// by the underlying system have been broken. This error code is reserved for
/// serious errors. HTTP Mapping: 500 Internal Server Error
/// - "UNAVAILABLE" : The service is currently unavailable. This is most
/// likely a transient condition, which can be corrected by retrying with a
/// backoff. Note that it is not always safe to retry non-idempotent
/// operations. See the guidelines above for deciding between
/// `FAILED_PRECONDITION`, `ABORTED`, and `UNAVAILABLE`. HTTP Mapping: 503
/// Service Unavailable
/// - "DATA_LOSS" : Unrecoverable data loss or corruption. HTTP Mapping: 500
/// Internal Server Error
core.String? code;
IamPolicyAnalysisState({this.cause, this.code});
IamPolicyAnalysisState.fromJson(core.Map json_)
: this(
cause: json_['cause'] as core.String?,
code: json_['code'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final cause = this.cause;
final code = this.code;
return {'cause': ?cause, 'code': ?code};
}
}
/// A result of IAM Policy search, containing information of an IAM policy.
class IamPolicySearchResult {
/// The type of the resource associated with this IAM policy.
///
/// Example: `compute.googleapis.com/Disk`. To search against the
/// `asset_type`: * specify the `asset_types` field in your search request.
core.String? assetType;
/// Explanation about the IAM policy search result.
///
/// It contains additional information to explain why the search result
/// matches the query.
Explanation? explanation;
/// The folder(s) that the IAM policy belongs to, in the form of
/// folders/{FOLDER_NUMBER}.
///
/// This field is available when the IAM policy belongs to one or more
/// folders. To search against `folders`: * use a field query. Example:
/// `folders:(123 OR 456)` * use a free text query. Example: `123` * specify
/// the `scope` field as this folder in your search request.
core.List<core.String>? folders;
/// The organization that the IAM policy belongs to, in the form of
/// organizations/{ORGANIZATION_NUMBER}.
///
/// This field is available when the IAM policy belongs to an organization. To
/// search against `organization`: * use a field query. Example:
/// `organization:123` * use a free text query. Example: `123` * specify the
/// `scope` field as this organization in your search request.
core.String? organization;
/// The IAM policy directly set on the given resource.
///
/// Note that the original IAM policy can contain multiple bindings. This only
/// contains the bindings that match the given query. For queries that don't
/// contain a constrain on policies (e.g., an empty query), this contains all
/// the bindings. To search against the `policy` bindings: * use a field
/// query: - query by the policy contained members. Example:
/// `policy:amy@gmail.com` - query by the policy contained roles. Example:
/// `policy:roles/compute.admin` - query by the policy contained roles'
/// included permissions. Example:
/// `policy.role.permissions:compute.instances.create`
Policy? policy;
/// The project that the associated Google Cloud resource belongs to, in the
/// form of projects/{PROJECT_NUMBER}.
///
/// If an IAM policy is set on a resource (like VM instance, Cloud Storage
/// bucket), the project field will indicate the project that contains the
/// resource. If an IAM policy is set on a folder or organization, this field
/// will be empty. To search against the `project`: * specify the `scope`
/// field as this project in your search request.
core.String? project;
/// The full resource name of the resource associated with this IAM policy.
///
/// Example:
/// `//compute.googleapis.com/projects/my_project_123/zones/zone1/instances/instance1`.
/// See
/// [Cloud Asset Inventory Resource Name Format](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// for more information. To search against the `resource`: * use a field
/// query. Example: `resource:organizations/123`
core.String? resource;
IamPolicySearchResult({
this.assetType,
this.explanation,
this.folders,
this.organization,
this.policy,
this.project,
this.resource,
});
IamPolicySearchResult.fromJson(core.Map json_)
: this(
assetType: json_['assetType'] as core.String?,
explanation: json_.containsKey('explanation')
? Explanation.fromJson(
json_['explanation'] as core.Map<core.String, core.dynamic>,
)
: null,
folders: (json_['folders'] as core.List?)
?.map((value) => value as core.String)
.toList(),
organization: json_['organization'] as core.String?,
policy: json_.containsKey('policy')
? Policy.fromJson(
json_['policy'] as core.Map<core.String, core.dynamic>,
)
: null,
project: json_['project'] as core.String?,
resource: json_['resource'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final assetType = this.assetType;
final explanation = this.explanation;
final folders = this.folders;
final organization = this.organization;
final policy = this.policy;
final project = this.project;
final resource = this.resource;
return {
'assetType': ?assetType,
'explanation': ?explanation,
'folders': ?folders,
'organization': ?organization,
'policy': ?policy,
'project': ?project,
'resource': ?resource,
};
}
}
/// Specifies an identity for which to determine resource access, based on roles
/// assigned either directly to them or to the groups they belong to, directly
/// or indirectly.
class IdentitySelector {
/// The identity appear in the form of principals in
/// [IAM policy binding](https://cloud.google.com/iam/reference/rest/v1/Binding).
///
/// The examples of supported forms are: "user:mike@example.com",
/// "group:admins@example.com", "domain:google.com",
/// "serviceAccount:my-project-id@appspot.gserviceaccount.com". Notice that
/// wildcard characters (such as * and ?) are not supported. You must give a
/// specific identity.
///
/// Required.
core.String? identity;
IdentitySelector({this.identity});
IdentitySelector.fromJson(core.Map json_)
: this(identity: json_['identity'] as core.String?);
core.Map<core.String, core.dynamic> toJson() {
final identity = this.identity;
return {'identity': ?identity};
}
}
/// This API resource represents the available inventory data for a Compute
/// Engine virtual machine (VM) instance at a given point in time.
///
/// You can use this API resource to determine the inventory data of your VM.
/// For more information, see
/// [Information provided by OS inventory management](https://cloud.google.com/compute/docs/instances/os-inventory-management#data-collected).
class Inventory {
/// Inventory items related to the VM keyed by an opaque unique identifier for
/// each inventory item.
///
/// The identifier is unique to each distinct and addressable inventory item
/// and will change, when there is a new package version.
core.Map<core.String, Item>? items;
/// The `Inventory` API resource name.
///
/// Format:
/// `projects/{project_number}/locations/{location}/instances/{instance_id}/inventory`
///
/// Output only.
core.String? name;
/// Base level operating system information for the VM.
OsInfo? osInfo;
/// Timestamp of the last reported inventory for the VM.
///
/// Output only.
core.String? updateTime;
Inventory({this.items, this.name, this.osInfo, this.updateTime});
Inventory.fromJson(core.Map json_)
: this(
items: (json_['items'] as core.Map<core.String, core.dynamic>?)?.map(
(key, value) => core.MapEntry(
key,
Item.fromJson(value as core.Map<core.String, core.dynamic>),
),
),
name: json_['name'] as core.String?,
osInfo: json_.containsKey('osInfo')
? OsInfo.fromJson(
json_['osInfo'] as core.Map<core.String, core.dynamic>,
)
: null,
updateTime: json_['updateTime'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final items = this.items;
final name = this.name;
final osInfo = this.osInfo;
final updateTime = this.updateTime;
return {
'items': ?items,
'name': ?name,
'osInfo': ?osInfo,
'updateTime': ?updateTime,
};
}
}
/// A single piece of inventory on a VM.
class Item {
/// Software package available to be installed on the VM instance.
SoftwarePackage? availablePackage;
/// When this inventory item was first detected.
core.String? createTime;
/// Identifier for this item, unique across items for this VM.
core.String? id;
/// Software package present on the VM instance.
SoftwarePackage? installedPackage;
/// The origin of this inventory item.
/// Possible string values are:
/// - "ORIGIN_TYPE_UNSPECIFIED" : Invalid. An origin type must be specified.
/// - "INVENTORY_REPORT" : This inventory item was discovered as the result of
/// the agent reporting inventory via the reporting API.
core.String? originType;
/// The specific type of inventory, correlating to its specific details.
/// Possible string values are:
/// - "TYPE_UNSPECIFIED" : Invalid. A type must be specified.
/// - "INSTALLED_PACKAGE" : This represents a package that is installed on the
/// VM.
/// - "AVAILABLE_PACKAGE" : This represents an update that is available for a
/// package.
core.String? type;
/// When this inventory item was last modified.
core.String? updateTime;
Item({
this.availablePackage,
this.createTime,
this.id,
this.installedPackage,
this.originType,
this.type,
this.updateTime,
});
Item.fromJson(core.Map json_)
: this(
availablePackage: json_.containsKey('availablePackage')
? SoftwarePackage.fromJson(
json_['availablePackage']
as core.Map<core.String, core.dynamic>,
)
: null,
createTime: json_['createTime'] as core.String?,
id: json_['id'] as core.String?,
installedPackage: json_.containsKey('installedPackage')
? SoftwarePackage.fromJson(
json_['installedPackage']
as core.Map<core.String, core.dynamic>,
)
: null,
originType: json_['originType'] as core.String?,
type: json_['type'] as core.String?,
updateTime: json_['updateTime'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final availablePackage = this.availablePackage;
final createTime = this.createTime;
final id = this.id;
final installedPackage = this.installedPackage;
final originType = this.originType;
final type = this.type;
final updateTime = this.updateTime;
return {
'availablePackage': ?availablePackage,
'createTime': ?createTime,
'id': ?id,
'installedPackage': ?installedPackage,
'originType': ?originType,
'type': ?type,
'updateTime': ?updateTime,
};
}
}
/// ListAssets response.
class ListAssetsResponse {
/// Assets.
core.List<Asset>? assets;
/// Token to retrieve the next page of results.
///
/// It expires 72 hours after the page token for the first page is generated.
/// Set to empty if there are no remaining results.
core.String? nextPageToken;
/// Time the snapshot was taken.
core.String? readTime;
ListAssetsResponse({this.assets, this.nextPageToken, this.readTime});
ListAssetsResponse.fromJson(core.Map json_)
: this(
assets: (json_['assets'] as core.List?)
?.map(
(value) =>
Asset.fromJson(value as core.Map<core.String, core.dynamic>),
)
.toList(),
nextPageToken: json_['nextPageToken'] as core.String?,
readTime: json_['readTime'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final assets = this.assets;
final nextPageToken = this.nextPageToken;
final readTime = this.readTime;
return {
'assets': ?assets,
'nextPageToken': ?nextPageToken,
'readTime': ?readTime,
};
}
}
class ListFeedsResponse {
/// A list of feeds.
core.List<Feed>? feeds;
ListFeedsResponse({this.feeds});
ListFeedsResponse.fromJson(core.Map json_)
: this(
feeds: (json_['feeds'] as core.List?)
?.map(
(value) =>
Feed.fromJson(value as core.Map<core.String, core.dynamic>),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final feeds = this.feeds;
return {'feeds': ?feeds};
}
}
/// Response of listing saved queries.
class ListSavedQueriesResponse {
/// A token, which can be sent as `page_token` to retrieve the next page.
///
/// If this field is omitted, there are no subsequent pages.
core.String? nextPageToken;
/// A list of savedQueries.
core.List<SavedQuery>? savedQueries;
ListSavedQueriesResponse({this.nextPageToken, this.savedQueries});
ListSavedQueriesResponse.fromJson(core.Map json_)
: this(
nextPageToken: json_['nextPageToken'] as core.String?,
savedQueries: (json_['savedQueries'] as core.List?)
?.map(
(value) => SavedQuery.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final nextPageToken = this.nextPageToken;
final savedQueries = this.savedQueries;
return {'nextPageToken': ?nextPageToken, 'savedQueries': ?savedQueries};
}
}
/// A message to group the analysis information.
class MoveAnalysis {
/// Analysis result of moving the target resource.
MoveAnalysisResult? analysis;
/// The user friendly display name of the analysis.
///
/// E.g. IAM, organization policy etc.
core.String? displayName;
/// Description of error encountered when performing the analysis.
Status? error;
MoveAnalysis({this.analysis, this.displayName, this.error});
MoveAnalysis.fromJson(core.Map json_)
: this(
analysis: json_.containsKey('analysis')
? MoveAnalysisResult.fromJson(
json_['analysis'] as core.Map<core.String, core.dynamic>,
)
: null,
displayName: json_['displayName'] as core.String?,
error: json_.containsKey('error')
? Status.fromJson(
json_['error'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final analysis = this.analysis;
final displayName = this.displayName;
final error = this.error;
return {
'analysis': ?analysis,
'displayName': ?displayName,
'error': ?error,
};
}
}
/// An analysis result including blockers and warnings.
class MoveAnalysisResult {
/// Blocking information that would prevent the target resource from moving to
/// the specified destination at runtime.
core.List<MoveImpact>? blockers;
/// Warning information indicating that moving the target resource to the
/// specified destination might be unsafe.
///
/// This can include important policy information and configuration changes,
/// but will not block moves at runtime.
core.List<MoveImpact>? warnings;
MoveAnalysisResult({this.blockers, this.warnings});
MoveAnalysisResult.fromJson(core.Map json_)
: this(
blockers: (json_['blockers'] as core.List?)
?.map(
(value) => MoveImpact.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
warnings: (json_['warnings'] as core.List?)
?.map(
(value) => MoveImpact.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final blockers = this.blockers;
final warnings = this.warnings;
return {'blockers': ?blockers, 'warnings': ?warnings};
}
}
/// A message to group impacts of moving the target resource.
class MoveImpact {
/// User friendly impact detail in a free form message.
core.String? detail;
MoveImpact({this.detail});
MoveImpact.fromJson(core.Map json_)
: this(detail: json_['detail'] as core.String?);
core.Map<core.String, core.dynamic> toJson() {
final detail = this.detail;
return {'detail': ?detail};
}
}
/// This resource represents a long-running operation that is the result of a
/// network API call.
class Operation {
/// If the value is `false`, it means the operation is still in progress.
///
/// If `true`, the operation is completed, and either `error` or `response` is
/// available.
core.bool? done;
/// The error result of the operation in case of failure or cancellation.
Status? error;
/// Service-specific metadata associated with the operation.
///
/// It typically contains progress information and common metadata such as
/// create time. Some services might not provide such metadata. Any method
/// that returns a long-running operation should document the metadata type,
/// if any.
///
/// The values for Object must be JSON objects. It can consist of `num`,
/// `String`, `bool` and `null` as well as `Map` and `List` values.
core.Map<core.String, core.Object?>? metadata;
/// The server-assigned name, which is only unique within the same service
/// that originally returns it.
///
/// If you use the default HTTP mapping, the `name` should be a resource name
/// ending with `operations/{unique_id}`.
core.String? name;
/// The normal, successful response of the operation.
///
/// If the original method returns no data on success, such as `Delete`, the
/// response is `google.protobuf.Empty`. If the original method is standard
/// `Get`/`Create`/`Update`, the response should be the resource. For other
/// methods, the response should have the type `XxxResponse`, where `Xxx` is
/// the original method name. For example, if the original method name is
/// `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.
///
/// The values for Object must be JSON objects. It can consist of `num`,
/// `String`, `bool` and `null` as well as `Map` and `List` values.
core.Map<core.String, core.Object?>? response;
Operation({this.done, this.error, this.metadata, this.name, this.response});
Operation.fromJson(core.Map json_)
: this(
done: json_['done'] as core.bool?,
error: json_.containsKey('error')
? Status.fromJson(
json_['error'] as core.Map<core.String, core.dynamic>,
)
: null,
metadata: json_.containsKey('metadata')
? json_['metadata'] as core.Map<core.String, core.dynamic>
: null,
name: json_['name'] as core.String?,
response: json_.containsKey('response')
? json_['response'] as core.Map<core.String, core.dynamic>
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final done = this.done;
final error = this.error;
final metadata = this.metadata;
final name = this.name;
final response = this.response;
return {
'done': ?done,
'error': ?error,
'metadata': ?metadata,
'name': ?name,
'response': ?response,
};
}
}
/// Contains query options.
class Options {
/// If true, the response will include access analysis from identities to
/// resources via service account impersonation.
///
/// This is a very expensive operation, because many derived queries will be
/// executed. We highly recommend you use
/// AssetService.AnalyzeIamPolicyLongrunning RPC instead. For example, if the
/// request analyzes for which resources user A has permission P, and there's
/// an IAM policy states user A has iam.serviceAccounts.getAccessToken
/// permission to a service account SA, and there's another IAM policy states
/// service account SA has permission P to a Google Cloud folder F, then user
/// A potentially has access to the Google Cloud folder F. And those advanced
/// analysis results will be included in
/// AnalyzeIamPolicyResponse.service_account_impersonation_analysis. Another
/// example, if the request analyzes for who has permission P to a Google
/// Cloud folder F, and there's an IAM policy states user A has
/// iam.serviceAccounts.actAs permission to a service account SA, and there's
/// another IAM policy states service account SA has permission P to the
/// Google Cloud folder F, then user A potentially has access to the Google
/// Cloud folder F. And those advanced analysis results will be included in
/// AnalyzeIamPolicyResponse.service_account_impersonation_analysis. Only the
/// following permissions are considered in this analysis: *
/// `iam.serviceAccounts.actAs` * `iam.serviceAccounts.signBlob` *
/// `iam.serviceAccounts.signJwt` * `iam.serviceAccounts.getAccessToken` *
/// `iam.serviceAccounts.getOpenIdToken` *
/// `iam.serviceAccounts.implicitDelegation` Default is false.
///
/// Optional.
core.bool? analyzeServiceAccountImpersonation;
/// If true, the identities section of the result will expand any Google
/// groups appearing in an IAM policy binding.
///
/// If IamPolicyAnalysisQuery.identity_selector is specified, the identity in
/// the result will be determined by the selector, and this flag is not
/// allowed to set. If true, the default max expansion per group is 1000 for
/// AssetService.AnalyzeIamPolicy\]\[\]. Default is false.
///
/// Optional.
core.bool? expandGroups;
/// If true and IamPolicyAnalysisQuery.resource_selector is not specified, the
/// resource section of the result will expand any resource attached to an IAM
/// policy to include resources lower in the resource hierarchy.
///
/// For example, if the request analyzes for which resources user A has
/// permission P, and the results include an IAM policy with P on a Google
/// Cloud folder, the results will also include resources in that folder with
/// permission P. If true and IamPolicyAnalysisQuery.resource_selector is
/// specified, the resource section of the result will expand the specified
/// resource to include resources lower in the resource hierarchy. Only
/// project or lower resources are supported. Folder and organization
/// resources cannot be used together with this option. For example, if the
/// request analyzes for which users have permission P on a Google Cloud
/// project with this option enabled, the results will include all users who
/// have permission P on that project or any lower resource. If true, the
/// default max expansion per resource is 1000 for
/// AssetService.AnalyzeIamPolicy\]\[\] and 100000 for
/// AssetService.AnalyzeIamPolicyLongrunning\]\[\]. Default is false.
///
/// Optional.
core.bool? expandResources;
/// If true, the access section of result will expand any roles appearing in
/// IAM policy bindings to include their permissions.
///
/// If IamPolicyAnalysisQuery.access_selector is specified, the access section
/// of the result will be determined by the selector, and this flag is not
/// allowed to set. Default is false.
///
/// Optional.
core.bool? expandRoles;
/// If true, the result will output the relevant membership relationships
/// between groups and other groups, and between groups and principals.
///
/// Default is false.
///
/// Optional.
core.bool? outputGroupEdges;
/// If true, the result will output the relevant parent/child relationships
/// between resources.
///
/// Default is false.
///
/// Optional.
core.bool? outputResourceEdges;
Options({
this.analyzeServiceAccountImpersonation,
this.expandGroups,
this.expandResources,
this.expandRoles,
this.outputGroupEdges,
this.outputResourceEdges,
});
Options.fromJson(core.Map json_)
: this(
analyzeServiceAccountImpersonation:
json_['analyzeServiceAccountImpersonation'] as core.bool?,
expandGroups: json_['expandGroups'] as core.bool?,
expandResources: json_['expandResources'] as core.bool?,
expandRoles: json_['expandRoles'] as core.bool?,
outputGroupEdges: json_['outputGroupEdges'] as core.bool?,
outputResourceEdges: json_['outputResourceEdges'] as core.bool?,
);
core.Map<core.String, core.dynamic> toJson() {
final analyzeServiceAccountImpersonation =
this.analyzeServiceAccountImpersonation;
final expandGroups = this.expandGroups;
final expandResources = this.expandResources;
final expandRoles = this.expandRoles;
final outputGroupEdges = this.outputGroupEdges;
final outputResourceEdges = this.outputResourceEdges;
return {
'analyzeServiceAccountImpersonation': ?analyzeServiceAccountImpersonation,
'expandGroups': ?expandGroups,
'expandResources': ?expandResources,
'expandRoles': ?expandRoles,
'outputGroupEdges': ?outputGroupEdges,
'outputResourceEdges': ?outputResourceEdges,
};
}
}
/// The organization policy result to the query.
class OrgPolicyResult {
/// The consolidated organization policy for the analyzed resource.
///
/// The consolidated organization policy is computed by merging and evaluating
/// policy_bundle. The evaluation will respect the organization policy
/// [hierarchy rules](https://cloud.google.com/resource-manager/docs/organization-policy/understanding-hierarchy).
AnalyzerOrgPolicy? consolidatedPolicy;
/// The folder(s) that this consolidated policy belongs to, in the format of
/// folders/{FOLDER_NUMBER}.
///
/// This field is available when the consolidated policy belongs (directly or
/// cascadingly) to one or more folders.
core.List<core.String>? folders;
/// The organization that this consolidated policy belongs to, in the format
/// of organizations/{ORGANIZATION_NUMBER}.
///
/// This field is available when the consolidated policy belongs (directly or
/// cascadingly) to an organization.
core.String? organization;
/// The ordered list of all organization policies from the
/// consolidated_policy.attached_resource.
///
/// to the scope specified in the request. If the constraint is defined with
/// default policy, it will also appear in the list.
core.List<AnalyzerOrgPolicy>? policyBundle;
/// The project that this consolidated policy belongs to, in the format of
/// projects/{PROJECT_NUMBER}.
///
/// This field is available when the consolidated policy belongs to a project.
core.String? project;
OrgPolicyResult({
this.consolidatedPolicy,
this.folders,
this.organization,
this.policyBundle,
this.project,
});
OrgPolicyResult.fromJson(core.Map json_)
: this(
consolidatedPolicy: json_.containsKey('consolidatedPolicy')
? AnalyzerOrgPolicy.fromJson(
json_['consolidatedPolicy']
as core.Map<core.String, core.dynamic>,
)
: null,
folders: (json_['folders'] as core.List?)
?.map((value) => value as core.String)
.toList(),
organization: json_['organization'] as core.String?,
policyBundle: (json_['policyBundle'] as core.List?)
?.map(
(value) => AnalyzerOrgPolicy.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
project: json_['project'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final consolidatedPolicy = this.consolidatedPolicy;
final folders = this.folders;
final organization = this.organization;
final policyBundle = this.policyBundle;
final project = this.project;
return {
'consolidatedPolicy': ?consolidatedPolicy,
'folders': ?folders,
'organization': ?organization,
'policyBundle': ?policyBundle,
'project': ?project,
};
}
}
/// Operating system information for the VM.
typedef OsInfo = $OsInfo;
/// Output configuration for export assets destination.
class OutputConfig {
/// Destination on BigQuery.
///
/// The output table stores the fields in asset Protobuf as columns in
/// BigQuery.
BigQueryDestination? bigqueryDestination;
/// Destination on Cloud Storage.
GcsDestination? gcsDestination;
OutputConfig({this.bigqueryDestination, this.gcsDestination});
OutputConfig.fromJson(core.Map json_)
: this(
bigqueryDestination: json_.containsKey('bigqueryDestination')
? BigQueryDestination.fromJson(
json_['bigqueryDestination']
as core.Map<core.String, core.dynamic>,
)
: null,
gcsDestination: json_.containsKey('gcsDestination')
? GcsDestination.fromJson(
json_['gcsDestination'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final bigqueryDestination = this.bigqueryDestination;
final gcsDestination = this.gcsDestination;
return {
'bigqueryDestination': ?bigqueryDestination,
'gcsDestination': ?gcsDestination,
};
}
}
/// Specifications of BigQuery partitioned table as export destination.
class PartitionSpec {
/// The partition key for BigQuery partitioned table.
/// Possible string values are:
/// - "PARTITION_KEY_UNSPECIFIED" : Unspecified partition key. If used, it
/// means using non-partitioned table.
/// - "READ_TIME" : The time when the snapshot is taken. If specified as
/// partition key, the result table(s) is partitioned by the additional
/// timestamp column, readTime. If \[read_time\] in ExportAssetsRequest is
/// specified, the readTime column's value will be the same as it. Otherwise,
/// its value will be the current time that is used to take the snapshot.
/// - "REQUEST_TIME" : The time when the request is received and started to be
/// processed. If specified as partition key, the result table(s) is
/// partitioned by the requestTime column, an additional timestamp column
/// representing when the request was received.
core.String? partitionKey;
PartitionSpec({this.partitionKey});
PartitionSpec.fromJson(core.Map json_)
: this(partitionKey: json_['partitionKey'] as core.String?);
core.Map<core.String, core.dynamic> toJson() {
final partitionKey = this.partitionKey;
return {'partitionKey': ?partitionKey};
}
}
/// IAM permissions
class Permissions {
/// A list of permissions.
///
/// A sample permission string: `compute.disk.get`.
core.List<core.String>? permissions;
Permissions({this.permissions});
Permissions.fromJson(core.Map json_)
: this(
permissions: (json_['permissions'] as core.List?)
?.map((value) => value as core.String)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final permissions = this.permissions;
return {'permissions': ?permissions};
}
}
/// An Identity and Access Management (IAM) policy, which specifies access
/// controls for Google Cloud resources.
///
/// A `Policy` is a collection of `bindings`. A `binding` binds one or more
/// `members`, or principals, to a single `role`. Principals can be user
/// accounts, service accounts, Google groups, and domains (such as G Suite). A
/// `role` is a named list of permissions; each `role` can be an IAM predefined
/// role or a user-created custom role. For some types of Google Cloud
/// resources, a `binding` can also specify a `condition`, which is a logical
/// expression that allows access to a resource only if the expression evaluates
/// to `true`. A condition can add constraints based on attributes of the
/// request, the resource, or both. To learn which resources support conditions
/// in their IAM policies, see the
/// [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).
/// **JSON example:** ``` { "bindings": [ { "role":
/// "roles/resourcemanager.organizationAdmin", "members": [
/// "user:mike@example.com", "group:admins@example.com", "domain:google.com",
/// "serviceAccount:my-project-id@appspot.gserviceaccount.com" ] }, { "role":
/// "roles/resourcemanager.organizationViewer", "members": [
/// "user:eve@example.com" ], "condition": { "title": "expirable access",
/// "description": "Does not grant access after Sep 2020", "expression":
/// "request.time < timestamp('2020-10-01T00:00:00.000Z')", } } ], "etag":
/// "BwWWja0YfJA=", "version": 3 } ``` **YAML example:** ``` bindings: -
/// members: - user:mike@example.com - group:admins@example.com -
/// domain:google.com - serviceAccount:my-project-id@appspot.gserviceaccount.com
/// role: roles/resourcemanager.organizationAdmin - members: -
/// user:eve@example.com role: roles/resourcemanager.organizationViewer
/// condition: title: expirable access description: Does not grant access after
/// Sep 2020 expression: request.time < timestamp('2020-10-01T00:00:00.000Z')
/// etag: BwWWja0YfJA= version: 3 ``` For a description of IAM and its features,
/// see the [IAM documentation](https://cloud.google.com/iam/docs/).
class Policy {
/// Specifies cloud audit logging configuration for this policy.
core.List<AuditConfig>? auditConfigs;
/// Associates a list of `members`, or principals, with a `role`.
///
/// Optionally, may specify a `condition` that determines how and when the
/// `bindings` are applied. Each of the `bindings` must contain at least one
/// principal. The `bindings` in a `Policy` can refer to up to 1,500
/// principals; up to 250 of these principals can be Google groups. Each
/// occurrence of a principal counts towards these limits. For example, if the
/// `bindings` grant 50 different roles to `user:alice@example.com`, and not
/// to any other principal, then you can add another 1,450 principals to the
/// `bindings` in the `Policy`.
core.List<Binding>? bindings;
/// `etag` is used for optimistic concurrency control as a way to help prevent
/// simultaneous updates of a policy from overwriting each other.
///
/// It is strongly suggested that systems make use of the `etag` in the
/// read-modify-write cycle to perform policy updates in order to avoid race
/// conditions: An `etag` is returned in the response to `getIamPolicy`, and
/// systems are expected to put that etag in the request to `setIamPolicy` to
/// ensure that their change will be applied to the same version of the
/// policy. **Important:** If you use IAM Conditions, you must include the
/// `etag` field whenever you call `setIamPolicy`. If you omit this field,
/// then IAM allows you to overwrite a version `3` policy with a version `1`
/// policy, and all of the conditions in the version `3` policy are lost.
core.String? etag;
core.List<core.int> get etagAsBytes => convert.base64.decode(etag!);
set etagAsBytes(core.List<core.int> bytes_) {
etag = convert.base64
.encode(bytes_)
.replaceAll('/', '_')
.replaceAll('+', '-');
}
/// Specifies the format of the policy.
///
/// Valid values are `0`, `1`, and `3`. Requests that specify an invalid value
/// are rejected. Any operation that affects conditional role bindings must
/// specify version `3`. This requirement applies to the following operations:
/// * Getting a policy that includes a conditional role binding * Adding a
/// conditional role binding to a policy * Changing a conditional role binding
/// in a policy * Removing any role binding, with or without a condition, from
/// a policy that includes conditions **Important:** If you use IAM
/// Conditions, you must include the `etag` field whenever you call
/// `setIamPolicy`. If you omit this field, then IAM allows you to overwrite a
/// version `3` policy with a version `1` policy, and all of the conditions in
/// the version `3` policy are lost. If a policy does not include any
/// conditions, operations on that policy may specify any valid version or
/// leave the field unset. To learn which resources support conditions in
/// their IAM policies, see the
/// [IAM documentation](https://cloud.google.com/iam/help/conditions/resource-policies).
core.int? version;
Policy({this.auditConfigs, this.bindings, this.etag, this.version});
Policy.fromJson(core.Map json_)
: this(
auditConfigs: (json_['auditConfigs'] as core.List?)
?.map(
(value) => AuditConfig.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
bindings: (json_['bindings'] as core.List?)
?.map(
(value) => Binding.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
etag: json_['etag'] as core.String?,
version: json_['version'] as core.int?,
);
core.Map<core.String, core.dynamic> toJson() {
final auditConfigs = this.auditConfigs;
final bindings = this.bindings;
final etag = this.etag;
final version = this.version;
return {
'auditConfigs': ?auditConfigs,
'bindings': ?bindings,
'etag': ?etag,
'version': ?version,
};
}
}
/// The IAM policy and its attached resource.
class PolicyInfo {
/// The full resource name the policy is directly attached to.
core.String? attachedResource;
/// The IAM policy that's directly attached to the attached_resource.
Policy? policy;
PolicyInfo({this.attachedResource, this.policy});
PolicyInfo.fromJson(core.Map json_)
: this(
attachedResource: json_['attachedResource'] as core.String?,
policy: json_.containsKey('policy')
? Policy.fromJson(
json_['policy'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final attachedResource = this.attachedResource;
final policy = this.policy;
return {'attachedResource': ?attachedResource, 'policy': ?policy};
}
}
/// A Pub/Sub destination.
class PubsubDestination {
/// The name of the Pub/Sub topic to publish to.
///
/// Example: `projects/PROJECT_ID/topics/TOPIC_ID`.
core.String? topic;
PubsubDestination({this.topic});
PubsubDestination.fromJson(core.Map json_)
: this(topic: json_['topic'] as core.String?);
core.Map<core.String, core.dynamic> toJson() {
final topic = this.topic;
return {'topic': ?topic};
}
}
/// Output configuration query assets.
class QueryAssetsOutputConfig {
/// BigQuery destination where the query results will be saved.
GoogleCloudAssetV1QueryAssetsOutputConfigBigQueryDestination?
bigqueryDestination;
QueryAssetsOutputConfig({this.bigqueryDestination});
QueryAssetsOutputConfig.fromJson(core.Map json_)
: this(
bigqueryDestination: json_.containsKey('bigqueryDestination')
? GoogleCloudAssetV1QueryAssetsOutputConfigBigQueryDestination.fromJson(
json_['bigqueryDestination']
as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final bigqueryDestination = this.bigqueryDestination;
return {'bigqueryDestination': ?bigqueryDestination};
}
}
/// QueryAssets request.
class QueryAssetsRequest {
/// Reference to the query job, which is from the `QueryAssetsResponse` of
/// previous `QueryAssets` call.
///
/// Optional.
core.String? jobReference;
/// Destination where the query results will be saved.
///
/// When this field is specified, the query results won't be saved in the
/// \[QueryAssetsResponse.query_result\]. Instead
/// \[QueryAssetsResponse.output_config\] will be set. Meanwhile,
/// \[QueryAssetsResponse.job_reference\] will be set and can be used to check
/// the status of the query job when passed to a following \[QueryAssets\] API
/// call.
///
/// Optional.
QueryAssetsOutputConfig? outputConfig;
/// The maximum number of rows to return in the results.
///
/// Responses are limited to 10 MB and 1000 rows. By default, the maximum row
/// count is 1000. When the byte or row count limit is reached, the rest of
/// the query results will be paginated. The field will be ignored when
/// \[output_config\] is specified.
///
/// Optional.
core.int? pageSize;
/// A page token received from previous `QueryAssets`.
///
/// The field will be ignored when \[output_config\] is specified.
///
/// Optional.
core.String? pageToken;
/// Queries cloud assets as they appeared at the specified point in time.
///
/// Optional.
core.String? readTime;
/// \[start_time\] is required.
///
/// \[start_time\] must be less than \[end_time\] Defaults \[end_time\] to now
/// if \[start_time\] is set and \[end_time\] isn't. Maximum permitted time
/// range is 7 days.
///
/// Optional.
TimeWindow? readTimeWindow;
/// A SQL statement that's compatible with
/// [BigQuery SQL](https://cloud.google.com/bigquery/docs/introduction-sql).
///
/// Optional.
core.String? statement;
/// Specifies the maximum amount of time that the client is willing to wait
/// for the query to complete.
///
/// By default, this limit is 5 min for the first query, and 1 minute for the
/// following queries. If the query is complete, the `done` field in the
/// `QueryAssetsResponse` is true, otherwise false. Like BigQuery
/// [jobs.query API](https://cloud.google.com/bigquery/docs/reference/rest/v2/jobs/query#queryrequest)
/// The call is not guaranteed to wait for the specified timeout; it typically
/// returns after around 200 seconds (200,000 milliseconds), even if the query
/// is not complete. The field will be ignored when \[output_config\] is
/// specified.
///
/// Optional.
core.String? timeout;
QueryAssetsRequest({
this.jobReference,
this.outputConfig,
this.pageSize,
this.pageToken,
this.readTime,
this.readTimeWindow,
this.statement,
this.timeout,
});
QueryAssetsRequest.fromJson(core.Map json_)
: this(
jobReference: json_['jobReference'] as core.String?,
outputConfig: json_.containsKey('outputConfig')
? QueryAssetsOutputConfig.fromJson(
json_['outputConfig'] as core.Map<core.String, core.dynamic>,
)
: null,
pageSize: json_['pageSize'] as core.int?,
pageToken: json_['pageToken'] as core.String?,
readTime: json_['readTime'] as core.String?,
readTimeWindow: json_.containsKey('readTimeWindow')
? TimeWindow.fromJson(
json_['readTimeWindow'] as core.Map<core.String, core.dynamic>,
)
: null,
statement: json_['statement'] as core.String?,
timeout: json_['timeout'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final jobReference = this.jobReference;
final outputConfig = this.outputConfig;
final pageSize = this.pageSize;
final pageToken = this.pageToken;
final readTime = this.readTime;
final readTimeWindow = this.readTimeWindow;
final statement = this.statement;
final timeout = this.timeout;
return {
'jobReference': ?jobReference,
'outputConfig': ?outputConfig,
'pageSize': ?pageSize,
'pageToken': ?pageToken,
'readTime': ?readTime,
'readTimeWindow': ?readTimeWindow,
'statement': ?statement,
'timeout': ?timeout,
};
}
}
/// QueryAssets response.
class QueryAssetsResponse {
/// The query response, which can be either an `error` or a valid `response`.
///
/// If `done` == `false` and the query result is being saved in an output, the
/// output_config field will be set. If `done` == `true`, exactly one of
/// `error`, `query_result` or `output_config` will be set. \[done\] is unset
/// unless the \[QueryAssetsResponse\] contains a
/// \[QueryAssetsResponse.job_reference\].
core.bool? done;
/// Error status.
Status? error;
/// Reference to a query job.
core.String? jobReference;
/// Output configuration, which indicates that instead of being returned in an
/// API response on the fly, the query result will be saved in a specific
/// output.
QueryAssetsOutputConfig? outputConfig;
/// Result of the query.
QueryResult? queryResult;
QueryAssetsResponse({
this.done,
this.error,
this.jobReference,
this.outputConfig,
this.queryResult,
});
QueryAssetsResponse.fromJson(core.Map json_)
: this(
done: json_['done'] as core.bool?,
error: json_.containsKey('error')
? Status.fromJson(
json_['error'] as core.Map<core.String, core.dynamic>,
)
: null,
jobReference: json_['jobReference'] as core.String?,
outputConfig: json_.containsKey('outputConfig')
? QueryAssetsOutputConfig.fromJson(
json_['outputConfig'] as core.Map<core.String, core.dynamic>,
)
: null,
queryResult: json_.containsKey('queryResult')
? QueryResult.fromJson(
json_['queryResult'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final done = this.done;
final error = this.error;
final jobReference = this.jobReference;
final outputConfig = this.outputConfig;
final queryResult = this.queryResult;
return {
'done': ?done,
'error': ?error,
'jobReference': ?jobReference,
'outputConfig': ?outputConfig,
'queryResult': ?queryResult,
};
}
}
/// The query content.
class QueryContent {
/// An IAM Policy Analysis query, which could be used in the
/// AssetService.AnalyzeIamPolicy RPC or the
/// AssetService.AnalyzeIamPolicyLongrunning RPC.
IamPolicyAnalysisQuery? iamPolicyAnalysisQuery;
QueryContent({this.iamPolicyAnalysisQuery});
QueryContent.fromJson(core.Map json_)
: this(
iamPolicyAnalysisQuery: json_.containsKey('iamPolicyAnalysisQuery')
? IamPolicyAnalysisQuery.fromJson(
json_['iamPolicyAnalysisQuery']
as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final iamPolicyAnalysisQuery = this.iamPolicyAnalysisQuery;
return {'iamPolicyAnalysisQuery': ?iamPolicyAnalysisQuery};
}
}
/// Execution results of the query.
///
/// The result is formatted as rows represented by BigQuery compatible
/// \[schema\]. When pagination is necessary, it will contains the page token to
/// retrieve the results of following pages.
class QueryResult {
/// Token to retrieve the next page of the results.
core.String? nextPageToken;
/// Each row hold a query result in the format of `Struct`.
///
/// The values for Object must be JSON objects. It can consist of `num`,
/// `String`, `bool` and `null` as well as `Map` and `List` values.
core.List<core.Map<core.String, core.Object?>>? rows;
/// Describes the format of the \[rows\].
TableSchema? schema;
/// Total rows of the whole query results.
core.String? totalRows;
QueryResult({this.nextPageToken, this.rows, this.schema, this.totalRows});
QueryResult.fromJson(core.Map json_)
: this(
nextPageToken: json_['nextPageToken'] as core.String?,
rows: (json_['rows'] as core.List?)
?.map((value) => value as core.Map<core.String, core.dynamic>)
.toList(),
schema: json_.containsKey('schema')
? TableSchema.fromJson(
json_['schema'] as core.Map<core.String, core.dynamic>,
)
: null,
totalRows: json_['totalRows'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final nextPageToken = this.nextPageToken;
final rows = this.rows;
final schema = this.schema;
final totalRows = this.totalRows;
return {
'nextPageToken': ?nextPageToken,
'rows': ?rows,
'schema': ?schema,
'totalRows': ?totalRows,
};
}
}
/// An asset identifier in Google Cloud which contains its name, type and
/// ancestors.
///
/// An asset can be any resource in the Google Cloud
/// [resource hierarchy](https://cloud.google.com/resource-manager/docs/cloud-platform-resource-hierarchy),
/// a resource outside the Google Cloud resource hierarchy (such as Google
/// Kubernetes Engine clusters and objects), or a policy (e.g. IAM policy). See
/// [Supported asset types](https://cloud.google.com/asset-inventory/docs/supported-asset-types)
/// for more information.
class RelatedAsset {
/// The ancestors of an asset in Google Cloud
/// [resource hierarchy](https://cloud.google.com/resource-manager/docs/cloud-platform-resource-hierarchy),
/// represented as a list of relative resource names.
///
/// An ancestry path starts with the closest ancestor in the hierarchy and
/// ends at root. Example: `["projects/123456789", "folders/5432",
/// "organizations/1234"]`
core.List<core.String>? ancestors;
/// The full name of the asset.
///
/// Example:
/// `//compute.googleapis.com/projects/my_project_123/zones/zone1/instances/instance1`
/// See
/// [Resource names](https://cloud.google.com/apis/design/resource_names#full_resource_name)
/// for more information.
core.String? asset;
/// The type of the asset.
///
/// Example: `compute.googleapis.com/Disk` See
/// [Supported asset types](https://cloud.google.com/asset-inventory/docs/supported-asset-types)
/// for more information.
core.String? assetType;
/// The unique identifier of the relationship type.
///
/// Example: `INSTANCE_TO_INSTANCEGROUP`
core.String? relationshipType;
RelatedAsset({
this.ancestors,
this.asset,
this.assetType,
this.relationshipType,
});
RelatedAsset.fromJson(core.Map json_)
: this(
ancestors: (json_['ancestors'] as core.List?)
?.map((value) => value as core.String)
.toList(),
asset: json_['asset'] as core.String?,
assetType: json_['assetType'] as core.String?,
relationshipType: json_['relationshipType'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final ancestors = this.ancestors;
final asset = this.asset;
final assetType = this.assetType;
final relationshipType = this.relationshipType;
return {
'ancestors': ?ancestors,
'asset': ?asset,
'assetType': ?assetType,
'relationshipType': ?relationshipType,
};
}
}
/// This message only presents for the purpose of backward-compatibility.
///
/// The server will never populate this message in responses. The detailed
/// related assets with the `relationship_type`.
///
/// Deprecated.
class RelatedAssets {
/// The peer resources of the relationship.
core.List<RelatedAsset>? assets;
/// The detailed relationship attributes.
RelationshipAttributes? relationshipAttributes;
RelatedAssets({this.assets, this.relationshipAttributes});
RelatedAssets.fromJson(core.Map json_)
: this(
assets: (json_['assets'] as core.List?)
?.map(
(value) => RelatedAsset.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
relationshipAttributes: json_.containsKey('relationshipAttributes')
? RelationshipAttributes.fromJson(
json_['relationshipAttributes']
as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final assets = this.assets;
final relationshipAttributes = this.relationshipAttributes;
return {
'assets': ?assets,
'relationshipAttributes': ?relationshipAttributes,
};
}
}
/// The detailed related resource.
class RelatedResource {
/// The type of the asset.
///
/// Example: `compute.googleapis.com/Instance`
core.String? assetType;
/// The full resource name of the related resource.
///
/// Example:
/// `//compute.googleapis.com/projects/my_proj_123/zones/instance/instance123`
core.String? fullResourceName;
RelatedResource({this.assetType, this.fullResourceName});
RelatedResource.fromJson(core.Map json_)
: this(
assetType: json_['assetType'] as core.String?,
fullResourceName: json_['fullResourceName'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final assetType = this.assetType;
final fullResourceName = this.fullResourceName;
return {'assetType': ?assetType, 'fullResourceName': ?fullResourceName};
}
}
/// The related resources of the primary resource.
class RelatedResources {
/// The detailed related resources of the primary resource.
core.List<RelatedResource>? relatedResources;
RelatedResources({this.relatedResources});
RelatedResources.fromJson(core.Map json_)
: this(
relatedResources: (json_['relatedResources'] as core.List?)
?.map(
(value) => RelatedResource.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final relatedResources = this.relatedResources;
return {'relatedResources': ?relatedResources};
}
}
/// This message only presents for the purpose of backward-compatibility.
///
/// The server will never populate this message in responses. The relationship
/// attributes which include `type`, `source_resource_type`,
/// `target_resource_type` and `action`.
///
/// Deprecated.
class RelationshipAttributes {
/// The detail of the relationship, e.g. `contains`, `attaches`
core.String? action;
/// The source asset type.
///
/// Example: `compute.googleapis.com/Instance`
core.String? sourceResourceType;
/// The target asset type.
///
/// Example: `compute.googleapis.com/Disk`
core.String? targetResourceType;
/// The unique identifier of the relationship type.
///
/// Example: `INSTANCE_TO_INSTANCEGROUP`
core.String? type;
RelationshipAttributes({
this.action,
this.sourceResourceType,
this.targetResourceType,
this.type,
});
RelationshipAttributes.fromJson(core.Map json_)
: this(
action: json_['action'] as core.String?,
sourceResourceType: json_['sourceResourceType'] as core.String?,
targetResourceType: json_['targetResourceType'] as core.String?,
type: json_['type'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final action = this.action;
final sourceResourceType = this.sourceResourceType;
final targetResourceType = this.targetResourceType;
final type = this.type;
return {
'action': ?action,
'sourceResourceType': ?sourceResourceType,
'targetResourceType': ?targetResourceType,
'type': ?type,
};
}
}
/// A representation of a Google Cloud resource.
class Resource {
/// The content of the resource, in which some sensitive fields are removed
/// and may not be present.
///
/// The values for Object must be JSON objects. It can consist of `num`,
/// `String`, `bool` and `null` as well as `Map` and `List` values.
core.Map<core.String, core.Object?>? data;
/// The URL of the discovery document containing the resource's JSON schema.
///
/// Example: `https://www.googleapis.com/discovery/v1/apis/compute/v1/rest`
/// This value is unspecified for resources that do not have an API based on a
/// discovery document, such as Cloud Bigtable.
core.String? discoveryDocumentUri;
/// The JSON schema name listed in the discovery document.
///
/// Example: `Project` This value is unspecified for resources that do not
/// have an API based on a discovery document, such as Cloud Bigtable.
core.String? discoveryName;
/// The location of the resource in Google Cloud, such as its zone and region.
///
/// For more information, see https://cloud.google.com/about/locations/.
core.String? location;
/// The full name of the immediate parent of this resource.
///
/// See
/// [Resource Names](https://cloud.google.com/apis/design/resource_names#full_resource_name)
/// for more information. For Google Cloud assets, this value is the parent
/// resource defined in the
/// [IAM policy hierarchy](https://cloud.google.com/iam/docs/overview#policy_hierarchy).
/// Example: `//cloudresourcemanager.googleapis.com/projects/my_project_123`
core.String? parent;
/// The REST URL for accessing the resource.
///
/// An HTTP `GET` request using this URL returns the resource itself. Example:
/// `https://cloudresourcemanager.googleapis.com/v1/projects/my-project-123`
/// This value is unspecified for resources without a REST API.
core.String? resourceUrl;
/// The API version.
///
/// Example: `v1`
core.String? version;
Resource({
this.data,
this.discoveryDocumentUri,
this.discoveryName,
this.location,
this.parent,
this.resourceUrl,
this.version,
});
Resource.fromJson(core.Map json_)
: this(
data: json_.containsKey('data')
? json_['data'] as core.Map<core.String, core.dynamic>
: null,
discoveryDocumentUri: json_['discoveryDocumentUri'] as core.String?,
discoveryName: json_['discoveryName'] as core.String?,
location: json_['location'] as core.String?,
parent: json_['parent'] as core.String?,
resourceUrl: json_['resourceUrl'] as core.String?,
version: json_['version'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final data = this.data;
final discoveryDocumentUri = this.discoveryDocumentUri;
final discoveryName = this.discoveryName;
final location = this.location;
final parent = this.parent;
final resourceUrl = this.resourceUrl;
final version = this.version;
return {
'data': ?data,
'discoveryDocumentUri': ?discoveryDocumentUri,
'discoveryName': ?discoveryName,
'location': ?location,
'parent': ?parent,
'resourceUrl': ?resourceUrl,
'version': ?version,
};
}
}
/// The resource owners information.
class ResourceOwners {
/// List of resource owners.
core.List<core.String>? resourceOwners;
ResourceOwners({this.resourceOwners});
ResourceOwners.fromJson(core.Map json_)
: this(
resourceOwners: (json_['resourceOwners'] as core.List?)
?.map((value) => value as core.String)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final resourceOwners = this.resourceOwners;
return {'resourceOwners': ?resourceOwners};
}
}
/// A result of Resource Search, containing information of a cloud resource.
class ResourceSearchResult {
/// The additional searchable attributes of this resource.
///
/// The attributes may vary from one resource type to another. Examples:
/// `projectId` for Project, `dnsName` for DNS ManagedZone. This field
/// contains a subset of the resource metadata fields that are returned by the
/// List or Get APIs provided by the corresponding Google Cloud service (e.g.,
/// Compute Engine). see
/// [API references and supported searchable attributes](https://cloud.google.com/asset-inventory/docs/supported-asset-types)
/// to see which fields are included. You can search values of these fields
/// through free text search. However, you should not consume the field
/// programically as the field names and values may change as the Google Cloud
/// service updates to a new incompatible API version. To search against the
/// `additional_attributes`: * Use a free text query to match the attributes
/// values. Example: to search `additional_attributes = { dnsName: "foobar"
/// }`, you can issue a query `foobar`.
///
/// The values for Object must be JSON objects. It can consist of `num`,
/// `String`, `bool` and `null` as well as `Map` and `List` values.
core.Map<core.String, core.Object?>? additionalAttributes;
/// The type of this resource.
///
/// Example: `compute.googleapis.com/Disk`. To search against the
/// `asset_type`: * Specify the `asset_type` field in your search request.
core.String? assetType;
/// Attached resources of this resource.
///
/// For example, an OSConfig Inventory is an attached resource of a Compute
/// Instance. This field is repeated because a resource could have multiple
/// attached resources. This `attached_resources` field is not searchable.
/// Some attributes of the attached resources are exposed in
/// `additional_attributes` field, so as to allow users to search on them.
core.List<AttachedResource>? attachedResources;
/// The create timestamp of this resource, at which the resource was created.
///
/// The granularity is in seconds. Timestamp.nanos will always be 0. This
/// field is available only when the resource's Protobuf contains it. To
/// search against `create_time`: * Use a field query. - value in seconds
/// since unix epoch. Example: `createTime > 1609459200` - value in date
/// string. Example: `createTime > 2021-01-01` - value in date-time string
/// (must be quoted). Example: `createTime > "2021-01-01T00:00:00"`
core.String? createTime;
/// One or more paragraphs of text description of this resource.
///
/// Maximum length could be up to 1M bytes. This field is available only when
/// the resource's Protobuf contains it. To search against the `description`:
/// * Use a field query. Example: `description:"important instance"` * Use a
/// free text query. Example: `"important instance"`
core.String? description;
/// The display name of this resource.
///
/// This field is available only when the resource's Protobuf contains it. To
/// search against the `display_name`: * Use a field query. Example:
/// `displayName:"My Instance"` * Use a free text query. Example: `"My
/// Instance"`
core.String? displayName;
/// The effective tags on this resource.
///
/// All of the tags that are both attached to and inherited by a resource are
/// collectively called the effective tags. For more information, see
/// [tag inheritance](https://cloud.google.com/resource-manager/docs/tags/tags-overview#inheritance).
/// To search against the `effective_tags`: * Use a field query. Example: -
/// `effectiveTagKeys:"123456789/env*"` - `effectiveTagKeys="123456789/env"` -
/// `effectiveTagKeys:"env"` - `effectiveTagKeyIds="tagKeys/123"` -
/// `effectiveTagValues:"env"` - `effectiveTagValues:"env/prod"` -
/// `effectiveTagValues:"123456789/env/prod*"` -
/// `effectiveTagValues="123456789/env/prod"` -
/// `effectiveTagValueIds="tagValues/456"`
core.List<EffectiveTagDetails>? effectiveTags;
/// Enrichments of the asset.
///
/// Currently supported enrichment types with SearchAllResources API: *
/// RESOURCE_OWNERS The corresponding read masks in order to get the
/// enrichment: * enrichments.resource_owners The corresponding required
/// permissions: * cloudasset.assets.searchEnrichmentResourceOwners Example
/// query to get resource owner enrichment: ``` scope: "projects/my-project"
/// query: "name: my-project" assetTypes:
/// "cloudresourcemanager.googleapis.com/Project" readMask: { paths:
/// "asset_type" paths: "name" paths: "enrichments.resource_owners" } ```
core.List<AssetEnrichment>? enrichments;
/// The folder(s) that this resource belongs to, in the form of
/// folders/{FOLDER_NUMBER}.
///
/// This field is available when the resource belongs to one or more folders.
/// To search against `folders`: * Use a field query. Example: `folders:(123
/// OR 456)` * Use a free text query. Example: `123` * Specify the `scope`
/// field as this folder in your search request.
core.List<core.String>? folders;
/// The Cloud KMS
/// [CryptoKey](https://cloud.google.com/kms/docs/reference/rest/v1/projects.locations.keyRings.cryptoKeys)
/// name or
/// [CryptoKeyVersion](https://cloud.google.com/kms/docs/reference/rest/v1/projects.locations.keyRings.cryptoKeys.cryptoKeyVersions)
/// name.
///
/// This field only presents for the purpose of backward compatibility. Use
/// the `kms_keys` field to retrieve Cloud KMS key information. This field is
/// available only when the resource's Protobuf contains it and will only be
/// populated for
/// [these resource types](https://cloud.google.com/asset-inventory/docs/legacy-field-names#resource_types_with_the_to_be_deprecated_kmskey_field)
/// for backward compatible purposes. To search against the `kms_key`: * Use a
/// field query. Example: `kmsKey:key` * Use a free text query. Example: `key`
@core.Deprecated(
'Not supported. Member documentation may have more information.',
)
core.String? kmsKey;
/// The Cloud KMS
/// [CryptoKey](https://cloud.google.com/kms/docs/reference/rest/v1/projects.locations.keyRings.cryptoKeys)
/// names or
/// [CryptoKeyVersion](https://cloud.google.com/kms/docs/reference/rest/v1/projects.locations.keyRings.cryptoKeys.cryptoKeyVersions)
/// names.
///
/// This field is available only when the resource's Protobuf contains it. To
/// search against the `kms_keys`: * Use a field query. Example: `kmsKeys:key`
/// * Use a free text query. Example: `key`
core.List<core.String>? kmsKeys;
/// User labels associated with this resource.
///
/// See
/// [Labelling and grouping Google Cloud resources](https://cloud.google.com/blog/products/gcp/labelling-and-grouping-your-google-cloud-platform-resources)
/// for more information. This field is available only when the resource's
/// Protobuf contains it. To search against the `labels`: * Use a field query:
/// - query on any label's key or value. Example: `labels:prod` - query by a
/// given label. Example: `labels.env:prod` - query by a given label's
/// existence. Example: `labels.env:*` * Use a free text query. Example:
/// `prod`
core.Map<core.String, core.String>? labels;
/// Location can be `global`, regional like `us-east1`, or zonal like
/// `us-west1-b`.
///
/// This field is available only when the resource's Protobuf contains it. To
/// search against the `location`: * Use a field query. Example:
/// `location:us-west*` * Use a free text query. Example: `us-west*`
core.String? location;
/// The full resource name of this resource.
///
/// Example:
/// `//compute.googleapis.com/projects/my_project_123/zones/zone1/instances/instance1`.
/// See
/// [Cloud Asset Inventory Resource Name Format](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// for more information. To search against the `name`: * Use a field query.
/// Example: `name:instance1` * Use a free text query. Example: `instance1`
core.String? name;
/// Network tags associated with this resource.
///
/// Like labels, network tags are a type of annotations used to group Google
/// Cloud resources. See
/// [Labelling Google Cloud resources](https://cloud.google.com/blog/products/gcp/labelling-and-grouping-your-google-cloud-platform-resources)
/// for more information. This field is available only when the resource's
/// Protobuf contains it. To search against the `network_tags`: * Use a field
/// query. Example: `networkTags:internal` * Use a free text query. Example:
/// `internal`
core.List<core.String>? networkTags;
/// The organization that this resource belongs to, in the form of
/// organizations/{ORGANIZATION_NUMBER}.
///
/// This field is available when the resource belongs to an organization. To
/// search against `organization`: * Use a field query. Example:
/// `organization:123` * Use a free text query. Example: `123` * Specify the
/// `scope` field as this organization in your search request.
core.String? organization;
/// The type of this resource's immediate parent, if there is one.
///
/// To search against the `parent_asset_type`: * Use a field query. Example:
/// `parentAssetType:"cloudresourcemanager.googleapis.com/Project"` * Use a
/// free text query. Example: `cloudresourcemanager.googleapis.com/Project`
core.String? parentAssetType;
/// The full resource name of this resource's parent, if it has one.
///
/// To search against the `parent_full_resource_name`: * Use a field query.
/// Example: `parentFullResourceName:"project-name"` * Use a free text query.
/// Example: `project-name`
core.String? parentFullResourceName;
/// The project that this resource belongs to, in the form of
/// projects/{PROJECT_NUMBER}.
///
/// This field is available when the resource belongs to a project. To search
/// against `project`: * Use a field query. Example: `project:12345` * Use a
/// free text query. Example: `12345` * Specify the `scope` field as this
/// project in your search request.
core.String? project;
/// A map of related resources of this resource, keyed by the relationship
/// type.
///
/// A relationship type is in the format of {SourceType}_{ACTION}_{DestType}.
/// Example: `DISK_TO_INSTANCE`, `DISK_TO_NETWORK`,
/// `INSTANCE_TO_INSTANCEGROUP`. See
/// [supported relationship types](https://cloud.google.com/asset-inventory/docs/supported-asset-types#supported_relationship_types).
core.Map<core.String, RelatedResources>? relationships;
/// The actual content of Security Command Center security marks associated
/// with the asset.
///
/// To search against SCC SecurityMarks field: * Use a field query: - query by
/// a given key value pair. Example: `sccSecurityMarks.foo=bar` - query by a
/// given key's existence. Example: `sccSecurityMarks.foo:*`
core.Map<core.String, core.String>? sccSecurityMarks;
/// The state of this resource.
///
/// Different resources types have different state definitions that are mapped
/// from various fields of different resource types. This field is available
/// only when the resource's Protobuf contains it. Example: If the resource is
/// an instance provided by Compute Engine, its state will include
/// PROVISIONING, STAGING, RUNNING, STOPPING, SUSPENDING, SUSPENDED,
/// REPAIRING, and TERMINATED. See `status` definition in
/// [API Reference](https://cloud.google.com/compute/docs/reference/rest/v1/instances).
/// If the resource is a project provided by Resource Manager, its state will
/// include LIFECYCLE_STATE_UNSPECIFIED, ACTIVE, DELETE_REQUESTED and
/// DELETE_IN_PROGRESS. See `lifecycleState` definition in
/// [API Reference](https://cloud.google.com/resource-manager/reference/rest/v1/projects).
/// To search against the `state`: * Use a field query. Example:
/// `state:RUNNING` * Use a free text query. Example: `RUNNING`
core.String? state;
/// This field is only present for the purpose of backward compatibility.
///
/// Use the `tags` field instead. TagKey namespaced names, in the format of
/// {ORG_ID}/{TAG_KEY_SHORT_NAME}. To search against the `tagKeys`: * Use a
/// field query. Example: - `tagKeys:"123456789/env*"` -
/// `tagKeys="123456789/env"` - `tagKeys:"env"` * Use a free text query.
/// Example: - `env`
@core.Deprecated(
'Not supported. Member documentation may have more information.',
)
core.List<core.String>? tagKeys;
/// This field is only present for the purpose of backward compatibility.
///
/// Use the `tags` field instead. TagValue IDs, in the format of
/// tagValues/{TAG_VALUE_ID}. To search against the `tagValueIds`: * Use a
/// field query. Example: - `tagValueIds="tagValues/456"` * Use a free text
/// query. Example: - `456`
@core.Deprecated(
'Not supported. Member documentation may have more information.',
)
core.List<core.String>? tagValueIds;
/// This field is only present for the purpose of backward compatibility.
///
/// Use the `tags` field instead. TagValue namespaced names, in the format of
/// {ORG_ID}/{TAG_KEY_SHORT_NAME}/{TAG_VALUE_SHORT_NAME}. To search against
/// the `tagValues`: * Use a field query. Example: - `tagValues:"env"` -
/// `tagValues:"env/prod"` - `tagValues:"123456789/env/prod*"` -
/// `tagValues="123456789/env/prod"` * Use a free text query. Example: -
/// `prod`
@core.Deprecated(
'Not supported. Member documentation may have more information.',
)
core.List<core.String>? tagValues;
/// The tags directly attached to this resource.
///
/// To search against the `tags`: * Use a field query. Example: -
/// `tagKeys:"123456789/env*"` - `tagKeys="123456789/env"` - `tagKeys:"env"` -
/// `tagKeyIds="tagKeys/123"` - `tagValues:"env"` - `tagValues:"env/prod"` -
/// `tagValues:"123456789/env/prod*"` - `tagValues="123456789/env/prod"` -
/// `tagValueIds="tagValues/456"` * Use a free text query. Example: -
/// `env/prod`
core.List<Tag>? tags;
/// The last update timestamp of this resource, at which the resource was last
/// modified or deleted.
///
/// The granularity is in seconds. Timestamp.nanos will always be 0. This
/// field is available only when the resource's Protobuf contains it. To
/// search against `update_time`: * Use a field query. - value in seconds
/// since unix epoch. Example: `updateTime < 1609459200` - value in date
/// string. Example: `updateTime < 2021-01-01` - value in date-time string
/// (must be quoted). Example: `updateTime < "2021-01-01T00:00:00"`
core.String? updateTime;
/// Versioned resource representations of this resource.
///
/// This is repeated because there could be multiple versions of resource
/// representations during version migration. This `versioned_resources` field
/// is not searchable. Some attributes of the resource representations are
/// exposed in `additional_attributes` field, so as to allow users to search
/// on them.
core.List<VersionedResource>? versionedResources;
ResourceSearchResult({
this.additionalAttributes,
this.assetType,
this.attachedResources,
this.createTime,
this.description,
this.displayName,
this.effectiveTags,
this.enrichments,
this.folders,
this.kmsKey,
this.kmsKeys,
this.labels,
this.location,
this.name,
this.networkTags,
this.organization,
this.parentAssetType,
this.parentFullResourceName,
this.project,
this.relationships,
this.sccSecurityMarks,
this.state,
this.tagKeys,
this.tagValueIds,
this.tagValues,
this.tags,
this.updateTime,
this.versionedResources,
});
ResourceSearchResult.fromJson(core.Map json_)
: this(
additionalAttributes: json_.containsKey('additionalAttributes')
? json_['additionalAttributes']
as core.Map<core.String, core.dynamic>
: null,
assetType: json_['assetType'] as core.String?,
attachedResources: (json_['attachedResources'] as core.List?)
?.map(
(value) => AttachedResource.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
createTime: json_['createTime'] as core.String?,
description: json_['description'] as core.String?,
displayName: json_['displayName'] as core.String?,
effectiveTags: (json_['effectiveTags'] as core.List?)
?.map(
(value) => EffectiveTagDetails.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
enrichments: (json_['enrichments'] as core.List?)
?.map(
(value) => AssetEnrichment.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
folders: (json_['folders'] as core.List?)
?.map((value) => value as core.String)
.toList(),
kmsKey: json_['kmsKey'] as core.String?,
kmsKeys: (json_['kmsKeys'] as core.List?)
?.map((value) => value as core.String)
.toList(),
labels: (json_['labels'] as core.Map<core.String, core.dynamic>?)?.map(
(key, value) => core.MapEntry(key, value as core.String),
),
location: json_['location'] as core.String?,
name: json_['name'] as core.String?,
networkTags: (json_['networkTags'] as core.List?)
?.map((value) => value as core.String)
.toList(),
organization: json_['organization'] as core.String?,
parentAssetType: json_['parentAssetType'] as core.String?,
parentFullResourceName: json_['parentFullResourceName'] as core.String?,
project: json_['project'] as core.String?,
relationships:
(json_['relationships'] as core.Map<core.String, core.dynamic>?)
?.map(
(key, value) => core.MapEntry(
key,
RelatedResources.fromJson(
value as core.Map<core.String, core.dynamic>,
),
),
),
sccSecurityMarks:
(json_['sccSecurityMarks'] as core.Map<core.String, core.dynamic>?)
?.map((key, value) => core.MapEntry(key, value as core.String)),
state: json_['state'] as core.String?,
tagKeys: (json_['tagKeys'] as core.List?)
?.map((value) => value as core.String)
.toList(),
tagValueIds: (json_['tagValueIds'] as core.List?)
?.map((value) => value as core.String)
.toList(),
tagValues: (json_['tagValues'] as core.List?)
?.map((value) => value as core.String)
.toList(),
tags: (json_['tags'] as core.List?)
?.map(
(value) =>
Tag.fromJson(value as core.Map<core.String, core.dynamic>),
)
.toList(),
updateTime: json_['updateTime'] as core.String?,
versionedResources: (json_['versionedResources'] as core.List?)
?.map(
(value) => VersionedResource.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final additionalAttributes = this.additionalAttributes;
final assetType = this.assetType;
final attachedResources = this.attachedResources;
final createTime = this.createTime;
final description = this.description;
final displayName = this.displayName;
final effectiveTags = this.effectiveTags;
final enrichments = this.enrichments;
final folders = this.folders;
final kmsKey = this.kmsKey;
final kmsKeys = this.kmsKeys;
final labels = this.labels;
final location = this.location;
final name = this.name;
final networkTags = this.networkTags;
final organization = this.organization;
final parentAssetType = this.parentAssetType;
final parentFullResourceName = this.parentFullResourceName;
final project = this.project;
final relationships = this.relationships;
final sccSecurityMarks = this.sccSecurityMarks;
final state = this.state;
final tagKeys = this.tagKeys;
final tagValueIds = this.tagValueIds;
final tagValues = this.tagValues;
final tags = this.tags;
final updateTime = this.updateTime;
final versionedResources = this.versionedResources;
return {
'additionalAttributes': ?additionalAttributes,
'assetType': ?assetType,
'attachedResources': ?attachedResources,
'createTime': ?createTime,
'description': ?description,
'displayName': ?displayName,
'effectiveTags': ?effectiveTags,
'enrichments': ?enrichments,
'folders': ?folders,
'kmsKey': ?kmsKey,
'kmsKeys': ?kmsKeys,
'labels': ?labels,
'location': ?location,
'name': ?name,
'networkTags': ?networkTags,
'organization': ?organization,
'parentAssetType': ?parentAssetType,
'parentFullResourceName': ?parentFullResourceName,
'project': ?project,
'relationships': ?relationships,
'sccSecurityMarks': ?sccSecurityMarks,
'state': ?state,
'tagKeys': ?tagKeys,
'tagValueIds': ?tagValueIds,
'tagValues': ?tagValues,
'tags': ?tags,
'updateTime': ?updateTime,
'versionedResources': ?versionedResources,
};
}
}
/// Specifies the resource to analyze for access policies, which may be set
/// directly on the resource, or on ancestors such as organizations, folders or
/// projects.
class ResourceSelector {
/// The
/// [full resource name](https://cloud.google.com/asset-inventory/docs/resource-name-format)
/// of a resource of
/// [supported resource types](https://cloud.google.com/asset-inventory/docs/supported-asset-types#analyzable_asset_types).
///
/// Required.
core.String? fullResourceName;
ResourceSelector({this.fullResourceName});
ResourceSelector.fromJson(core.Map json_)
: this(fullResourceName: json_['fullResourceName'] as core.String?);
core.Map<core.String, core.dynamic> toJson() {
final fullResourceName = this.fullResourceName;
return {'fullResourceName': ?fullResourceName};
}
}
/// A saved query which can be shared with others or used later.
class SavedQuery {
/// The query content.
QueryContent? content;
/// The create time of this saved query.
///
/// Output only.
core.String? createTime;
/// The account's email address who has created this saved query.
///
/// Output only.
core.String? creator;
/// The description of this saved query.
///
/// This value should be fewer than 255 characters.
core.String? description;
/// Labels applied on the resource.
///
/// This value should not contain more than 10 entries. The key and value of
/// each entry must be non-empty and fewer than 64 characters.
core.Map<core.String, core.String>? labels;
/// The last update time of this saved query.
///
/// Output only.
core.String? lastUpdateTime;
/// The account's email address who has updated this saved query most
/// recently.
///
/// Output only.
core.String? lastUpdater;
/// The resource name of the saved query.
///
/// The format must be: * projects/project_number/savedQueries/saved_query_id
/// * folders/folder_number/savedQueries/saved_query_id *
/// organizations/organization_number/savedQueries/saved_query_id
core.String? name;
SavedQuery({
this.content,
this.createTime,
this.creator,
this.description,
this.labels,
this.lastUpdateTime,
this.lastUpdater,
this.name,
});
SavedQuery.fromJson(core.Map json_)
: this(
content: json_.containsKey('content')
? QueryContent.fromJson(
json_['content'] as core.Map<core.String, core.dynamic>,
)
: null,
createTime: json_['createTime'] as core.String?,
creator: json_['creator'] as core.String?,
description: json_['description'] as core.String?,
labels: (json_['labels'] as core.Map<core.String, core.dynamic>?)?.map(
(key, value) => core.MapEntry(key, value as core.String),
),
lastUpdateTime: json_['lastUpdateTime'] as core.String?,
lastUpdater: json_['lastUpdater'] as core.String?,
name: json_['name'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final content = this.content;
final createTime = this.createTime;
final creator = this.creator;
final description = this.description;
final labels = this.labels;
final lastUpdateTime = this.lastUpdateTime;
final lastUpdater = this.lastUpdater;
final name = this.name;
return {
'content': ?content,
'createTime': ?createTime,
'creator': ?creator,
'description': ?description,
'labels': ?labels,
'lastUpdateTime': ?lastUpdateTime,
'lastUpdater': ?lastUpdater,
'name': ?name,
};
}
}
/// Search all IAM policies response.
class SearchAllIamPoliciesResponse {
/// Set if there are more results than those appearing in this response; to
/// get the next set of results, call this method again, using this value as
/// the `page_token`.
core.String? nextPageToken;
/// A list of IAM policies that match the search query.
///
/// Related information such as the associated resource is returned along with
/// the policy.
core.List<IamPolicySearchResult>? results;
SearchAllIamPoliciesResponse({this.nextPageToken, this.results});
SearchAllIamPoliciesResponse.fromJson(core.Map json_)
: this(
nextPageToken: json_['nextPageToken'] as core.String?,
results: (json_['results'] as core.List?)
?.map(
(value) => IamPolicySearchResult.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final nextPageToken = this.nextPageToken;
final results = this.results;
return {'nextPageToken': ?nextPageToken, 'results': ?results};
}
}
/// Search all resources response.
class SearchAllResourcesResponse {
/// If there are more results than those appearing in this response, then
/// `next_page_token` is included.
///
/// To get the next set of results, call this method again using the value of
/// `next_page_token` as `page_token`.
core.String? nextPageToken;
/// A list of Resources that match the search query.
///
/// It contains the resource standard metadata information.
core.List<ResourceSearchResult>? results;
SearchAllResourcesResponse({this.nextPageToken, this.results});
SearchAllResourcesResponse.fromJson(core.Map json_)
: this(
nextPageToken: json_['nextPageToken'] as core.String?,
results: (json_['results'] as core.List?)
?.map(
(value) => ResourceSearchResult.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final nextPageToken = this.nextPageToken;
final results = this.results;
return {'nextPageToken': ?nextPageToken, 'results': ?results};
}
}
/// Software package information of the operating system.
class SoftwarePackage {
/// Details of an APT package.
///
/// For details about the apt package manager, see
/// https://wiki.debian.org/Apt.
VersionedPackage? aptPackage;
/// Details of a COS package.
VersionedPackage? cosPackage;
/// Details of a Googet package.
///
/// For details about the googet package manager, see
/// https://github.com/google/googet.
VersionedPackage? googetPackage;
/// Details of a Windows Quick Fix engineering package.
///
/// See
/// https://docs.microsoft.com/en-us/windows/win32/cimwin32prov/win32-quickfixengineering
/// for info in Windows Quick Fix Engineering.
WindowsQuickFixEngineeringPackage? qfePackage;
/// Details of Windows Application.
WindowsApplication? windowsApplication;
/// Details of a Windows Update package.
///
/// See https://docs.microsoft.com/en-us/windows/win32/api/_wua/ for
/// information about Windows Update.
WindowsUpdatePackage? wuaPackage;
/// Yum package info.
///
/// For details about the yum package manager, see
/// https://access.redhat.com/documentation/en-us/red_hat_enterprise_linux/6/html/deployment_guide/ch-yum.
VersionedPackage? yumPackage;
/// Details of a Zypper package.
///
/// For details about the Zypper package manager, see
/// https://en.opensuse.org/SDB:Zypper_manual.
VersionedPackage? zypperPackage;
/// Details of a Zypper patch.
///
/// For details about the Zypper package manager, see
/// https://en.opensuse.org/SDB:Zypper_manual.
ZypperPatch? zypperPatch;
SoftwarePackage({
this.aptPackage,
this.cosPackage,
this.googetPackage,
this.qfePackage,
this.windowsApplication,
this.wuaPackage,
this.yumPackage,
this.zypperPackage,
this.zypperPatch,
});
SoftwarePackage.fromJson(core.Map json_)
: this(
aptPackage: json_.containsKey('aptPackage')
? VersionedPackage.fromJson(
json_['aptPackage'] as core.Map<core.String, core.dynamic>,
)
: null,
cosPackage: json_.containsKey('cosPackage')
? VersionedPackage.fromJson(
json_['cosPackage'] as core.Map<core.String, core.dynamic>,
)
: null,
googetPackage: json_.containsKey('googetPackage')
? VersionedPackage.fromJson(
json_['googetPackage'] as core.Map<core.String, core.dynamic>,
)
: null,
qfePackage: json_.containsKey('qfePackage')
? WindowsQuickFixEngineeringPackage.fromJson(
json_['qfePackage'] as core.Map<core.String, core.dynamic>,
)
: null,
windowsApplication: json_.containsKey('windowsApplication')
? WindowsApplication.fromJson(
json_['windowsApplication']
as core.Map<core.String, core.dynamic>,
)
: null,
wuaPackage: json_.containsKey('wuaPackage')
? WindowsUpdatePackage.fromJson(
json_['wuaPackage'] as core.Map<core.String, core.dynamic>,
)
: null,
yumPackage: json_.containsKey('yumPackage')
? VersionedPackage.fromJson(
json_['yumPackage'] as core.Map<core.String, core.dynamic>,
)
: null,
zypperPackage: json_.containsKey('zypperPackage')
? VersionedPackage.fromJson(
json_['zypperPackage'] as core.Map<core.String, core.dynamic>,
)
: null,
zypperPatch: json_.containsKey('zypperPatch')
? ZypperPatch.fromJson(
json_['zypperPatch'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final aptPackage = this.aptPackage;
final cosPackage = this.cosPackage;
final googetPackage = this.googetPackage;
final qfePackage = this.qfePackage;
final windowsApplication = this.windowsApplication;
final wuaPackage = this.wuaPackage;
final yumPackage = this.yumPackage;
final zypperPackage = this.zypperPackage;
final zypperPatch = this.zypperPatch;
return {
'aptPackage': ?aptPackage,
'cosPackage': ?cosPackage,
'googetPackage': ?googetPackage,
'qfePackage': ?qfePackage,
'windowsApplication': ?windowsApplication,
'wuaPackage': ?wuaPackage,
'yumPackage': ?yumPackage,
'zypperPackage': ?zypperPackage,
'zypperPatch': ?zypperPatch,
};
}
}
/// The `Status` type defines a logical error model that is suitable for
/// different programming environments, including REST APIs and RPC APIs.
///
/// It is used by [gRPC](https://github.com/grpc). Each `Status` message
/// contains three pieces of data: error code, error message, and error details.
/// You can find out more about this error model and how to work with it in the
/// [API Design Guide](https://cloud.google.com/apis/design/errors).
typedef Status = $Status00;
/// A field in TableSchema.
class TableFieldSchema {
/// The field name.
///
/// The name must contain only letters (a-z, A-Z), numbers (0-9), or
/// underscores (_), and must start with a letter or underscore. The maximum
/// length is 128 characters.
core.String? field;
/// Describes the nested schema fields if the type property is set to RECORD.
core.List<TableFieldSchema>? fields;
/// The field mode.
///
/// Possible values include NULLABLE, REQUIRED and REPEATED. The default value
/// is NULLABLE.
core.String? mode;
/// The field data type.
///
/// Possible values include * STRING * BYTES * INTEGER * FLOAT * BOOLEAN *
/// TIMESTAMP * DATE * TIME * DATETIME * GEOGRAPHY, * NUMERIC, * BIGNUMERIC, *
/// RECORD (where RECORD indicates that the field contains a nested schema).
core.String? type;
TableFieldSchema({this.field, this.fields, this.mode, this.type});
TableFieldSchema.fromJson(core.Map json_)
: this(
field: json_['field'] as core.String?,
fields: (json_['fields'] as core.List?)
?.map(
(value) => TableFieldSchema.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
mode: json_['mode'] as core.String?,
type: json_['type'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final field = this.field;
final fields = this.fields;
final mode = this.mode;
final type = this.type;
return {'field': ?field, 'fields': ?fields, 'mode': ?mode, 'type': ?type};
}
}
/// BigQuery Compatible table schema.
class TableSchema {
/// Describes the fields in a table.
core.List<TableFieldSchema>? fields;
TableSchema({this.fields});
TableSchema.fromJson(core.Map json_)
: this(
fields: (json_['fields'] as core.List?)
?.map(
(value) => TableFieldSchema.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
);
core.Map<core.String, core.dynamic> toJson() {
final fields = this.fields;
return {'fields': ?fields};
}
}
/// The key and value for a
/// [tag](https://cloud.google.com/resource-manager/docs/tags/tags-overview).
class Tag {
/// TagKey namespaced name, in the format of {ORG_ID}/{TAG_KEY_SHORT_NAME}.
core.String? tagKey;
/// TagKey ID, in the format of tagKeys/{TAG_KEY_ID}.
core.String? tagKeyId;
/// TagValue namespaced name, in the format of
/// {ORG_ID}/{TAG_KEY_SHORT_NAME}/{TAG_VALUE_SHORT_NAME}.
core.String? tagValue;
/// TagValue ID, in the format of tagValues/{TAG_VALUE_ID}.
core.String? tagValueId;
Tag({this.tagKey, this.tagKeyId, this.tagValue, this.tagValueId});
Tag.fromJson(core.Map json_)
: this(
tagKey: json_['tagKey'] as core.String?,
tagKeyId: json_['tagKeyId'] as core.String?,
tagValue: json_['tagValue'] as core.String?,
tagValueId: json_['tagValueId'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final tagKey = this.tagKey;
final tagKeyId = this.tagKeyId;
final tagValue = this.tagValue;
final tagValueId = this.tagValueId;
return {
'tagKey': ?tagKey,
'tagKeyId': ?tagKeyId,
'tagValue': ?tagValue,
'tagValueId': ?tagValueId,
};
}
}
/// An asset in Google Cloud and its temporal metadata, including the time
/// window when it was observed and its status during that window.
class TemporalAsset {
/// An asset in Google Cloud.
Asset? asset;
/// Whether the asset has been deleted or not.
core.bool? deleted;
/// Prior copy of the asset.
///
/// Populated if prior_asset_state is PRESENT. Currently this is only set for
/// responses in Real-Time Feed.
Asset? priorAsset;
/// State of prior_asset.
/// Possible string values are:
/// - "PRIOR_ASSET_STATE_UNSPECIFIED" : prior_asset is not applicable for the
/// current asset.
/// - "PRESENT" : prior_asset is populated correctly.
/// - "INVALID" : Failed to set prior_asset.
/// - "DOES_NOT_EXIST" : Current asset is the first known state.
/// - "DELETED" : prior_asset is a deletion.
core.String? priorAssetState;
/// The time window when the asset data and state was observed.
TimeWindow? window;
TemporalAsset({
this.asset,
this.deleted,
this.priorAsset,
this.priorAssetState,
this.window,
});
TemporalAsset.fromJson(core.Map json_)
: this(
asset: json_.containsKey('asset')
? Asset.fromJson(
json_['asset'] as core.Map<core.String, core.dynamic>,
)
: null,
deleted: json_['deleted'] as core.bool?,
priorAsset: json_.containsKey('priorAsset')
? Asset.fromJson(
json_['priorAsset'] as core.Map<core.String, core.dynamic>,
)
: null,
priorAssetState: json_['priorAssetState'] as core.String?,
window: json_.containsKey('window')
? TimeWindow.fromJson(
json_['window'] as core.Map<core.String, core.dynamic>,
)
: null,
);
core.Map<core.String, core.dynamic> toJson() {
final asset = this.asset;
final deleted = this.deleted;
final priorAsset = this.priorAsset;
final priorAssetState = this.priorAssetState;
final window = this.window;
return {
'asset': ?asset,
'deleted': ?deleted,
'priorAsset': ?priorAsset,
'priorAssetState': ?priorAssetState,
'window': ?window,
};
}
}
/// A time window specified by its `start_time` and `end_time`.
class TimeWindow {
/// End time of the time window (inclusive).
///
/// If not specified, the current timestamp is used instead.
core.String? endTime;
/// Start time of the time window (exclusive).
core.String? startTime;
TimeWindow({this.endTime, this.startTime});
TimeWindow.fromJson(core.Map json_)
: this(
endTime: json_['endTime'] as core.String?,
startTime: json_['startTime'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final endTime = this.endTime;
final startTime = this.startTime;
return {'endTime': ?endTime, 'startTime': ?startTime};
}
}
/// Update asset feed request.
class UpdateFeedRequest {
/// The new values of feed details.
///
/// It must match an existing feed and the field `name` must be in the format
/// of: projects/project_number/feeds/feed_id or
/// folders/folder_number/feeds/feed_id or
/// organizations/organization_number/feeds/feed_id.
///
/// Required.
Feed? feed;
/// Only updates the `feed` fields indicated by this mask.
///
/// The field mask must not be empty, and it must not contain fields that are
/// immutable or only set by the server.
///
/// Required.
core.String? updateMask;
UpdateFeedRequest({this.feed, this.updateMask});
UpdateFeedRequest.fromJson(core.Map json_)
: this(
feed: json_.containsKey('feed')
? Feed.fromJson(
json_['feed'] as core.Map<core.String, core.dynamic>,
)
: null,
updateMask: json_['updateMask'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final feed = this.feed;
final updateMask = this.updateMask;
return {'feed': ?feed, 'updateMask': ?updateMask};
}
}
/// Information related to the a standard versioned package.
///
/// This includes package info for APT, Yum, Zypper, and Googet package
/// managers.
typedef VersionedPackage = $VersionedPackage;
/// Resource representation as defined by the corresponding service providing
/// the resource for a given API version.
class VersionedResource {
/// The exceptions of a resource.
core.List<AssetException>? assetExceptions;
/// JSON representation of the resource as defined by the corresponding
/// service providing this resource.
///
/// Example: If the resource is an instance provided by Compute Engine, this
/// field will contain the JSON representation of the instance as defined by
/// Compute Engine:
/// `https://cloud.google.com/compute/docs/reference/rest/v1/instances`. You
/// can find the resource definition for each supported resource type in this
/// table:
/// `https://cloud.google.com/asset-inventory/docs/supported-asset-types`
///
/// The values for Object must be JSON objects. It can consist of `num`,
/// `String`, `bool` and `null` as well as `Map` and `List` values.
core.Map<core.String, core.Object?>? resource;
/// API version of the resource.
///
/// Example: If the resource is an instance provided by Compute Engine v1 API
/// as defined in
/// `https://cloud.google.com/compute/docs/reference/rest/v1/instances`,
/// version will be "v1".
core.String? version;
VersionedResource({this.assetExceptions, this.resource, this.version});
VersionedResource.fromJson(core.Map json_)
: this(
assetExceptions: (json_['assetExceptions'] as core.List?)
?.map(
(value) => AssetException.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
resource: json_.containsKey('resource')
? json_['resource'] as core.Map<core.String, core.dynamic>
: null,
version: json_['version'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final assetExceptions = this.assetExceptions;
final resource = this.resource;
final version = this.version;
return {
'assetExceptions': ?assetExceptions,
'resource': ?resource,
'version': ?version,
};
}
}
/// Contains information about a Windows application that is retrieved from the
/// Windows Registry.
///
/// For more information about these fields, see:
/// https://docs.microsoft.com/en-us/windows/win32/msi/uninstall-registry-key
class WindowsApplication {
/// The name of the application or product.
core.String? displayName;
/// The version of the product or application in string format.
core.String? displayVersion;
/// The internet address for technical support.
core.String? helpLink;
/// The last time this product received service.
///
/// The value of this property is replaced each time a patch is applied or
/// removed from the product or the command-line option is used to repair the
/// product.
Date? installDate;
/// The name of the manufacturer for the product or application.
core.String? publisher;
WindowsApplication({
this.displayName,
this.displayVersion,
this.helpLink,
this.installDate,
this.publisher,
});
WindowsApplication.fromJson(core.Map json_)
: this(
displayName: json_['displayName'] as core.String?,
displayVersion: json_['displayVersion'] as core.String?,
helpLink: json_['helpLink'] as core.String?,
installDate: json_.containsKey('installDate')
? Date.fromJson(
json_['installDate'] as core.Map<core.String, core.dynamic>,
)
: null,
publisher: json_['publisher'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final displayName = this.displayName;
final displayVersion = this.displayVersion;
final helpLink = this.helpLink;
final installDate = this.installDate;
final publisher = this.publisher;
return {
'displayName': ?displayName,
'displayVersion': ?displayVersion,
'helpLink': ?helpLink,
'installDate': ?installDate,
'publisher': ?publisher,
};
}
}
/// Information related to a Quick Fix Engineering package.
///
/// Fields are taken from Windows QuickFixEngineering Interface and match the
/// source names:
/// https://docs.microsoft.com/en-us/windows/win32/cimwin32prov/win32-quickfixengineering
typedef WindowsQuickFixEngineeringPackage = $WindowsQuickFixEngineeringPackage;
/// Categories specified by the Windows Update.
typedef WindowsUpdateCategory = $WindowsUpdateCategory;
/// Details related to a Windows Update package.
///
/// Field data and names are taken from Windows Update API IUpdate Interface:
/// https://docs.microsoft.com/en-us/windows/win32/api/_wua/ Descriptive fields
/// like title, and description are localized based on the locale of the VM
/// being updated.
class WindowsUpdatePackage {
/// The categories that are associated with this update package.
core.List<WindowsUpdateCategory>? categories;
/// The localized description of the update package.
core.String? description;
/// A collection of Microsoft Knowledge Base article IDs that are associated
/// with the update package.
core.List<core.String>? kbArticleIds;
/// The last published date of the update, in (UTC) date and time.
core.String? lastDeploymentChangeTime;
/// A collection of URLs that provide more information about the update
/// package.
core.List<core.String>? moreInfoUrls;
/// The revision number of this update package.
core.int? revisionNumber;
/// A hyperlink to the language-specific support information for the update.
core.String? supportUrl;
/// The localized title of the update package.
core.String? title;
/// Gets the identifier of an update package.
///
/// Stays the same across revisions.
core.String? updateId;
WindowsUpdatePackage({
this.categories,
this.description,
this.kbArticleIds,
this.lastDeploymentChangeTime,
this.moreInfoUrls,
this.revisionNumber,
this.supportUrl,
this.title,
this.updateId,
});
WindowsUpdatePackage.fromJson(core.Map json_)
: this(
categories: (json_['categories'] as core.List?)
?.map(
(value) => WindowsUpdateCategory.fromJson(
value as core.Map<core.String, core.dynamic>,
),
)
.toList(),
description: json_['description'] as core.String?,
kbArticleIds: (json_['kbArticleIds'] as core.List?)
?.map((value) => value as core.String)
.toList(),
lastDeploymentChangeTime:
json_['lastDeploymentChangeTime'] as core.String?,
moreInfoUrls: (json_['moreInfoUrls'] as core.List?)
?.map((value) => value as core.String)
.toList(),
revisionNumber: json_['revisionNumber'] as core.int?,
supportUrl: json_['supportUrl'] as core.String?,
title: json_['title'] as core.String?,
updateId: json_['updateId'] as core.String?,
);
core.Map<core.String, core.dynamic> toJson() {
final categories = this.categories;
final description = this.description;
final kbArticleIds = this.kbArticleIds;
final lastDeploymentChangeTime = this.lastDeploymentChangeTime;
final moreInfoUrls = this.moreInfoUrls;
final revisionNumber = this.revisionNumber;
final supportUrl = this.supportUrl;
final title = this.title;
final updateId = this.updateId;
return {
'categories': ?categories,
'description': ?description,
'kbArticleIds': ?kbArticleIds,
'lastDeploymentChangeTime': ?lastDeploymentChangeTime,
'moreInfoUrls': ?moreInfoUrls,
'revisionNumber': ?revisionNumber,
'supportUrl': ?supportUrl,
'title': ?title,
'updateId': ?updateId,
};
}
}
/// Details related to a Zypper Patch.
typedef ZypperPatch = $ZypperPatch;