CloudFunctionsServiceClient(*, credentials: Optional[google.auth.credentials.Credentials] = None, transport: Optional[Union[str, google.cloud.functions_v1.services.cloud_functions_service.transports.base.CloudFunctionsServiceTransport]] = None, client_options: Optional[Union[google.api_core.client_options.ClientOptions, dict]] = None, client_info: google.api_core.gapic_v1.client_info.ClientInfo = <google.api_core.gapic_v1.client_info.ClientInfo object>)A service that application uses to manipulate triggers and functions.
Properties
transport
Returns the transport used by the client instance.
| Type | Description | 
| CloudFunctionsServiceTransport | The transport used by the client instance. | 
Methods
CloudFunctionsServiceClient
CloudFunctionsServiceClient(*, credentials: Optional[google.auth.credentials.Credentials] = None, transport: Optional[Union[str, google.cloud.functions_v1.services.cloud_functions_service.transports.base.CloudFunctionsServiceTransport]] = None, client_options: Optional[Union[google.api_core.client_options.ClientOptions, dict]] = None, client_info: google.api_core.gapic_v1.client_info.ClientInfo = <google.api_core.gapic_v1.client_info.ClientInfo object>)Instantiates the cloud functions service client.
| Name | Description | 
| credentials | Optional[google.auth.credentials.Credentials]The authorization credentials to attach to requests. These credentials identify the application to the service; if none are specified, the client will attempt to ascertain the credentials from the environment. | 
| transport | Union[str, CloudFunctionsServiceTransport]The transport to use. If set to None, a transport is chosen automatically. | 
| client_options | Optional[Union[google.api_core.client_options.ClientOptions, dict]]Custom options for the client. It won't take effect if a  | 
| client_info | google.api_core.gapic_v1.client_info.ClientInfoThe client info used to send a user-agent string along with API requests. If  | 
| Type | Description | 
| google.auth.exceptions.MutualTLSChannelError | If mutual TLS transport creation failed for any reason. | 
__exit__
__exit__(type, value, traceback)Releases underlying transport's resources.
call_function
call_function(request: Optional[Union[google.cloud.functions_v1.types.functions.CallFunctionRequest, dict]] = None, *, name: Optional[str] = None, data: Optional[str] = None, retry: Union[google.api_core.retry.Retry, google.api_core.gapic_v1.method._MethodDefault] = <_MethodDefault._DEFAULT_VALUE: <object object>>, timeout: Union[float, object] = <_MethodDefault._DEFAULT_VALUE: <object object>>, metadata: Sequence[Tuple[str, str]] = ())Synchronously invokes a deployed Cloud Function. To be used for
testing purposes as very limited traffic is allowed. For more
information on the actual limits, refer to Rate
Limits <https://cloud.google.com/functions/quotas#rate_limits>__.
# This snippet has been automatically generated and should be regarded as a
# code template only.
# It will require modifications to work:
# - It may require correct/in-range values for request initialization.
# - It may require specifying regional endpoints when creating the service
#   client as shown in:
#   https://googleapis.dev/python/google-api-core/latest/client_options.html
from google.cloud import functions_v1
def sample_call_function():
    # Create a client
    client = functions_v1.CloudFunctionsServiceClient()
    # Initialize request argument(s)
    request = functions_v1.CallFunctionRequest(
        name="name_value",
        data="data_value",
    )
    # Make the request
    response = client.call_function(request=request)
    # Handle the response
    print(response)
