Class CompanyServiceClient

public class CompanyServiceClient implements BackgroundResource

Service Description: A service that handles company management, including CRUD and enumeration.

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:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   TenantName parent = TenantName.of("[PROJECT]", "[TENANT]");
   Company company = Company.newBuilder().build();
   Company response = companyServiceClient.createCompany(parent, company);
 }
 

Note: close() needs to be called on the CompanyServiceClient 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 CompanyServiceSettings to create(). For example:

To customize credentials:


 CompanyServiceSettings companyServiceSettings =
     CompanyServiceSettings.newBuilder()
         .setCredentialsProvider(FixedCredentialsProvider.create(myCredentials))
         .build();
 CompanyServiceClient companyServiceClient = CompanyServiceClient.create(companyServiceSettings);
 

To customize the endpoint:


 CompanyServiceSettings companyServiceSettings =
     CompanyServiceSettings.newBuilder().setEndpoint(myEndpoint).build();
 CompanyServiceClient companyServiceClient = CompanyServiceClient.create(companyServiceSettings);
 

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

Inheritance

java.lang.Object > CompanyServiceClient

Implements

BackgroundResource

Static Methods

create()

public static final CompanyServiceClient create()

Constructs an instance of CompanyServiceClient with default settings.

Returns
TypeDescription
CompanyServiceClient
Exceptions
TypeDescription
IOException

create(CompanyServiceSettings settings)

public static final CompanyServiceClient create(CompanyServiceSettings settings)

Constructs an instance of CompanyServiceClient, using the given settings. The channels are created based on the settings passed in, or defaults for any settings that are not set.

Parameter
NameDescription
settingsCompanyServiceSettings
Returns
TypeDescription
CompanyServiceClient
Exceptions
TypeDescription
IOException

create(CompanyServiceStub stub)

public static final CompanyServiceClient create(CompanyServiceStub stub)

Constructs an instance of CompanyServiceClient, using the given stub for making calls. This is for advanced usage - prefer using create(CompanyServiceSettings).

Parameter
NameDescription
stubCompanyServiceStub
Returns
TypeDescription
CompanyServiceClient

Constructors

CompanyServiceClient(CompanyServiceSettings settings)

protected CompanyServiceClient(CompanyServiceSettings settings)

Constructs an instance of CompanyServiceClient, 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.

Parameter
NameDescription
settingsCompanyServiceSettings

CompanyServiceClient(CompanyServiceStub stub)

protected CompanyServiceClient(CompanyServiceStub stub)
Parameter
NameDescription
stubCompanyServiceStub

Methods

awaitTermination(long duration, TimeUnit unit)

public boolean awaitTermination(long duration, TimeUnit unit)
Parameters
NameDescription
durationlong
unitTimeUnit
Returns
TypeDescription
boolean
Exceptions
TypeDescription
InterruptedException

close()

public final void close()

createCompany(CreateCompanyRequest request)

public final Company createCompany(CreateCompanyRequest request)

Creates a new company entity.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   CreateCompanyRequest request =
       CreateCompanyRequest.newBuilder()
           .setParent(TenantName.of("[PROJECT]", "[TENANT]").toString())
           .setCompany(Company.newBuilder().build())
           .build();
   Company response = companyServiceClient.createCompany(request);
 }
 
Parameter
NameDescription
requestCreateCompanyRequest

The request object containing all of the parameters for the API call.

Returns
TypeDescription
Company

createCompany(TenantName parent, Company company)

public final Company createCompany(TenantName parent, Company company)

Creates a new company entity.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   TenantName parent = TenantName.of("[PROJECT]", "[TENANT]");
   Company company = Company.newBuilder().build();
   Company response = companyServiceClient.createCompany(parent, company);
 }
 
Parameters
NameDescription
parentTenantName

Required. Resource name of the tenant under which the company is created.

The format is "projects/{project_id}/tenants/{tenant_id}", for example, "projects/foo/tenants/bar".

companyCompany

Required. The company to be created.

Returns
TypeDescription
Company

