Class WorkstationsClient

  • All Implemented Interfaces:
    com.google.api.gax.core.BackgroundResource, AutoCloseable

    @BetaApi
    @Generated("by gapic-generator-java")
    public class WorkstationsClient
    extends Object
    implements com.google.api.gax.core.BackgroundResource
    Service Description: Service for interacting with Cloud Workstations.

    This class provides the ability to make remote calls to the backing service through method calls that map to API methods. Sample code to get started:

    
     // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
     try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
       WorkstationClusterName name =
           WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]");
       WorkstationCluster response = workstationsClient.getWorkstationCluster(name);
     }
     

    Note: close() needs to be called on the WorkstationsClient object to clean up resources such as threads. In the example above, try-with-resources is used, which automatically calls close().

    The surface of this class includes several types of Java methods for each of the API's methods:

    1. A "flattened" method. With this type of method, the fields of the request type have been converted into function parameters. It may be the case that not all fields are available as parameters, and not every API method will have a flattened method entry point.
    2. A "request object" method. This type of method only takes one parameter, a request object, which must be constructed before the call. Not every API method will have a request object method.
    3. A "callable" method. This type of method takes no parameters and returns an immutable API callable object, which can be used to initiate calls to the service.

    See the individual methods for example code.

    Many parameters require resource names to be formatted in a particular way. To assist with these names, this class includes a format method for each type of name, and additionally a parse method to extract the individual identifiers contained within names that are returned.

    This class can be customized by passing in a custom instance of WorkstationsSettings to create(). For example:

    To customize credentials:

    
     // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
     WorkstationsSettings workstationsSettings =
         WorkstationsSettings.newBuilder()
             .setCredentialsProvider(FixedCredentialsProvider.create(myCredentials))
             .build();
     WorkstationsClient workstationsClient = WorkstationsClient.create(workstationsSettings);
     

    To customize the endpoint:

    
     // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
     WorkstationsSettings workstationsSettings =
         WorkstationsSettings.newBuilder().setEndpoint(myEndpoint).build();
     WorkstationsClient workstationsClient = WorkstationsClient.create(workstationsSettings);
     

    To use REST (HTTP1.1/JSON) transport (instead of gRPC) for sending and receiving requests over the wire:

    
     // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
     WorkstationsSettings workstationsSettings = WorkstationsSettings.newHttpJsonBuilder().build();
     WorkstationsClient workstationsClient = WorkstationsClient.create(workstationsSettings);
     

    Please refer to the GitHub repository's samples for more quickstart code snippets.

    • Constructor Detail

      • WorkstationsClient

        protected WorkstationsClient​(WorkstationsSettings settings)
                              throws IOException
        Constructs an instance of WorkstationsClient, using the given settings. This is protected so that it is easy to make a subclass, but otherwise, the static factory methods should be preferred.
        Throws:
        IOException
    • Method Detail

      • create

        public static final WorkstationsClient create​(WorkstationsSettings settings)
                                               throws IOException
        Constructs an instance of WorkstationsClient, using the given settings. The channels are created based on the settings passed in, or defaults for any settings that are not set.
        Throws:
        IOException
      • create

        public static final WorkstationsClient create​(WorkstationsStub stub)
        Constructs an instance of WorkstationsClient, using the given stub for making calls. This is for advanced usage - prefer using create(WorkstationsSettings).
      • getOperationsClient

        public final com.google.longrunning.OperationsClient getOperationsClient()
        Returns the OperationsClient that can be used to query the status of a long-running operation returned by another API method call.
      • getHttpJsonOperationsClient

        @BetaApi
        public final com.google.api.gax.httpjson.longrunning.OperationsClient getHttpJsonOperationsClient()
        Returns the OperationsClient that can be used to query the status of a long-running operation returned by another API method call.
      • getWorkstationCluster

        public final WorkstationCluster getWorkstationCluster​(WorkstationClusterName name)
        Returns the requested workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationClusterName name =
               WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]");
           WorkstationCluster response = workstationsClient.getWorkstationCluster(name);
         }
         
        Parameters:
        name - Required. Name of the requested resource.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • getWorkstationCluster

        public final WorkstationCluster getWorkstationCluster​(String name)
        Returns the requested workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String name =
               WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]").toString();
           WorkstationCluster response = workstationsClient.getWorkstationCluster(name);
         }
         
        Parameters:
        name - Required. Name of the requested resource.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • getWorkstationCluster

        public final WorkstationCluster getWorkstationCluster​(GetWorkstationClusterRequest request)
        Returns the requested workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           GetWorkstationClusterRequest request =
               GetWorkstationClusterRequest.newBuilder()
                   .setName(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .build();
           WorkstationCluster response = workstationsClient.getWorkstationCluster(request);
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • getWorkstationClusterCallable

        public final com.google.api.gax.rpc.UnaryCallable<GetWorkstationClusterRequest,​WorkstationCluster> getWorkstationClusterCallable()
        Returns the requested workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           GetWorkstationClusterRequest request =
               GetWorkstationClusterRequest.newBuilder()
                   .setName(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .build();
           ApiFuture<WorkstationCluster> future =
               workstationsClient.getWorkstationClusterCallable().futureCall(request);
           // Do something.
           WorkstationCluster response = future.get();
         }
         
      • listWorkstationClusters

        public final WorkstationsClient.ListWorkstationClustersPagedResponse listWorkstationClusters​(LocationName parent)
        Returns all workstation clusters in the specified location.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           LocationName parent = LocationName.of("[PROJECT]", "[LOCATION]");
           for (WorkstationCluster element :
               workstationsClient.listWorkstationClusters(parent).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        parent - Required. Parent resource name.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listWorkstationClusters

        public final WorkstationsClient.ListWorkstationClustersPagedResponse listWorkstationClusters​(String parent)
        Returns all workstation clusters in the specified location.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String parent = LocationName.of("[PROJECT]", "[LOCATION]").toString();
           for (WorkstationCluster element :
               workstationsClient.listWorkstationClusters(parent).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        parent - Required. Parent resource name.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listWorkstationClusters

        public final WorkstationsClient.ListWorkstationClustersPagedResponse listWorkstationClusters​(ListWorkstationClustersRequest request)
        Returns all workstation clusters in the specified location.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListWorkstationClustersRequest request =
               ListWorkstationClustersRequest.newBuilder()
                   .setParent(LocationName.of("[PROJECT]", "[LOCATION]").toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           for (WorkstationCluster element :
               workstationsClient.listWorkstationClusters(request).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listWorkstationClustersPagedCallable

        public final com.google.api.gax.rpc.UnaryCallable<ListWorkstationClustersRequest,​WorkstationsClient.ListWorkstationClustersPagedResponse> listWorkstationClustersPagedCallable()
        Returns all workstation clusters in the specified location.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListWorkstationClustersRequest request =
               ListWorkstationClustersRequest.newBuilder()
                   .setParent(LocationName.of("[PROJECT]", "[LOCATION]").toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           ApiFuture<WorkstationCluster> future =
               workstationsClient.listWorkstationClustersPagedCallable().futureCall(request);
           // Do something.
           for (WorkstationCluster element : future.get().iterateAll()) {
             // doThingsWith(element);
           }
         }
         
      • listWorkstationClustersCallable

        public final com.google.api.gax.rpc.UnaryCallable<ListWorkstationClustersRequest,​ListWorkstationClustersResponse> listWorkstationClustersCallable()
        Returns all workstation clusters in the specified location.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListWorkstationClustersRequest request =
               ListWorkstationClustersRequest.newBuilder()
                   .setParent(LocationName.of("[PROJECT]", "[LOCATION]").toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           while (true) {
             ListWorkstationClustersResponse response =
                 workstationsClient.listWorkstationClustersCallable().call(request);
             for (WorkstationCluster element : response.getWorkstationClustersList()) {
               // doThingsWith(element);
             }
             String nextPageToken = response.getNextPageToken();
             if (!Strings.isNullOrEmpty(nextPageToken)) {
               request = request.toBuilder().setPageToken(nextPageToken).build();
             } else {
               break;
             }
           }
         }
         
      • createWorkstationClusterAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationCluster,​OperationMetadata> createWorkstationClusterAsync​(LocationName parent,
                                                                                                                                              WorkstationCluster workstationCluster,
                                                                                                                                              String workstationClusterId)
        Creates a new workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           LocationName parent = LocationName.of("[PROJECT]", "[LOCATION]");
           WorkstationCluster workstationCluster = WorkstationCluster.newBuilder().build();
           String workstationClusterId = "workstationClusterId351421170";
           WorkstationCluster response =
               workstationsClient
                   .createWorkstationClusterAsync(parent, workstationCluster, workstationClusterId)
                   .get();
         }
         
        Parameters:
        parent - Required. Parent resource name.
        workstationCluster - Required. Workstation cluster to create.
        workstationClusterId - Required. ID to use for the workstation cluster.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • createWorkstationClusterAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationCluster,​OperationMetadata> createWorkstationClusterAsync​(String parent,
                                                                                                                                              WorkstationCluster workstationCluster,
                                                                                                                                              String workstationClusterId)
        Creates a new workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String parent = LocationName.of("[PROJECT]", "[LOCATION]").toString();
           WorkstationCluster workstationCluster = WorkstationCluster.newBuilder().build();
           String workstationClusterId = "workstationClusterId351421170";
           WorkstationCluster response =
               workstationsClient
                   .createWorkstationClusterAsync(parent, workstationCluster, workstationClusterId)
                   .get();
         }
         
        Parameters:
        parent - Required. Parent resource name.
        workstationCluster - Required. Workstation cluster to create.
        workstationClusterId - Required. ID to use for the workstation cluster.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • createWorkstationClusterAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationCluster,​OperationMetadata> createWorkstationClusterAsync​(CreateWorkstationClusterRequest request)
        Creates a new workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           CreateWorkstationClusterRequest request =
               CreateWorkstationClusterRequest.newBuilder()
                   .setParent(LocationName.of("[PROJECT]", "[LOCATION]").toString())
                   .setWorkstationClusterId("workstationClusterId351421170")
                   .setWorkstationCluster(WorkstationCluster.newBuilder().build())
                   .setValidateOnly(true)
                   .build();
           WorkstationCluster response = workstationsClient.createWorkstationClusterAsync(request).get();
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • createWorkstationClusterOperationCallable

        public final com.google.api.gax.rpc.OperationCallable<CreateWorkstationClusterRequest,​WorkstationCluster,​OperationMetadata> createWorkstationClusterOperationCallable()
        Creates a new workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           CreateWorkstationClusterRequest request =
               CreateWorkstationClusterRequest.newBuilder()
                   .setParent(LocationName.of("[PROJECT]", "[LOCATION]").toString())
                   .setWorkstationClusterId("workstationClusterId351421170")
                   .setWorkstationCluster(WorkstationCluster.newBuilder().build())
                   .setValidateOnly(true)
                   .build();
           OperationFuture<WorkstationCluster, OperationMetadata> future =
               workstationsClient.createWorkstationClusterOperationCallable().futureCall(request);
           // Do something.
           WorkstationCluster response = future.get();
         }
         
      • createWorkstationClusterCallable

        public final com.google.api.gax.rpc.UnaryCallable<CreateWorkstationClusterRequest,​com.google.longrunning.Operation> createWorkstationClusterCallable()
        Creates a new workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           CreateWorkstationClusterRequest request =
               CreateWorkstationClusterRequest.newBuilder()
                   .setParent(LocationName.of("[PROJECT]", "[LOCATION]").toString())
                   .setWorkstationClusterId("workstationClusterId351421170")
                   .setWorkstationCluster(WorkstationCluster.newBuilder().build())
                   .setValidateOnly(true)
                   .build();
           ApiFuture<Operation> future =
               workstationsClient.createWorkstationClusterCallable().futureCall(request);
           // Do something.
           Operation response = future.get();
         }
         
      • updateWorkstationClusterAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationCluster,​OperationMetadata> updateWorkstationClusterAsync​(WorkstationCluster workstationCluster,
                                                                                                                                              com.google.protobuf.FieldMask updateMask)
        Updates an existing workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationCluster workstationCluster = WorkstationCluster.newBuilder().build();
           FieldMask updateMask = FieldMask.newBuilder().build();
           WorkstationCluster response =
               workstationsClient.updateWorkstationClusterAsync(workstationCluster, updateMask).get();
         }
         
        Parameters:
        workstationCluster - Required. Workstation cluster to update.
        updateMask - Required. Mask that specifies which fields in the workstation cluster should be updated.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • updateWorkstationClusterAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationCluster,​OperationMetadata> updateWorkstationClusterAsync​(UpdateWorkstationClusterRequest request)
        Updates an existing workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           UpdateWorkstationClusterRequest request =
               UpdateWorkstationClusterRequest.newBuilder()
                   .setWorkstationCluster(WorkstationCluster.newBuilder().build())
                   .setUpdateMask(FieldMask.newBuilder().build())
                   .setValidateOnly(true)
                   .setAllowMissing(true)
                   .build();
           WorkstationCluster response = workstationsClient.updateWorkstationClusterAsync(request).get();
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • updateWorkstationClusterOperationCallable

        public final com.google.api.gax.rpc.OperationCallable<UpdateWorkstationClusterRequest,​WorkstationCluster,​OperationMetadata> updateWorkstationClusterOperationCallable()
        Updates an existing workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           UpdateWorkstationClusterRequest request =
               UpdateWorkstationClusterRequest.newBuilder()
                   .setWorkstationCluster(WorkstationCluster.newBuilder().build())
                   .setUpdateMask(FieldMask.newBuilder().build())
                   .setValidateOnly(true)
                   .setAllowMissing(true)
                   .build();
           OperationFuture<WorkstationCluster, OperationMetadata> future =
               workstationsClient.updateWorkstationClusterOperationCallable().futureCall(request);
           // Do something.
           WorkstationCluster response = future.get();
         }
         
      • updateWorkstationClusterCallable

        public final com.google.api.gax.rpc.UnaryCallable<UpdateWorkstationClusterRequest,​com.google.longrunning.Operation> updateWorkstationClusterCallable()
        Updates an existing workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           UpdateWorkstationClusterRequest request =
               UpdateWorkstationClusterRequest.newBuilder()
                   .setWorkstationCluster(WorkstationCluster.newBuilder().build())
                   .setUpdateMask(FieldMask.newBuilder().build())
                   .setValidateOnly(true)
                   .setAllowMissing(true)
                   .build();
           ApiFuture<Operation> future =
               workstationsClient.updateWorkstationClusterCallable().futureCall(request);
           // Do something.
           Operation response = future.get();
         }
         
      • deleteWorkstationClusterAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationCluster,​OperationMetadata> deleteWorkstationClusterAsync​(WorkstationClusterName name)
        Deletes the specified workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationClusterName name =
               WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]");
           WorkstationCluster response = workstationsClient.deleteWorkstationClusterAsync(name).get();
         }
         
        Parameters:
        name - Required. Name of the workstation cluster to delete.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • deleteWorkstationClusterAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationCluster,​OperationMetadata> deleteWorkstationClusterAsync​(String name)
        Deletes the specified workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String name =
               WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]").toString();
           WorkstationCluster response = workstationsClient.deleteWorkstationClusterAsync(name).get();
         }
         
        Parameters:
        name - Required. Name of the workstation cluster to delete.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • deleteWorkstationClusterAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationCluster,​OperationMetadata> deleteWorkstationClusterAsync​(DeleteWorkstationClusterRequest request)
        Deletes the specified workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           DeleteWorkstationClusterRequest request =
               DeleteWorkstationClusterRequest.newBuilder()
                   .setName(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .setForce(true)
                   .build();
           WorkstationCluster response = workstationsClient.deleteWorkstationClusterAsync(request).get();
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • deleteWorkstationClusterOperationCallable

        public final com.google.api.gax.rpc.OperationCallable<DeleteWorkstationClusterRequest,​WorkstationCluster,​OperationMetadata> deleteWorkstationClusterOperationCallable()
        Deletes the specified workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           DeleteWorkstationClusterRequest request =
               DeleteWorkstationClusterRequest.newBuilder()
                   .setName(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .setForce(true)
                   .build();
           OperationFuture<WorkstationCluster, OperationMetadata> future =
               workstationsClient.deleteWorkstationClusterOperationCallable().futureCall(request);
           // Do something.
           WorkstationCluster response = future.get();
         }
         
      • deleteWorkstationClusterCallable

        public final com.google.api.gax.rpc.UnaryCallable<DeleteWorkstationClusterRequest,​com.google.longrunning.Operation> deleteWorkstationClusterCallable()
        Deletes the specified workstation cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           DeleteWorkstationClusterRequest request =
               DeleteWorkstationClusterRequest.newBuilder()
                   .setName(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .setForce(true)
                   .build();
           ApiFuture<Operation> future =
               workstationsClient.deleteWorkstationClusterCallable().futureCall(request);
           // Do something.
           Operation response = future.get();
         }
         
      • getWorkstationConfig

        public final WorkstationConfig getWorkstationConfig​(WorkstationConfigName name)
        Returns the requested workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationConfigName name =
               WorkstationConfigName.of(
                   "[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]", "[WORKSTATION_CONFIG]");
           WorkstationConfig response = workstationsClient.getWorkstationConfig(name);
         }
         
        Parameters:
        name - Required. Name of the requested resource.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • getWorkstationConfig

        public final WorkstationConfig getWorkstationConfig​(String name)
        Returns the requested workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String name =
               WorkstationConfigName.of(
                       "[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]", "[WORKSTATION_CONFIG]")
                   .toString();
           WorkstationConfig response = workstationsClient.getWorkstationConfig(name);
         }
         
        Parameters:
        name - Required. Name of the requested resource.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • getWorkstationConfig

        public final WorkstationConfig getWorkstationConfig​(GetWorkstationConfigRequest request)
        Returns the requested workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           GetWorkstationConfigRequest request =
               GetWorkstationConfigRequest.newBuilder()
                   .setName(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .build();
           WorkstationConfig response = workstationsClient.getWorkstationConfig(request);
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • getWorkstationConfigCallable

        public final com.google.api.gax.rpc.UnaryCallable<GetWorkstationConfigRequest,​WorkstationConfig> getWorkstationConfigCallable()
        Returns the requested workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           GetWorkstationConfigRequest request =
               GetWorkstationConfigRequest.newBuilder()
                   .setName(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .build();
           ApiFuture<WorkstationConfig> future =
               workstationsClient.getWorkstationConfigCallable().futureCall(request);
           // Do something.
           WorkstationConfig response = future.get();
         }
         
      • listWorkstationConfigs

        public final WorkstationsClient.ListWorkstationConfigsPagedResponse listWorkstationConfigs​(WorkstationClusterName parent)
        Returns all workstation configurations in the specified cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationClusterName parent =
               WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]");
           for (WorkstationConfig element :
               workstationsClient.listWorkstationConfigs(parent).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        parent - Required. Parent resource name.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listWorkstationConfigs

        public final WorkstationsClient.ListWorkstationConfigsPagedResponse listWorkstationConfigs​(String parent)
        Returns all workstation configurations in the specified cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String parent =
               WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]").toString();
           for (WorkstationConfig element :
               workstationsClient.listWorkstationConfigs(parent).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        parent - Required. Parent resource name.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listWorkstationConfigs

        public final WorkstationsClient.ListWorkstationConfigsPagedResponse listWorkstationConfigs​(ListWorkstationConfigsRequest request)
        Returns all workstation configurations in the specified cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListWorkstationConfigsRequest request =
               ListWorkstationConfigsRequest.newBuilder()
                   .setParent(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           for (WorkstationConfig element :
               workstationsClient.listWorkstationConfigs(request).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listWorkstationConfigsPagedCallable

        public final com.google.api.gax.rpc.UnaryCallable<ListWorkstationConfigsRequest,​WorkstationsClient.ListWorkstationConfigsPagedResponse> listWorkstationConfigsPagedCallable()
        Returns all workstation configurations in the specified cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListWorkstationConfigsRequest request =
               ListWorkstationConfigsRequest.newBuilder()
                   .setParent(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           ApiFuture<WorkstationConfig> future =
               workstationsClient.listWorkstationConfigsPagedCallable().futureCall(request);
           // Do something.
           for (WorkstationConfig element : future.get().iterateAll()) {
             // doThingsWith(element);
           }
         }
         
      • listWorkstationConfigsCallable

        public final com.google.api.gax.rpc.UnaryCallable<ListWorkstationConfigsRequest,​ListWorkstationConfigsResponse> listWorkstationConfigsCallable()
        Returns all workstation configurations in the specified cluster.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListWorkstationConfigsRequest request =
               ListWorkstationConfigsRequest.newBuilder()
                   .setParent(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           while (true) {
             ListWorkstationConfigsResponse response =
                 workstationsClient.listWorkstationConfigsCallable().call(request);
             for (WorkstationConfig element : response.getWorkstationConfigsList()) {
               // doThingsWith(element);
             }
             String nextPageToken = response.getNextPageToken();
             if (!Strings.isNullOrEmpty(nextPageToken)) {
               request = request.toBuilder().setPageToken(nextPageToken).build();
             } else {
               break;
             }
           }
         }
         
      • listUsableWorkstationConfigs

        public final WorkstationsClient.ListUsableWorkstationConfigsPagedResponse listUsableWorkstationConfigs​(WorkstationClusterName parent)
        Returns all workstation configurations in the specified cluster on which the caller has the "workstations.workstation.create" permission.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationClusterName parent =
               WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]");
           for (WorkstationConfig element :
               workstationsClient.listUsableWorkstationConfigs(parent).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        parent - Required. Parent resource name.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listUsableWorkstationConfigs

        public final WorkstationsClient.ListUsableWorkstationConfigsPagedResponse listUsableWorkstationConfigs​(String parent)
        Returns all workstation configurations in the specified cluster on which the caller has the "workstations.workstation.create" permission.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String parent =
               WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]").toString();
           for (WorkstationConfig element :
               workstationsClient.listUsableWorkstationConfigs(parent).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        parent - Required. Parent resource name.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listUsableWorkstationConfigs

        public final WorkstationsClient.ListUsableWorkstationConfigsPagedResponse listUsableWorkstationConfigs​(ListUsableWorkstationConfigsRequest request)
        Returns all workstation configurations in the specified cluster on which the caller has the "workstations.workstation.create" permission.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListUsableWorkstationConfigsRequest request =
               ListUsableWorkstationConfigsRequest.newBuilder()
                   .setParent(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           for (WorkstationConfig element :
               workstationsClient.listUsableWorkstationConfigs(request).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listUsableWorkstationConfigsPagedCallable

        public final com.google.api.gax.rpc.UnaryCallable<ListUsableWorkstationConfigsRequest,​WorkstationsClient.ListUsableWorkstationConfigsPagedResponse> listUsableWorkstationConfigsPagedCallable()
        Returns all workstation configurations in the specified cluster on which the caller has the "workstations.workstation.create" permission.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListUsableWorkstationConfigsRequest request =
               ListUsableWorkstationConfigsRequest.newBuilder()
                   .setParent(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           ApiFuture<WorkstationConfig> future =
               workstationsClient.listUsableWorkstationConfigsPagedCallable().futureCall(request);
           // Do something.
           for (WorkstationConfig element : future.get().iterateAll()) {
             // doThingsWith(element);
           }
         }
         
      • listUsableWorkstationConfigsCallable

        public final com.google.api.gax.rpc.UnaryCallable<ListUsableWorkstationConfigsRequest,​ListUsableWorkstationConfigsResponse> listUsableWorkstationConfigsCallable()
        Returns all workstation configurations in the specified cluster on which the caller has the "workstations.workstation.create" permission.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListUsableWorkstationConfigsRequest request =
               ListUsableWorkstationConfigsRequest.newBuilder()
                   .setParent(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           while (true) {
             ListUsableWorkstationConfigsResponse response =
                 workstationsClient.listUsableWorkstationConfigsCallable().call(request);
             for (WorkstationConfig element : response.getWorkstationConfigsList()) {
               // doThingsWith(element);
             }
             String nextPageToken = response.getNextPageToken();
             if (!Strings.isNullOrEmpty(nextPageToken)) {
               request = request.toBuilder().setPageToken(nextPageToken).build();
             } else {
               break;
             }
           }
         }
         
      • createWorkstationConfigAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationConfig,​OperationMetadata> createWorkstationConfigAsync​(WorkstationClusterName parent,
                                                                                                                                            WorkstationConfig workstationConfig,
                                                                                                                                            String workstationConfigId)
        Creates a new workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationClusterName parent =
               WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]");
           WorkstationConfig workstationConfig = WorkstationConfig.newBuilder().build();
           String workstationConfigId = "workstationConfigId798542368";
           WorkstationConfig response =
               workstationsClient
                   .createWorkstationConfigAsync(parent, workstationConfig, workstationConfigId)
                   .get();
         }
         
        Parameters:
        parent - Required. Parent resource name.
        workstationConfig - Required. Config to create.
        workstationConfigId - Required. ID to use for the workstation configuration.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • createWorkstationConfigAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationConfig,​OperationMetadata> createWorkstationConfigAsync​(String parent,
                                                                                                                                            WorkstationConfig workstationConfig,
                                                                                                                                            String workstationConfigId)
        Creates a new workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String parent =
               WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]").toString();
           WorkstationConfig workstationConfig = WorkstationConfig.newBuilder().build();
           String workstationConfigId = "workstationConfigId798542368";
           WorkstationConfig response =
               workstationsClient
                   .createWorkstationConfigAsync(parent, workstationConfig, workstationConfigId)
                   .get();
         }
         
        Parameters:
        parent - Required. Parent resource name.
        workstationConfig - Required. Config to create.
        workstationConfigId - Required. ID to use for the workstation configuration.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • createWorkstationConfigAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationConfig,​OperationMetadata> createWorkstationConfigAsync​(CreateWorkstationConfigRequest request)
        Creates a new workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           CreateWorkstationConfigRequest request =
               CreateWorkstationConfigRequest.newBuilder()
                   .setParent(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setWorkstationConfigId("workstationConfigId798542368")
                   .setWorkstationConfig(WorkstationConfig.newBuilder().build())
                   .setValidateOnly(true)
                   .build();
           WorkstationConfig response = workstationsClient.createWorkstationConfigAsync(request).get();
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • createWorkstationConfigOperationCallable

        public final com.google.api.gax.rpc.OperationCallable<CreateWorkstationConfigRequest,​WorkstationConfig,​OperationMetadata> createWorkstationConfigOperationCallable()
        Creates a new workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           CreateWorkstationConfigRequest request =
               CreateWorkstationConfigRequest.newBuilder()
                   .setParent(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setWorkstationConfigId("workstationConfigId798542368")
                   .setWorkstationConfig(WorkstationConfig.newBuilder().build())
                   .setValidateOnly(true)
                   .build();
           OperationFuture<WorkstationConfig, OperationMetadata> future =
               workstationsClient.createWorkstationConfigOperationCallable().futureCall(request);
           // Do something.
           WorkstationConfig response = future.get();
         }
         
      • createWorkstationConfigCallable

        public final com.google.api.gax.rpc.UnaryCallable<CreateWorkstationConfigRequest,​com.google.longrunning.Operation> createWorkstationConfigCallable()
        Creates a new workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           CreateWorkstationConfigRequest request =
               CreateWorkstationConfigRequest.newBuilder()
                   .setParent(
                       WorkstationClusterName.of("[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]")
                           .toString())
                   .setWorkstationConfigId("workstationConfigId798542368")
                   .setWorkstationConfig(WorkstationConfig.newBuilder().build())
                   .setValidateOnly(true)
                   .build();
           ApiFuture<Operation> future =
               workstationsClient.createWorkstationConfigCallable().futureCall(request);
           // Do something.
           Operation response = future.get();
         }
         
      • updateWorkstationConfigAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationConfig,​OperationMetadata> updateWorkstationConfigAsync​(WorkstationConfig workstationConfig,
                                                                                                                                            com.google.protobuf.FieldMask updateMask)
        Updates an existing workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationConfig workstationConfig = WorkstationConfig.newBuilder().build();
           FieldMask updateMask = FieldMask.newBuilder().build();
           WorkstationConfig response =
               workstationsClient.updateWorkstationConfigAsync(workstationConfig, updateMask).get();
         }
         
        Parameters:
        workstationConfig - Required. Config to update.
        updateMask - Required. Mask specifying which fields in the workstation configuration should be updated.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • updateWorkstationConfigAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationConfig,​OperationMetadata> updateWorkstationConfigAsync​(UpdateWorkstationConfigRequest request)
        Updates an existing workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           UpdateWorkstationConfigRequest request =
               UpdateWorkstationConfigRequest.newBuilder()
                   .setWorkstationConfig(WorkstationConfig.newBuilder().build())
                   .setUpdateMask(FieldMask.newBuilder().build())
                   .setValidateOnly(true)
                   .setAllowMissing(true)
                   .build();
           WorkstationConfig response = workstationsClient.updateWorkstationConfigAsync(request).get();
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • updateWorkstationConfigOperationCallable

        public final com.google.api.gax.rpc.OperationCallable<UpdateWorkstationConfigRequest,​WorkstationConfig,​OperationMetadata> updateWorkstationConfigOperationCallable()
        Updates an existing workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           UpdateWorkstationConfigRequest request =
               UpdateWorkstationConfigRequest.newBuilder()
                   .setWorkstationConfig(WorkstationConfig.newBuilder().build())
                   .setUpdateMask(FieldMask.newBuilder().build())
                   .setValidateOnly(true)
                   .setAllowMissing(true)
                   .build();
           OperationFuture<WorkstationConfig, OperationMetadata> future =
               workstationsClient.updateWorkstationConfigOperationCallable().futureCall(request);
           // Do something.
           WorkstationConfig response = future.get();
         }
         
      • updateWorkstationConfigCallable

        public final com.google.api.gax.rpc.UnaryCallable<UpdateWorkstationConfigRequest,​com.google.longrunning.Operation> updateWorkstationConfigCallable()
        Updates an existing workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           UpdateWorkstationConfigRequest request =
               UpdateWorkstationConfigRequest.newBuilder()
                   .setWorkstationConfig(WorkstationConfig.newBuilder().build())
                   .setUpdateMask(FieldMask.newBuilder().build())
                   .setValidateOnly(true)
                   .setAllowMissing(true)
                   .build();
           ApiFuture<Operation> future =
               workstationsClient.updateWorkstationConfigCallable().futureCall(request);
           // Do something.
           Operation response = future.get();
         }
         
      • deleteWorkstationConfigAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationConfig,​OperationMetadata> deleteWorkstationConfigAsync​(WorkstationConfigName name)
        Deletes the specified workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationConfigName name =
               WorkstationConfigName.of(
                   "[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]", "[WORKSTATION_CONFIG]");
           WorkstationConfig response = workstationsClient.deleteWorkstationConfigAsync(name).get();
         }
         
        Parameters:
        name - Required. Name of the workstation configuration to delete.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • deleteWorkstationConfigAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationConfig,​OperationMetadata> deleteWorkstationConfigAsync​(String name)
        Deletes the specified workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String name =
               WorkstationConfigName.of(
                       "[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]", "[WORKSTATION_CONFIG]")
                   .toString();
           WorkstationConfig response = workstationsClient.deleteWorkstationConfigAsync(name).get();
         }
         
        Parameters:
        name - Required. Name of the workstation configuration to delete.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • deleteWorkstationConfigAsync

        public final com.google.api.gax.longrunning.OperationFuture<WorkstationConfig,​OperationMetadata> deleteWorkstationConfigAsync​(DeleteWorkstationConfigRequest request)
        Deletes the specified workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           DeleteWorkstationConfigRequest request =
               DeleteWorkstationConfigRequest.newBuilder()
                   .setName(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .setForce(true)
                   .build();
           WorkstationConfig response = workstationsClient.deleteWorkstationConfigAsync(request).get();
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • deleteWorkstationConfigOperationCallable

        public final com.google.api.gax.rpc.OperationCallable<DeleteWorkstationConfigRequest,​WorkstationConfig,​OperationMetadata> deleteWorkstationConfigOperationCallable()
        Deletes the specified workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           DeleteWorkstationConfigRequest request =
               DeleteWorkstationConfigRequest.newBuilder()
                   .setName(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .setForce(true)
                   .build();
           OperationFuture<WorkstationConfig, OperationMetadata> future =
               workstationsClient.deleteWorkstationConfigOperationCallable().futureCall(request);
           // Do something.
           WorkstationConfig response = future.get();
         }
         
      • deleteWorkstationConfigCallable

        public final com.google.api.gax.rpc.UnaryCallable<DeleteWorkstationConfigRequest,​com.google.longrunning.Operation> deleteWorkstationConfigCallable()
        Deletes the specified workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           DeleteWorkstationConfigRequest request =
               DeleteWorkstationConfigRequest.newBuilder()
                   .setName(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .setForce(true)
                   .build();
           ApiFuture<Operation> future =
               workstationsClient.deleteWorkstationConfigCallable().futureCall(request);
           // Do something.
           Operation response = future.get();
         }
         
      • getWorkstation

        public final Workstation getWorkstation​(WorkstationName name)
        Returns the requested workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationName name =
               WorkstationName.of(
                   "[PROJECT]",
                   "[LOCATION]",
                   "[WORKSTATION_CLUSTER]",
                   "[WORKSTATION_CONFIG]",
                   "[WORKSTATION]");
           Workstation response = workstationsClient.getWorkstation(name);
         }
         
        Parameters:
        name - Required. Name of the requested resource.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • getWorkstation

        public final Workstation getWorkstation​(String name)
        Returns the requested workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String name =
               WorkstationName.of(
                       "[PROJECT]",
                       "[LOCATION]",
                       "[WORKSTATION_CLUSTER]",
                       "[WORKSTATION_CONFIG]",
                       "[WORKSTATION]")
                   .toString();
           Workstation response = workstationsClient.getWorkstation(name);
         }
         
        Parameters:
        name - Required. Name of the requested resource.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • getWorkstation

        public final Workstation getWorkstation​(GetWorkstationRequest request)
        Returns the requested workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           GetWorkstationRequest request =
               GetWorkstationRequest.newBuilder()
                   .setName(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .build();
           Workstation response = workstationsClient.getWorkstation(request);
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • getWorkstationCallable

        public final com.google.api.gax.rpc.UnaryCallable<GetWorkstationRequest,​Workstation> getWorkstationCallable()
        Returns the requested workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           GetWorkstationRequest request =
               GetWorkstationRequest.newBuilder()
                   .setName(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .build();
           ApiFuture<Workstation> future =
               workstationsClient.getWorkstationCallable().futureCall(request);
           // Do something.
           Workstation response = future.get();
         }
         
      • listWorkstations

        public final WorkstationsClient.ListWorkstationsPagedResponse listWorkstations​(WorkstationConfigName parent)
        Returns all Workstations using the specified workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationConfigName parent =
               WorkstationConfigName.of(
                   "[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]", "[WORKSTATION_CONFIG]");
           for (Workstation element : workstationsClient.listWorkstations(parent).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        parent - Required. Parent resource name.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listWorkstations

        public final WorkstationsClient.ListWorkstationsPagedResponse listWorkstations​(String parent)
        Returns all Workstations using the specified workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String parent =
               WorkstationConfigName.of(
                       "[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]", "[WORKSTATION_CONFIG]")
                   .toString();
           for (Workstation element : workstationsClient.listWorkstations(parent).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        parent - Required. Parent resource name.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listWorkstations

        public final WorkstationsClient.ListWorkstationsPagedResponse listWorkstations​(ListWorkstationsRequest request)
        Returns all Workstations using the specified workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListWorkstationsRequest request =
               ListWorkstationsRequest.newBuilder()
                   .setParent(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           for (Workstation element : workstationsClient.listWorkstations(request).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listWorkstationsPagedCallable

        public final com.google.api.gax.rpc.UnaryCallable<ListWorkstationsRequest,​WorkstationsClient.ListWorkstationsPagedResponse> listWorkstationsPagedCallable()
        Returns all Workstations using the specified workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListWorkstationsRequest request =
               ListWorkstationsRequest.newBuilder()
                   .setParent(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           ApiFuture<Workstation> future =
               workstationsClient.listWorkstationsPagedCallable().futureCall(request);
           // Do something.
           for (Workstation element : future.get().iterateAll()) {
             // doThingsWith(element);
           }
         }
         
      • listWorkstationsCallable

        public final com.google.api.gax.rpc.UnaryCallable<ListWorkstationsRequest,​ListWorkstationsResponse> listWorkstationsCallable()
        Returns all Workstations using the specified workstation configuration.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListWorkstationsRequest request =
               ListWorkstationsRequest.newBuilder()
                   .setParent(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           while (true) {
             ListWorkstationsResponse response =
                 workstationsClient.listWorkstationsCallable().call(request);
             for (Workstation element : response.getWorkstationsList()) {
               // doThingsWith(element);
             }
             String nextPageToken = response.getNextPageToken();
             if (!Strings.isNullOrEmpty(nextPageToken)) {
               request = request.toBuilder().setPageToken(nextPageToken).build();
             } else {
               break;
             }
           }
         }
         
      • listUsableWorkstations

        public final WorkstationsClient.ListUsableWorkstationsPagedResponse listUsableWorkstations​(WorkstationConfigName parent)
        Returns all workstations using the specified workstation configuration on which the caller has the "workstations.workstations.use" permission.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationConfigName parent =
               WorkstationConfigName.of(
                   "[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]", "[WORKSTATION_CONFIG]");
           for (Workstation element : workstationsClient.listUsableWorkstations(parent).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        parent - Required. Parent resource name.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listUsableWorkstations

        public final WorkstationsClient.ListUsableWorkstationsPagedResponse listUsableWorkstations​(String parent)
        Returns all workstations using the specified workstation configuration on which the caller has the "workstations.workstations.use" permission.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String parent =
               WorkstationConfigName.of(
                       "[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]", "[WORKSTATION_CONFIG]")
                   .toString();
           for (Workstation element : workstationsClient.listUsableWorkstations(parent).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        parent - Required. Parent resource name.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listUsableWorkstations

        public final WorkstationsClient.ListUsableWorkstationsPagedResponse listUsableWorkstations​(ListUsableWorkstationsRequest request)
        Returns all workstations using the specified workstation configuration on which the caller has the "workstations.workstations.use" permission.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListUsableWorkstationsRequest request =
               ListUsableWorkstationsRequest.newBuilder()
                   .setParent(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           for (Workstation element : workstationsClient.listUsableWorkstations(request).iterateAll()) {
             // doThingsWith(element);
           }
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • listUsableWorkstationsPagedCallable

        public final com.google.api.gax.rpc.UnaryCallable<ListUsableWorkstationsRequest,​WorkstationsClient.ListUsableWorkstationsPagedResponse> listUsableWorkstationsPagedCallable()
        Returns all workstations using the specified workstation configuration on which the caller has the "workstations.workstations.use" permission.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListUsableWorkstationsRequest request =
               ListUsableWorkstationsRequest.newBuilder()
                   .setParent(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           ApiFuture<Workstation> future =
               workstationsClient.listUsableWorkstationsPagedCallable().futureCall(request);
           // Do something.
           for (Workstation element : future.get().iterateAll()) {
             // doThingsWith(element);
           }
         }
         
      • listUsableWorkstationsCallable

        public final com.google.api.gax.rpc.UnaryCallable<ListUsableWorkstationsRequest,​ListUsableWorkstationsResponse> listUsableWorkstationsCallable()
        Returns all workstations using the specified workstation configuration on which the caller has the "workstations.workstations.use" permission.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           ListUsableWorkstationsRequest request =
               ListUsableWorkstationsRequest.newBuilder()
                   .setParent(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setPageSize(883849137)
                   .setPageToken("pageToken873572522")
                   .build();
           while (true) {
             ListUsableWorkstationsResponse response =
                 workstationsClient.listUsableWorkstationsCallable().call(request);
             for (Workstation element : response.getWorkstationsList()) {
               // doThingsWith(element);
             }
             String nextPageToken = response.getNextPageToken();
             if (!Strings.isNullOrEmpty(nextPageToken)) {
               request = request.toBuilder().setPageToken(nextPageToken).build();
             } else {
               break;
             }
           }
         }
         
      • createWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> createWorkstationAsync​(WorkstationConfigName parent,
                                                                                                                                Workstation workstation,
                                                                                                                                String workstationId)
        Creates a new workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationConfigName parent =
               WorkstationConfigName.of(
                   "[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]", "[WORKSTATION_CONFIG]");
           Workstation workstation = Workstation.newBuilder().build();
           String workstationId = "workstationId560540030";
           Workstation response =
               workstationsClient.createWorkstationAsync(parent, workstation, workstationId).get();
         }
         
        Parameters:
        parent - Required. Parent resource name.
        workstation - Required. Workstation to create.
        workstationId - Required. ID to use for the workstation.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • createWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> createWorkstationAsync​(String parent,
                                                                                                                                Workstation workstation,
                                                                                                                                String workstationId)
        Creates a new workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String parent =
               WorkstationConfigName.of(
                       "[PROJECT]", "[LOCATION]", "[WORKSTATION_CLUSTER]", "[WORKSTATION_CONFIG]")
                   .toString();
           Workstation workstation = Workstation.newBuilder().build();
           String workstationId = "workstationId560540030";
           Workstation response =
               workstationsClient.createWorkstationAsync(parent, workstation, workstationId).get();
         }
         
        Parameters:
        parent - Required. Parent resource name.
        workstation - Required. Workstation to create.
        workstationId - Required. ID to use for the workstation.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • createWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> createWorkstationAsync​(CreateWorkstationRequest request)
        Creates a new workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           CreateWorkstationRequest request =
               CreateWorkstationRequest.newBuilder()
                   .setParent(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setWorkstationId("workstationId560540030")
                   .setWorkstation(Workstation.newBuilder().build())
                   .setValidateOnly(true)
                   .build();
           Workstation response = workstationsClient.createWorkstationAsync(request).get();
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • createWorkstationOperationCallable

        public final com.google.api.gax.rpc.OperationCallable<CreateWorkstationRequest,​Workstation,​OperationMetadata> createWorkstationOperationCallable()
        Creates a new workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           CreateWorkstationRequest request =
               CreateWorkstationRequest.newBuilder()
                   .setParent(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setWorkstationId("workstationId560540030")
                   .setWorkstation(Workstation.newBuilder().build())
                   .setValidateOnly(true)
                   .build();
           OperationFuture<Workstation, OperationMetadata> future =
               workstationsClient.createWorkstationOperationCallable().futureCall(request);
           // Do something.
           Workstation response = future.get();
         }
         
      • createWorkstationCallable

        public final com.google.api.gax.rpc.UnaryCallable<CreateWorkstationRequest,​com.google.longrunning.Operation> createWorkstationCallable()
        Creates a new workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           CreateWorkstationRequest request =
               CreateWorkstationRequest.newBuilder()
                   .setParent(
                       WorkstationConfigName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]")
                           .toString())
                   .setWorkstationId("workstationId560540030")
                   .setWorkstation(Workstation.newBuilder().build())
                   .setValidateOnly(true)
                   .build();
           ApiFuture<Operation> future =
               workstationsClient.createWorkstationCallable().futureCall(request);
           // Do something.
           Operation response = future.get();
         }
         
      • updateWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> updateWorkstationAsync​(Workstation workstation,
                                                                                                                                com.google.protobuf.FieldMask updateMask)
        Updates an existing workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           Workstation workstation = Workstation.newBuilder().build();
           FieldMask updateMask = FieldMask.newBuilder().build();
           Workstation response =
               workstationsClient.updateWorkstationAsync(workstation, updateMask).get();
         }
         
        Parameters:
        workstation - Required. Workstation to update.
        updateMask - Required. Mask specifying which fields in the workstation configuration should be updated.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • updateWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> updateWorkstationAsync​(UpdateWorkstationRequest request)
        Updates an existing workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           UpdateWorkstationRequest request =
               UpdateWorkstationRequest.newBuilder()
                   .setWorkstation(Workstation.newBuilder().build())
                   .setUpdateMask(FieldMask.newBuilder().build())
                   .setValidateOnly(true)
                   .setAllowMissing(true)
                   .build();
           Workstation response = workstationsClient.updateWorkstationAsync(request).get();
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • updateWorkstationOperationCallable

        public final com.google.api.gax.rpc.OperationCallable<UpdateWorkstationRequest,​Workstation,​OperationMetadata> updateWorkstationOperationCallable()
        Updates an existing workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           UpdateWorkstationRequest request =
               UpdateWorkstationRequest.newBuilder()
                   .setWorkstation(Workstation.newBuilder().build())
                   .setUpdateMask(FieldMask.newBuilder().build())
                   .setValidateOnly(true)
                   .setAllowMissing(true)
                   .build();
           OperationFuture<Workstation, OperationMetadata> future =
               workstationsClient.updateWorkstationOperationCallable().futureCall(request);
           // Do something.
           Workstation response = future.get();
         }
         
      • updateWorkstationCallable

        public final com.google.api.gax.rpc.UnaryCallable<UpdateWorkstationRequest,​com.google.longrunning.Operation> updateWorkstationCallable()
        Updates an existing workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           UpdateWorkstationRequest request =
               UpdateWorkstationRequest.newBuilder()
                   .setWorkstation(Workstation.newBuilder().build())
                   .setUpdateMask(FieldMask.newBuilder().build())
                   .setValidateOnly(true)
                   .setAllowMissing(true)
                   .build();
           ApiFuture<Operation> future =
               workstationsClient.updateWorkstationCallable().futureCall(request);
           // Do something.
           Operation response = future.get();
         }
         
      • deleteWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> deleteWorkstationAsync​(WorkstationName name)
        Deletes the specified workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationName name =
               WorkstationName.of(
                   "[PROJECT]",
                   "[LOCATION]",
                   "[WORKSTATION_CLUSTER]",
                   "[WORKSTATION_CONFIG]",
                   "[WORKSTATION]");
           Workstation response = workstationsClient.deleteWorkstationAsync(name).get();
         }
         
        Parameters:
        name - Required. Name of the workstation to delete.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • deleteWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> deleteWorkstationAsync​(String name)
        Deletes the specified workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String name =
               WorkstationName.of(
                       "[PROJECT]",
                       "[LOCATION]",
                       "[WORKSTATION_CLUSTER]",
                       "[WORKSTATION_CONFIG]",
                       "[WORKSTATION]")
                   .toString();
           Workstation response = workstationsClient.deleteWorkstationAsync(name).get();
         }
         
        Parameters:
        name - Required. Name of the workstation to delete.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • deleteWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> deleteWorkstationAsync​(DeleteWorkstationRequest request)
        Deletes the specified workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           DeleteWorkstationRequest request =
               DeleteWorkstationRequest.newBuilder()
                   .setName(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .build();
           Workstation response = workstationsClient.deleteWorkstationAsync(request).get();
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • deleteWorkstationOperationCallable

        public final com.google.api.gax.rpc.OperationCallable<DeleteWorkstationRequest,​Workstation,​OperationMetadata> deleteWorkstationOperationCallable()
        Deletes the specified workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           DeleteWorkstationRequest request =
               DeleteWorkstationRequest.newBuilder()
                   .setName(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .build();
           OperationFuture<Workstation, OperationMetadata> future =
               workstationsClient.deleteWorkstationOperationCallable().futureCall(request);
           // Do something.
           Workstation response = future.get();
         }
         
      • deleteWorkstationCallable

        public final com.google.api.gax.rpc.UnaryCallable<DeleteWorkstationRequest,​com.google.longrunning.Operation> deleteWorkstationCallable()
        Deletes the specified workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           DeleteWorkstationRequest request =
               DeleteWorkstationRequest.newBuilder()
                   .setName(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .build();
           ApiFuture<Operation> future =
               workstationsClient.deleteWorkstationCallable().futureCall(request);
           // Do something.
           Operation response = future.get();
         }
         
      • startWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> startWorkstationAsync​(WorkstationName name)
        Starts running a workstation so that users can connect to it.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationName name =
               WorkstationName.of(
                   "[PROJECT]",
                   "[LOCATION]",
                   "[WORKSTATION_CLUSTER]",
                   "[WORKSTATION_CONFIG]",
                   "[WORKSTATION]");
           Workstation response = workstationsClient.startWorkstationAsync(name).get();
         }
         
        Parameters:
        name - Required. Name of the workstation to start.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • startWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> startWorkstationAsync​(String name)
        Starts running a workstation so that users can connect to it.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String name =
               WorkstationName.of(
                       "[PROJECT]",
                       "[LOCATION]",
                       "[WORKSTATION_CLUSTER]",
                       "[WORKSTATION_CONFIG]",
                       "[WORKSTATION]")
                   .toString();
           Workstation response = workstationsClient.startWorkstationAsync(name).get();
         }
         
        Parameters:
        name - Required. Name of the workstation to start.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • startWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> startWorkstationAsync​(StartWorkstationRequest request)
        Starts running a workstation so that users can connect to it.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           StartWorkstationRequest request =
               StartWorkstationRequest.newBuilder()
                   .setName(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .build();
           Workstation response = workstationsClient.startWorkstationAsync(request).get();
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • startWorkstationOperationCallable

        public final com.google.api.gax.rpc.OperationCallable<StartWorkstationRequest,​Workstation,​OperationMetadata> startWorkstationOperationCallable()
        Starts running a workstation so that users can connect to it.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           StartWorkstationRequest request =
               StartWorkstationRequest.newBuilder()
                   .setName(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .build();
           OperationFuture<Workstation, OperationMetadata> future =
               workstationsClient.startWorkstationOperationCallable().futureCall(request);
           // Do something.
           Workstation response = future.get();
         }
         
      • startWorkstationCallable

        public final com.google.api.gax.rpc.UnaryCallable<StartWorkstationRequest,​com.google.longrunning.Operation> startWorkstationCallable()
        Starts running a workstation so that users can connect to it.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           StartWorkstationRequest request =
               StartWorkstationRequest.newBuilder()
                   .setName(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .build();
           ApiFuture<Operation> future =
               workstationsClient.startWorkstationCallable().futureCall(request);
           // Do something.
           Operation response = future.get();
         }
         
      • stopWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> stopWorkstationAsync​(WorkstationName name)
        Stops running a workstation, reducing costs.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationName name =
               WorkstationName.of(
                   "[PROJECT]",
                   "[LOCATION]",
                   "[WORKSTATION_CLUSTER]",
                   "[WORKSTATION_CONFIG]",
                   "[WORKSTATION]");
           Workstation response = workstationsClient.stopWorkstationAsync(name).get();
         }
         
        Parameters:
        name - Required. Name of the workstation to stop.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • stopWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> stopWorkstationAsync​(String name)
        Stops running a workstation, reducing costs.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String name =
               WorkstationName.of(
                       "[PROJECT]",
                       "[LOCATION]",
                       "[WORKSTATION_CLUSTER]",
                       "[WORKSTATION_CONFIG]",
                       "[WORKSTATION]")
                   .toString();
           Workstation response = workstationsClient.stopWorkstationAsync(name).get();
         }
         
        Parameters:
        name - Required. Name of the workstation to stop.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • stopWorkstationAsync

        public final com.google.api.gax.longrunning.OperationFuture<Workstation,​OperationMetadata> stopWorkstationAsync​(StopWorkstationRequest request)
        Stops running a workstation, reducing costs.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           StopWorkstationRequest request =
               StopWorkstationRequest.newBuilder()
                   .setName(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .build();
           Workstation response = workstationsClient.stopWorkstationAsync(request).get();
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • stopWorkstationOperationCallable

        public final com.google.api.gax.rpc.OperationCallable<StopWorkstationRequest,​Workstation,​OperationMetadata> stopWorkstationOperationCallable()
        Stops running a workstation, reducing costs.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           StopWorkstationRequest request =
               StopWorkstationRequest.newBuilder()
                   .setName(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .build();
           OperationFuture<Workstation, OperationMetadata> future =
               workstationsClient.stopWorkstationOperationCallable().futureCall(request);
           // Do something.
           Workstation response = future.get();
         }
         
      • stopWorkstationCallable

        public final com.google.api.gax.rpc.UnaryCallable<StopWorkstationRequest,​com.google.longrunning.Operation> stopWorkstationCallable()
        Stops running a workstation, reducing costs.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           StopWorkstationRequest request =
               StopWorkstationRequest.newBuilder()
                   .setName(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setValidateOnly(true)
                   .setEtag("etag3123477")
                   .build();
           ApiFuture<Operation> future =
               workstationsClient.stopWorkstationCallable().futureCall(request);
           // Do something.
           Operation response = future.get();
         }
         
      • generateAccessToken

        public final GenerateAccessTokenResponse generateAccessToken​(WorkstationName workstation)
        Returns a short-lived credential that can be used to send authenticated and authorized traffic to a workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           WorkstationName workstation =
               WorkstationName.of(
                   "[PROJECT]",
                   "[LOCATION]",
                   "[WORKSTATION_CLUSTER]",
                   "[WORKSTATION_CONFIG]",
                   "[WORKSTATION]");
           GenerateAccessTokenResponse response = workstationsClient.generateAccessToken(workstation);
         }
         
        Parameters:
        workstation - Required. Name of the workstation for which the access token should be generated.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • generateAccessToken

        public final GenerateAccessTokenResponse generateAccessToken​(String workstation)
        Returns a short-lived credential that can be used to send authenticated and authorized traffic to a workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           String workstation =
               WorkstationName.of(
                       "[PROJECT]",
                       "[LOCATION]",
                       "[WORKSTATION_CLUSTER]",
                       "[WORKSTATION_CONFIG]",
                       "[WORKSTATION]")
                   .toString();
           GenerateAccessTokenResponse response = workstationsClient.generateAccessToken(workstation);
         }
         
        Parameters:
        workstation - Required. Name of the workstation for which the access token should be generated.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • generateAccessToken

        public final GenerateAccessTokenResponse generateAccessToken​(GenerateAccessTokenRequest request)
        Returns a short-lived credential that can be used to send authenticated and authorized traffic to a workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           GenerateAccessTokenRequest request =
               GenerateAccessTokenRequest.newBuilder()
                   .setWorkstation(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .build();
           GenerateAccessTokenResponse response = workstationsClient.generateAccessToken(request);
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • generateAccessTokenCallable

        public final com.google.api.gax.rpc.UnaryCallable<GenerateAccessTokenRequest,​GenerateAccessTokenResponse> generateAccessTokenCallable()
        Returns a short-lived credential that can be used to send authenticated and authorized traffic to a workstation.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           GenerateAccessTokenRequest request =
               GenerateAccessTokenRequest.newBuilder()
                   .setWorkstation(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .build();
           ApiFuture<GenerateAccessTokenResponse> future =
               workstationsClient.generateAccessTokenCallable().futureCall(request);
           // Do something.
           GenerateAccessTokenResponse response = future.get();
         }
         
      • setIamPolicy

        public final com.google.iam.v1.Policy setIamPolicy​(com.google.iam.v1.SetIamPolicyRequest request)
        Sets the access control policy on the specified resource. Replacesany existing policy.

        Can return `NOT_FOUND`, `INVALID_ARGUMENT`, and `PERMISSION_DENIED`errors.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           SetIamPolicyRequest request =
               SetIamPolicyRequest.newBuilder()
                   .setResource(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setPolicy(Policy.newBuilder().build())
                   .setUpdateMask(FieldMask.newBuilder().build())
                   .build();
           Policy response = workstationsClient.setIamPolicy(request);
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • setIamPolicyCallable

        public final com.google.api.gax.rpc.UnaryCallable<com.google.iam.v1.SetIamPolicyRequest,​com.google.iam.v1.Policy> setIamPolicyCallable()
        Sets the access control policy on the specified resource. Replacesany existing policy.

        Can return `NOT_FOUND`, `INVALID_ARGUMENT`, and `PERMISSION_DENIED`errors.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           SetIamPolicyRequest request =
               SetIamPolicyRequest.newBuilder()
                   .setResource(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setPolicy(Policy.newBuilder().build())
                   .setUpdateMask(FieldMask.newBuilder().build())
                   .build();
           ApiFuture<Policy> future = workstationsClient.setIamPolicyCallable().futureCall(request);
           // Do something.
           Policy response = future.get();
         }
         
      • getIamPolicy

        public final com.google.iam.v1.Policy getIamPolicy​(com.google.iam.v1.GetIamPolicyRequest request)
        Gets the access control policy for a resource. Returns an empty policyif the resource exists and does not have a policy set.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           GetIamPolicyRequest request =
               GetIamPolicyRequest.newBuilder()
                   .setResource(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setOptions(GetPolicyOptions.newBuilder().build())
                   .build();
           Policy response = workstationsClient.getIamPolicy(request);
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • getIamPolicyCallable

        public final com.google.api.gax.rpc.UnaryCallable<com.google.iam.v1.GetIamPolicyRequest,​com.google.iam.v1.Policy> getIamPolicyCallable()
        Gets the access control policy for a resource. Returns an empty policyif the resource exists and does not have a policy set.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           GetIamPolicyRequest request =
               GetIamPolicyRequest.newBuilder()
                   .setResource(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .setOptions(GetPolicyOptions.newBuilder().build())
                   .build();
           ApiFuture<Policy> future = workstationsClient.getIamPolicyCallable().futureCall(request);
           // Do something.
           Policy response = future.get();
         }
         
      • testIamPermissions

        public final com.google.iam.v1.TestIamPermissionsResponse testIamPermissions​(com.google.iam.v1.TestIamPermissionsRequest request)
        Returns permissions that a caller has on the specified resource. If theresource does not exist, this will return an empty set ofpermissions, not a `NOT_FOUND` error.

        Note: This operation is designed to be used for buildingpermission-aware UIs and command-line tools, not for authorizationchecking. This operation may "fail open" without warning.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           TestIamPermissionsRequest request =
               TestIamPermissionsRequest.newBuilder()
                   .setResource(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .addAllPermissions(new ArrayList<String>())
                   .build();
           TestIamPermissionsResponse response = workstationsClient.testIamPermissions(request);
         }
         
        Parameters:
        request - The request object containing all of the parameters for the API call.
        Throws:
        com.google.api.gax.rpc.ApiException - if the remote call fails
      • testIamPermissionsCallable

        public final com.google.api.gax.rpc.UnaryCallable<com.google.iam.v1.TestIamPermissionsRequest,​com.google.iam.v1.TestIamPermissionsResponse> testIamPermissionsCallable()
        Returns permissions that a caller has on the specified resource. If theresource does not exist, this will return an empty set ofpermissions, not a `NOT_FOUND` error.

        Note: This operation is designed to be used for buildingpermission-aware UIs and command-line tools, not for authorizationchecking. This operation may "fail open" without warning.

        Sample code:

        
         // 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://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
         try (WorkstationsClient workstationsClient = WorkstationsClient.create()) {
           TestIamPermissionsRequest request =
               TestIamPermissionsRequest.newBuilder()
                   .setResource(
                       WorkstationName.of(
                               "[PROJECT]",
                               "[LOCATION]",
                               "[WORKSTATION_CLUSTER]",
                               "[WORKSTATION_CONFIG]",
                               "[WORKSTATION]")
                           .toString())
                   .addAllPermissions(new ArrayList<String>())
                   .build();
           ApiFuture<TestIamPermissionsResponse> future =
               workstationsClient.testIamPermissionsCallable().futureCall(request);
           // Do something.
           TestIamPermissionsResponse response = future.get();
         }
         
      • shutdown

        public void shutdown()
        Specified by:
        shutdown in interface com.google.api.gax.core.BackgroundResource
      • isShutdown

        public boolean isShutdown()
        Specified by:
        isShutdown in interface com.google.api.gax.core.BackgroundResource
      • isTerminated

        public boolean isTerminated()
        Specified by:
        isTerminated in interface com.google.api.gax.core.BackgroundResource
      • shutdownNow

        public void shutdownNow()
        Specified by:
        shutdownNow in interface com.google.api.gax.core.BackgroundResource