| Name | Description | 
| request | Union[google.cloud.functions_v1.types.CallFunctionRequest, dict]The request object. Request for the  | 
| name | strRequired. The name of the function to be called. This corresponds to the  | 
| data | strRequired. Input to be passed to the function. This corresponds to the  | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. | 
| timeout | floatThe timeout for this request. | 
| metadata | Sequence[Tuple[str, str]]Strings which should be sent along with the request as metadata. | 
| Type | Description | 
| google.cloud.functions_v1.types.CallFunctionResponse | Response of CallFunction method. | 
cloud_function_path
cloud_function_path(project: str, location: str, function: str)Returns a fully-qualified cloud_function string.
common_billing_account_path
common_billing_account_path(billing_account: str)Returns a fully-qualified billing_account string.
common_folder_path
common_folder_path(folder: str)Returns a fully-qualified folder string.
common_location_path
common_location_path(project: str, location: str)Returns a fully-qualified location string.
common_organization_path
common_organization_path(organization: str)Returns a fully-qualified organization string.
common_project_path
common_project_path(project: str)Returns a fully-qualified project string.
create_function
create_function(request: Optional[Union[google.cloud.functions_v1.types.functions.CreateFunctionRequest, dict]] = None, *, location: Optional[str] = None, function: Optional[google.cloud.functions_v1.types.functions.CloudFunction] = None, retry: Union[google.api_core.retry.Retry, google.api_core.gapic_v1.method._MethodDefault] = <_MethodDefault._DEFAULT_VALUE: <object object>>, timeout: Union[float, object] = <_MethodDefault._DEFAULT_VALUE: <object object>>, metadata: Sequence[Tuple[str, str]] = ())Creates a new function. If a function with the given name
already exists in the specified project, the long running
operation will return ALREADY_EXISTS error.
# This snippet has been automatically generated and should be regarded as a
# code template only.
# It will require modifications to work:
# - It may require correct/in-range values for request initialization.
# - It may require specifying regional endpoints when creating the service
#   client as shown in:
#   https://googleapis.dev/python/google-api-core/latest/client_options.html
from google.cloud import functions_v1
def sample_create_function():
    # Create a client
    client = functions_v1.CloudFunctionsServiceClient()
    # Initialize request argument(s)
    function = functions_v1.CloudFunction()
    function.source_archive_url = "source_archive_url_value"
    request = functions_v1.CreateFunctionRequest(
        location="location_value",
        function=function,
    )
    # Make the request
    operation = client.create_function(request=request)
    print("Waiting for operation to complete...")
    response = operation.result()
    # Handle the response
    print(response)
| Name | Description | 
| request | Union[google.cloud.functions_v1.types.CreateFunctionRequest, dict]The request object. Request for the  | 
| location | strRequired. The project and location in which the function should be created, specified in the format  | 
| function | google.cloud.functions_v1.types.CloudFunctionRequired. Function to be created. This corresponds to the  | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. | 
| timeout | floatThe timeout for this request. | 
| metadata | Sequence[Tuple[str, str]]Strings which should be sent along with the request as metadata. | 
| Type | Description | 
| google.api_core.operation.Operation | An object representing a long-running operation. The result type for the operation will be CloudFunction Describes a Cloud Function that contains user computation executed in response to an event. It encapsulate function and triggers configurations. | 
crypto_key_path
crypto_key_path(project: str, location: str, key_ring: str, crypto_key: str)Returns a fully-qualified crypto_key string.
delete_function
delete_function(request: Optional[Union[google.cloud.functions_v1.types.functions.DeleteFunctionRequest, dict]] = None, *, name: Optional[str] = None, retry: Union[google.api_core.retry.Retry, google.api_core.gapic_v1.method._MethodDefault] = <_MethodDefault._DEFAULT_VALUE: <object object>>, timeout: Union[float, object] = <_MethodDefault._DEFAULT_VALUE: <object object>>, metadata: Sequence[Tuple[str, str]] = ())Deletes a function with the given name from the specified project. If the given function is used by some trigger, the trigger will be updated to remove this function.
# This snippet has been automatically generated and should be regarded as a
# code template only.
# It will require modifications to work:
# - It may require correct/in-range values for request initialization.
# - It may require specifying regional endpoints when creating the service
#   client as shown in:
#   https://googleapis.dev/python/google-api-core/latest/client_options.html
from google.cloud import functions_v1
def sample_delete_function():
    # Create a client
    client = functions_v1.CloudFunctionsServiceClient()
    # Initialize request argument(s)
    request = functions_v1.DeleteFunctionRequest(
        name="name_value",
    )
    # Make the request
    operation = client.delete_function(request=request)
    print("Waiting for operation to complete...")
    response = operation.result()
    # Handle the response
    print(response)