createCompany(String parent, Company company)

public final Company createCompany(String parent, Company company)

Creates a new company entity.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   String parent = TenantName.of("[PROJECT]", "[TENANT]").toString();
   Company company = Company.newBuilder().build();
   Company response = companyServiceClient.createCompany(parent, company);
 }
 
Parameters
NameDescription
parentString

Required. Resource name of the tenant under which the company is created.

The format is "projects/{project_id}/tenants/{tenant_id}", for example, "projects/foo/tenants/bar".

companyCompany

Required. The company to be created.

Returns
TypeDescription
Company

createCompanyCallable()

public final UnaryCallable<CreateCompanyRequest,Company> createCompanyCallable()

Creates a new company entity.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   CreateCompanyRequest request =
       CreateCompanyRequest.newBuilder()
           .setParent(TenantName.of("[PROJECT]", "[TENANT]").toString())
           .setCompany(Company.newBuilder().build())
           .build();
   ApiFuture<Company> future = companyServiceClient.createCompanyCallable().futureCall(request);
   // Do something.
   Company response = future.get();
 }
 
Returns
TypeDescription
UnaryCallable<CreateCompanyRequest,Company>

deleteCompany(CompanyName name)

public final void deleteCompany(CompanyName name)

Deletes specified company. Prerequisite: The company has no jobs associated with it.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   CompanyName name = CompanyName.of("[PROJECT]", "[TENANT]", "[COMPANY]");
   companyServiceClient.deleteCompany(name);
 }
 
Parameter
NameDescription
nameCompanyName

Required. The resource name of the company to be deleted.

The format is "projects/{project_id}/tenants/{tenant_id}/companies/{company_id}", for example, "projects/foo/tenants/bar/companies/baz".

deleteCompany(DeleteCompanyRequest request)

public final void deleteCompany(DeleteCompanyRequest request)

Deletes specified company. Prerequisite: The company has no jobs associated with it.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   DeleteCompanyRequest request =
       DeleteCompanyRequest.newBuilder()
           .setName(CompanyName.of("[PROJECT]", "[TENANT]", "[COMPANY]").toString())
           .build();
   companyServiceClient.deleteCompany(request);
 }
 
Parameter
NameDescription
requestDeleteCompanyRequest

The request object containing all of the parameters for the API call.

deleteCompany(String name)

public final void deleteCompany(String name)

Deletes specified company. Prerequisite: The company has no jobs associated with it.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   String name = CompanyName.of("[PROJECT]", "[TENANT]", "[COMPANY]").toString();
   companyServiceClient.deleteCompany(name);
 }
 
Parameter
NameDescription
nameString

Required. The resource name of the company to be deleted.

The format is "projects/{project_id}/tenants/{tenant_id}/companies/{company_id}", for example, "projects/foo/tenants/bar/companies/baz".

deleteCompanyCallable()

public final UnaryCallable<DeleteCompanyRequest,Empty> deleteCompanyCallable()

Deletes specified company. Prerequisite: The company has no jobs associated with it.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   DeleteCompanyRequest request =
       DeleteCompanyRequest.newBuilder()
           .setName(CompanyName.of("[PROJECT]", "[TENANT]", "[COMPANY]").toString())
           .build();
   ApiFuture<Empty> future = companyServiceClient.deleteCompanyCallable().futureCall(request);
   // Do something.
   future.get();
 }
 
Returns
TypeDescription
UnaryCallable<DeleteCompanyRequest,Empty>

getCompany(CompanyName name)

public final Company getCompany(CompanyName name)

Retrieves specified company.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   CompanyName name = CompanyName.of("[PROJECT]", "[TENANT]", "[COMPANY]");
   Company response = companyServiceClient.getCompany(name);
 }
 
Parameter
NameDescription
nameCompanyName

Required. The resource name of the company to be retrieved.

The format is "projects/{project_id}/tenants/{tenant_id}/companies/{company_id}", for example, "projects/api-test-project/tenants/foo/companies/bar".

Returns
TypeDescription
Company