| Name | Description | 
| request | Union[google.cloud.functions_v1.types.DeleteFunctionRequest, dict]The request object. Request for the  | 
| name | strRequired. The name of the function which should be deleted. This corresponds to the  | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. | 
| timeout | floatThe timeout for this request. | 
| metadata | Sequence[Tuple[str, str]]Strings which should be sent along with the request as metadata. | 
| Type | Description | 
| google.api_core.operation.Operation | An object representing a long-running operation. The result type for the operation will be google.protobuf.empty_pb2.EmptyA 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); } | 
from_service_account_file
from_service_account_file(filename: str, *args, **kwargs)Creates an instance of this client using the provided credentials file.
| Name | Description | 
| filename | strThe path to the service account private key json file. | 
| Type | Description | 
| CloudFunctionsServiceClient | The constructed client. | 
from_service_account_info
from_service_account_info(info: dict, *args, **kwargs)Creates an instance of this client using the provided credentials info.
| Name | Description | 
| info | dictThe service account private key info. | 
| Type | Description | 
| CloudFunctionsServiceClient | The constructed client. | 
from_service_account_json
from_service_account_json(filename: str, *args, **kwargs)Creates an instance of this client using the provided credentials file.
| Name | Description | 
| filename | strThe path to the service account private key json file. | 
| Type | Description | 
| CloudFunctionsServiceClient | The constructed client. | 
generate_download_url
generate_download_url(request: Optional[Union[google.cloud.functions_v1.types.functions.GenerateDownloadUrlRequest, dict]] = None, *, retry: Union[google.api_core.retry.Retry, google.api_core.gapic_v1.method._MethodDefault] = <_MethodDefault._DEFAULT_VALUE: <object object>>, timeout: Union[float, object] = <_MethodDefault._DEFAULT_VALUE: <object object>>, metadata: Sequence[Tuple[str, str]] = ())Returns a signed URL for downloading deployed function source code. The URL is only valid for a limited period and should be used within minutes after generation. For more information about the signed URL usage see: https://cloud.google.com/storage/docs/access-control/signed-urls
# This snippet has been automatically generated and should be regarded as a
# code template only.
# It will require modifications to work:
# - It may require correct/in-range values for request initialization.
# - It may require specifying regional endpoints when creating the service
#   client as shown in:
#   https://googleapis.dev/python/google-api-core/latest/client_options.html
from google.cloud import functions_v1
def sample_generate_download_url():
    # Create a client
    client = functions_v1.CloudFunctionsServiceClient()
    # Initialize request argument(s)
    request = functions_v1.GenerateDownloadUrlRequest(
    )
    # Make the request
    response = client.generate_download_url(request=request)
    # Handle the response
    print(response)
| Name | Description | 
| request | Union[google.cloud.functions_v1.types.GenerateDownloadUrlRequest, dict]The request object. Request of  | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. | 
| timeout | floatThe timeout for this request. | 
| metadata | Sequence[Tuple[str, str]]Strings which should be sent along with the request as metadata. | 
| Type | Description | 
| google.cloud.functions_v1.types.GenerateDownloadUrlResponse | Response of GenerateDownloadUrl method. | 
generate_upload_url
generate_upload_url(request: Optional[Union[google.cloud.functions_v1.types.functions.GenerateUploadUrlRequest, dict]] = None, *, retry: Union[google.api_core.retry.Retry, google.api_core.gapic_v1.method._MethodDefault] = <_MethodDefault._DEFAULT_VALUE: <object object>>, timeout: Union[float, object] = <_MethodDefault._DEFAULT_VALUE: <object object>>, metadata: Sequence[Tuple[str, str]] = ())Returns a signed URL for uploading a function source code. For more information about the signed URL usage see: https://cloud.google.com/storage/docs/access-control/signed-urls. Once the function source code upload is complete, the used signed URL should be provided in CreateFunction or UpdateFunction request as a reference to the function source code.
When uploading source code to the generated signed URL, please follow these restrictions:
- Source file type should be a zip file.
- Source file size should not exceed 100MB limit.
- No credentials should be attached - the signed URLs provide access to the target bucket using internal service identity; if credentials were attached, the identity from the credentials would be used, but that identity does not have permissions to upload files to the URL.
When making a HTTP PUT request, these two headers need to be specified:
- content-type: application/zip
- x-goog-content-length-range: 0,104857600
And this header SHOULD NOT be specified:
- Authorization: Bearer YOUR_TOKEN
# This snippet has been automatically generated and should be regarded as a
# code template only.
# It will require modifications to work:
# - It may require correct/in-range values for request initialization.
# - It may require specifying regional endpoints when creating the service
#   client as shown in:
#   https://googleapis.dev/python/google-api-core/latest/client_options.html
from google.cloud import functions_v1
def sample_generate_upload_url():
    # Create a client
    client = functions_v1.CloudFunctionsServiceClient()
    # Initialize request argument(s)
    request = functions_v1.GenerateUploadUrlRequest(
    )
    # Make the request
    response = client.generate_upload_url(request=request)
    # Handle the response
    print(response)
| Name | Description | 
| request | Union[google.cloud.functions_v1.types.GenerateUploadUrlRequest, dict]The request object. Request of  | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. | 
| timeout | floatThe timeout for this request. | 
| metadata | Sequence[Tuple[str, str]]Strings which should be sent along with the request as metadata. | 
| Type | Description | 
| google.cloud.functions_v1.types.GenerateUploadUrlResponse | Response of GenerateSourceUploadUrl method. | 
get_function
get_function(request: Optional[Union[google.cloud.functions_v1.types.functions.GetFunctionRequest, dict]] = None, *, name: Optional[str] = None, retry: Union[google.api_core.retry.Retry, google.api_core.gapic_v1.method._MethodDefault] = <_MethodDefault._DEFAULT_VALUE: <object object>>, timeout: Union[float, object] = <_MethodDefault._DEFAULT_VALUE: <object object>>, metadata: Sequence[Tuple[str, str]] = ())Returns a function with the given name from the requested project.
# This snippet has been automatically generated and should be regarded as a
# code template only.
# It will require modifications to work:
# - It may require correct/in-range values for request initialization.
# - It may require specifying regional endpoints when creating the service
#   client as shown in:
#   https://googleapis.dev/python/google-api-core/latest/client_options.html
from google.cloud import functions_v1
def sample_get_function():
    # Create a client
    client = functions_v1.CloudFunctionsServiceClient()
    # Initialize request argument(s)
    request = functions_v1.GetFunctionRequest(
        name="name_value",
    )
    # Make the request
    response = client.get_function(request=request)
    # Handle the response
    print(response)