getCompany(GetCompanyRequest request)

public final Company getCompany(GetCompanyRequest request)

Retrieves specified company.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   GetCompanyRequest request =
       GetCompanyRequest.newBuilder()
           .setName(CompanyName.of("[PROJECT]", "[TENANT]", "[COMPANY]").toString())
           .build();
   Company response = companyServiceClient.getCompany(request);
 }
 
Parameter
NameDescription
requestGetCompanyRequest

The request object containing all of the parameters for the API call.

Returns
TypeDescription
Company

getCompany(String name)

public final Company getCompany(String name)

Retrieves specified company.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   String name = CompanyName.of("[PROJECT]", "[TENANT]", "[COMPANY]").toString();
   Company response = companyServiceClient.getCompany(name);
 }
 
Parameter
NameDescription
nameString

Required. The resource name of the company to be retrieved.

The format is "projects/{project_id}/tenants/{tenant_id}/companies/{company_id}", for example, "projects/api-test-project/tenants/foo/companies/bar".

Returns
TypeDescription
Company

getCompanyCallable()

public final UnaryCallable<GetCompanyRequest,Company> getCompanyCallable()

Retrieves specified company.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   GetCompanyRequest request =
       GetCompanyRequest.newBuilder()
           .setName(CompanyName.of("[PROJECT]", "[TENANT]", "[COMPANY]").toString())
           .build();
   ApiFuture<Company> future = companyServiceClient.getCompanyCallable().futureCall(request);
   // Do something.
   Company response = future.get();
 }
 
Returns
TypeDescription
UnaryCallable<GetCompanyRequest,Company>

getSettings()

public final CompanyServiceSettings getSettings()
Returns
TypeDescription
CompanyServiceSettings

getStub()

public CompanyServiceStub getStub()
Returns
TypeDescription
CompanyServiceStub

isShutdown()

public boolean isShutdown()
Returns
TypeDescription
boolean

isTerminated()

public boolean isTerminated()
Returns
TypeDescription
boolean

listCompanies(ListCompaniesRequest request)

public final CompanyServiceClient.ListCompaniesPagedResponse listCompanies(ListCompaniesRequest request)

Lists all companies associated with the project.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   ListCompaniesRequest request =
       ListCompaniesRequest.newBuilder()
           .setParent(TenantName.of("[PROJECT]", "[TENANT]").toString())
           .setPageToken("pageToken873572522")
           .setPageSize(883849137)
           .setRequireOpenJobs(true)
           .build();
   for (Company element : companyServiceClient.listCompanies(request).iterateAll()) {
     // doThingsWith(element);
   }
 }
 
Parameter
NameDescription
requestListCompaniesRequest

The request object containing all of the parameters for the API call.

Returns
TypeDescription
CompanyServiceClient.ListCompaniesPagedResponse

listCompanies(TenantName parent)

public final CompanyServiceClient.ListCompaniesPagedResponse listCompanies(TenantName parent)

Lists all companies associated with the project.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   TenantName parent = TenantName.of("[PROJECT]", "[TENANT]");
   for (Company element : companyServiceClient.listCompanies(parent).iterateAll()) {
     // doThingsWith(element);
   }
 }
 
Parameter
NameDescription
parentTenantName

Required. Resource name of the tenant under which the company is created.

The format is "projects/{project_id}/tenants/{tenant_id}", for example, "projects/foo/tenants/bar".

Returns
TypeDescription
CompanyServiceClient.ListCompaniesPagedResponse

listCompanies(String parent)

public final CompanyServiceClient.ListCompaniesPagedResponse listCompanies(String parent)

Lists all companies associated with the project.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   String parent = TenantName.of("[PROJECT]", "[TENANT]").toString();
   for (Company element : companyServiceClient.listCompanies(parent).iterateAll()) {
     // doThingsWith(element);
   }
 }
 
Parameter
NameDescription
parentString

Required. Resource name of the tenant under which the company is created.

The format is "projects/{project_id}/tenants/{tenant_id}", for example, "projects/foo/tenants/bar".