| Name | Description | 
| request | Union[google.cloud.functions_v1.types.GetFunctionRequest, dict]The request object. Request for the  | 
| name | strRequired. The name of the function which details should be obtained. This corresponds to the  | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. | 
| timeout | floatThe timeout for this request. | 
| metadata | Sequence[Tuple[str, str]]Strings which should be sent along with the request as metadata. | 
| Type | Description | 
| google.cloud.functions_v1.types.CloudFunction | Describes a Cloud Function that contains user computation executed in response to an event. It encapsulate function and triggers configurations. | 
get_iam_policy
get_iam_policy(request: Optional[Union[google.iam.v1.iam_policy_pb2.GetIamPolicyRequest, dict]] = None, *, retry: Union[google.api_core.retry.Retry, google.api_core.gapic_v1.method._MethodDefault] = <_MethodDefault._DEFAULT_VALUE: <object object>>, timeout: Union[float, object] = <_MethodDefault._DEFAULT_VALUE: <object object>>, metadata: Sequence[Tuple[str, str]] = ())Gets the IAM access control policy for a function. Returns an empty policy if the function exists and does not have a policy set.
# This snippet has been automatically generated and should be regarded as a
# code template only.
# It will require modifications to work:
# - It may require correct/in-range values for request initialization.
# - It may require specifying regional endpoints when creating the service
#   client as shown in:
#   https://googleapis.dev/python/google-api-core/latest/client_options.html
from google.cloud import functions_v1
from google.iam.v1 import iam_policy_pb2  # type: ignore
def sample_get_iam_policy():
    # Create a client
    client = functions_v1.CloudFunctionsServiceClient()
    # Initialize request argument(s)
    request = iam_policy_pb2.GetIamPolicyRequest(
        resource="resource_value",
    )
    # Make the request
    response = client.get_iam_policy(request=request)
    # Handle the response
    print(response)