Returns
TypeDescription
CompanyServiceClient.ListCompaniesPagedResponse

listCompaniesCallable()

public final UnaryCallable<ListCompaniesRequest,ListCompaniesResponse> listCompaniesCallable()

Lists all companies associated with the project.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   ListCompaniesRequest request =
       ListCompaniesRequest.newBuilder()
           .setParent(TenantName.of("[PROJECT]", "[TENANT]").toString())
           .setPageToken("pageToken873572522")
           .setPageSize(883849137)
           .setRequireOpenJobs(true)
           .build();
   while (true) {
     ListCompaniesResponse response = companyServiceClient.listCompaniesCallable().call(request);
     for (Company element : response.getResponsesList()) {
       // doThingsWith(element);
     }
     String nextPageToken = response.getNextPageToken();
     if (!Strings.isNullOrEmpty(nextPageToken)) {
       request = request.toBuilder().setPageToken(nextPageToken).build();
     } else {
       break;
     }
   }
 }
 
Returns
TypeDescription
UnaryCallable<ListCompaniesRequest,ListCompaniesResponse>

listCompaniesPagedCallable()

public final UnaryCallable<ListCompaniesRequest,CompanyServiceClient.ListCompaniesPagedResponse> listCompaniesPagedCallable()

Lists all companies associated with the project.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   ListCompaniesRequest request =
       ListCompaniesRequest.newBuilder()
           .setParent(TenantName.of("[PROJECT]", "[TENANT]").toString())
           .setPageToken("pageToken873572522")
           .setPageSize(883849137)
           .setRequireOpenJobs(true)
           .build();
   ApiFuture<Company> future =
       companyServiceClient.listCompaniesPagedCallable().futureCall(request);
   // Do something.
   for (Company element : future.get().iterateAll()) {
     // doThingsWith(element);
   }
 }
 
Returns
TypeDescription
UnaryCallable<ListCompaniesRequest,ListCompaniesPagedResponse>

shutdown()

public void shutdown()

shutdownNow()

public void shutdownNow()

updateCompany(Company company, FieldMask updateMask)

public final Company updateCompany(Company company, FieldMask updateMask)

Updates specified company.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   Company company = Company.newBuilder().build();
   FieldMask updateMask = FieldMask.newBuilder().build();
   Company response = companyServiceClient.updateCompany(company, updateMask);
 }
 
Parameters
NameDescription
companyCompany

Required. The company resource to replace the current resource in the system.

updateMaskFieldMask

Strongly recommended for the best service experience.

If update_mask is provided, only the specified fields in company are updated. Otherwise all the fields are updated.

A field mask to specify the company fields to be updated. Only top level fields of Company are supported.

Returns
TypeDescription
Company

updateCompany(UpdateCompanyRequest request)

public final Company updateCompany(UpdateCompanyRequest request)

Updates specified company.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   UpdateCompanyRequest request =
       UpdateCompanyRequest.newBuilder()
           .setCompany(Company.newBuilder().build())
           .setUpdateMask(FieldMask.newBuilder().build())
           .build();
   Company response = companyServiceClient.updateCompany(request);
 }
 
Parameter
NameDescription
requestUpdateCompanyRequest

The request object containing all of the parameters for the API call.

Returns
TypeDescription
Company

updateCompanyCallable()

public final UnaryCallable<UpdateCompanyRequest,Company> updateCompanyCallable()

Updates specified company.

Sample code:


 try (CompanyServiceClient companyServiceClient = CompanyServiceClient.create()) {
   UpdateCompanyRequest request =
       UpdateCompanyRequest.newBuilder()
           .setCompany(Company.newBuilder().build())
           .setUpdateMask(FieldMask.newBuilder().build())
           .build();
   ApiFuture<Company> future = companyServiceClient.updateCompanyCallable().futureCall(request);
   // Do something.
   Company response = future.get();
 }
 
Returns
TypeDescription
UnaryCallable<UpdateCompanyRequest,Company>