| Name | Description | 
| request | Union[google.iam.v1.iam_policy_pb2.GetIamPolicyRequest, dict]The request object. Request message for  | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. | 
| timeout | floatThe timeout for this request. | 
| metadata | Sequence[Tuple[str, str]]Strings which should be sent along with the request as metadata. | 
| Type | Description | 
| google.iam.v1.policy_pb2.Policy | 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:[email protected]", "group:[email protected]", "domain:google.com", "serviceAccount:[email protected]" ] }, { "role": "roles/resourcemanager.organizationViewer", "members": [ "user:[email protected]" ], "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:\="" [email protected]="" -="" group:\="" [email protected]="" -="" domain:google.com="" -="" serviceaccount:\="" [email protected]="" role:="" roles/resourcemanager.organizationadmin="" -="" members:="" -="" user:\="" [email protected]="" 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](\=""> | 
get_mtls_endpoint_and_cert_source
get_mtls_endpoint_and_cert_source(
    client_options: Optional[google.api_core.client_options.ClientOptions] = None,
)Return the API endpoint and client cert source for mutual TLS.
The client cert source is determined in the following order:
(1) if GOOGLE_API_USE_CLIENT_CERTIFICATE environment variable is not "true", the
client cert source is None.
(2) if client_options.client_cert_source is provided, use the provided one; if the
default client cert source exists, use the default one; otherwise the client cert
source is None.
The API endpoint is determined in the following order:
(1) if client_options.api_endpoint if provided, use the provided one.
(2) if GOOGLE_API_USE_CLIENT_CERTIFICATE environment variable is "always", use the
default mTLS endpoint; if the environment variable is "never", use the default API
endpoint; otherwise if client cert source exists, use the default mTLS endpoint, otherwise
use the default API endpoint.
More details can be found at https://google.aip.dev/auth/4114.
| Name | Description | 
| client_options | google.api_core.client_options.ClientOptionsCustom options for the client. Only the  | 
| Type | Description | 
| google.auth.exceptions.MutualTLSChannelError | If any errors happen. | 
| Type | Description | 
| Tuple[str, Callable[[], Tuple[bytes, bytes]]] | returns the API endpoint and the client cert source to use. | 
list_functions
list_functions(request: Optional[Union[google.cloud.functions_v1.types.functions.ListFunctionsRequest, dict]] = None, *, retry: Union[google.api_core.retry.Retry, google.api_core.gapic_v1.method._MethodDefault] = <_MethodDefault._DEFAULT_VALUE: <object object>>, timeout: Union[float, object] = <_MethodDefault._DEFAULT_VALUE: <object object>>, metadata: Sequence[Tuple[str, str]] = ())Returns a list of functions that belong to the requested project.
# This snippet has been automatically generated and should be regarded as a
# code template only.
# It will require modifications to work:
# - It may require correct/in-range values for request initialization.
# - It may require specifying regional endpoints when creating the service
#   client as shown in:
#   https://googleapis.dev/python/google-api-core/latest/client_options.html
from google.cloud import functions_v1
def sample_list_functions():
    # Create a client
    client = functions_v1.CloudFunctionsServiceClient()
    # Initialize request argument(s)
    request = functions_v1.ListFunctionsRequest(
    )
    # Make the request
    page_result = client.list_functions(request=request)
    # Handle the response
    for response in page_result:
        print(response)
| Name | Description | 
| request | Union[google.cloud.functions_v1.types.ListFunctionsRequest, dict]The request object. Request for the  | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. | 
| timeout | floatThe timeout for this request. | 
| metadata | Sequence[Tuple[str, str]]Strings which should be sent along with the request as metadata. | 
| Type | Description | 
| google.cloud.functions_v1.services.cloud_functions_service.pagers.ListFunctionsPager | Response for the ListFunctions method. Iterating over this object will yield results and resolve additional pages automatically. | 
parse_cloud_function_path
parse_cloud_function_path(path: str)Parses a cloud_function path into its component segments.
parse_common_billing_account_path
parse_common_billing_account_path(path: str)Parse a billing_account path into its component segments.
parse_common_folder_path
parse_common_folder_path(path: str)Parse a folder path into its component segments.
parse_common_location_path
parse_common_location_path(path: str)Parse a location path into its component segments.
parse_common_organization_path
parse_common_organization_path(path: str)Parse a organization path into its component segments.
parse_common_project_path
parse_common_project_path(path: str)Parse a project path into its component segments.
parse_crypto_key_path
parse_crypto_key_path(path: str)Parses a crypto_key path into its component segments.
parse_repository_path
parse_repository_path(path: str)Parses a repository path into its component segments.
repository_path
repository_path(project: str, location: str, repository: str)Returns a fully-qualified repository string.
set_iam_policy
set_iam_policy(request: Optional[Union[google.iam.v1.iam_policy_pb2.SetIamPolicyRequest, dict]] = None, *, retry: Union[google.api_core.retry.Retry, google.api_core.gapic_v1.method._MethodDefault] = <_MethodDefault._DEFAULT_VALUE: <object object>>, timeout: Union[float, object] = <_MethodDefault._DEFAULT_VALUE: <object object>>, metadata: Sequence[Tuple[str, str]] = ())Sets the IAM access control policy on the specified function. Replaces any existing policy.
# This snippet has been automatically generated and should be regarded as a
# code template only.
# It will require modifications to work:
# - It may require correct/in-range values for request initialization.
# - It may require specifying regional endpoints when creating the service
#   client as shown in:
#   https://googleapis.dev/python/google-api-core/latest/client_options.html
from google.cloud import functions_v1
from google.iam.v1 import iam_policy_pb2  # type: ignore
def sample_set_iam_policy():
    # Create a client
    client = functions_v1.CloudFunctionsServiceClient()
    # Initialize request argument(s)
    request = iam_policy_pb2.SetIamPolicyRequest(
        resource="resource_value",
    )
    # Make the request
    response = client.set_iam_policy(request=request)
    # Handle the response
    print(response)
| Name | Description | 
| request | Union[google.iam.v1.iam_policy_pb2.SetIamPolicyRequest, dict]The request object. Request message for  | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. | 
| timeout | floatThe timeout for this request. | 
| metadata | Sequence[Tuple[str, str]]Strings which should be sent along with the request as metadata. | 
| Type | Description | 
| google.iam.v1.policy_pb2.Policy | 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:[email protected]", "group:[email protected]", "domain:google.com", "serviceAccount:[email protected]" ] }, { "role": "roles/resourcemanager.organizationViewer", "members": [ "user:[email protected]" ], "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:\="" [email protected]="" -="" group:\="" [email protected]="" -="" domain:google.com="" -="" serviceaccount:\="" [email protected]="" role:="" roles/resourcemanager.organizationadmin="" -="" members:="" -="" user:\="" [email protected]="" 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](\=""> | 
test_iam_permissions
test_iam_permissions(request: Optional[Union[google.iam.v1.iam_policy_pb2.TestIamPermissionsRequest, dict]] = None, *, retry: Union[google.api_core.retry.Retry, google.api_core.gapic_v1.method._MethodDefault] = <_MethodDefault._DEFAULT_VALUE: <object object>>, timeout: Union[float, object] = <_MethodDefault._DEFAULT_VALUE: <object object>>, metadata: Sequence[Tuple[str, str]] = ())Tests the specified permissions against the IAM access control policy for a function. If the function does not exist, this will return an empty set of permissions, not a NOT_FOUND error.
# This snippet has been automatically generated and should be regarded as a
# code template only.
# It will require modifications to work:
# - It may require correct/in-range values for request initialization.
# - It may require specifying regional endpoints when creating the service
#   client as shown in:
#   https://googleapis.dev/python/google-api-core/latest/client_options.html
from google.cloud import functions_v1
from google.iam.v1 import iam_policy_pb2  # type: ignore
def sample_test_iam_permissions():
    # Create a client
    client = functions_v1.CloudFunctionsServiceClient()
    # Initialize request argument(s)
    request = iam_policy_pb2.TestIamPermissionsRequest(
        resource="resource_value",
        permissions=['permissions_value1', 'permissions_value2'],
    )
    # Make the request
    response = client.test_iam_permissions(request=request)
    # Handle the response
    print(response)
| Name | Description | 
| request | Union[google.iam.v1.iam_policy_pb2.TestIamPermissionsRequest, dict]The request object. Request message for  | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. | 
| timeout | floatThe timeout for this request. | 
| metadata | Sequence[Tuple[str, str]]Strings which should be sent along with the request as metadata. | 
| Type | Description | 
| google.iam.v1.iam_policy_pb2.TestIamPermissionsResponse | Response message for TestIamPermissions method. | 
update_function
update_function(request: Optional[Union[google.cloud.functions_v1.types.functions.UpdateFunctionRequest, dict]] = None, *, function: Optional[google.cloud.functions_v1.types.functions.CloudFunction] = None, retry: Union[google.api_core.retry.Retry, google.api_core.gapic_v1.method._MethodDefault] = <_MethodDefault._DEFAULT_VALUE: <object object>>, timeout: Union[float, object] = <_MethodDefault._DEFAULT_VALUE: <object object>>, metadata: Sequence[Tuple[str, str]] = ())Updates existing function.
# This snippet has been automatically generated and should be regarded as a
# code template only.
# It will require modifications to work:
# - It may require correct/in-range values for request initialization.
# - It may require specifying regional endpoints when creating the service
#   client as shown in:
#   https://googleapis.dev/python/google-api-core/latest/client_options.html
from google.cloud import functions_v1
def sample_update_function():
    # Create a client
    client = functions_v1.CloudFunctionsServiceClient()
    # Initialize request argument(s)
    function = functions_v1.CloudFunction()
    function.source_archive_url = "source_archive_url_value"
    request = functions_v1.UpdateFunctionRequest(
        function=function,
    )
    # Make the request
    operation = client.update_function(request=request)
    print("Waiting for operation to complete...")
    response = operation.result()
    # Handle the response
    print(response)
| Name | Description | 
| request | Union[google.cloud.functions_v1.types.UpdateFunctionRequest, dict]The request object. Request for the  | 
| function | google.cloud.functions_v1.types.CloudFunctionRequired. New version of the function. This corresponds to the  | 
| retry | google.api_core.retry.RetryDesignation of what errors, if any, should be retried. | 
| timeout | floatThe timeout for this request. | 
| metadata | Sequence[Tuple[str, str]]Strings which should be sent along with the request as metadata. | 
| Type | Description | 
| google.api_core.operation.Operation | An object representing a long-running operation. The result type for the operation will be CloudFunction Describes a Cloud Function that contains user computation executed in response to an event. It encapsulate function and triggers configurations. |