summaryrefslogtreecommitdiff
path: root/third_party/googleapis/google/cloud/talent/v4/job_service.proto
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/googleapis/google/cloud/talent/v4/job_service.proto')
-rw-r--r--third_party/googleapis/google/cloud/talent/v4/job_service.proto940
1 files changed, 940 insertions, 0 deletions
diff --git a/third_party/googleapis/google/cloud/talent/v4/job_service.proto b/third_party/googleapis/google/cloud/talent/v4/job_service.proto
new file mode 100644
index 0000000..b17751d
--- /dev/null
+++ b/third_party/googleapis/google/cloud/talent/v4/job_service.proto
@@ -0,0 +1,940 @@
+// Copyright 2022 Google LLC
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+syntax = "proto3";
+
+package google.cloud.talent.v4;
+
+import "google/api/annotations.proto";
+import "google/api/client.proto";
+import "google/api/field_behavior.proto";
+import "google/api/resource.proto";
+import "google/cloud/talent/v4/common.proto";
+import "google/cloud/talent/v4/filters.proto";
+import "google/cloud/talent/v4/histogram.proto";
+import "google/cloud/talent/v4/job.proto";
+import "google/longrunning/operations.proto";
+import "google/protobuf/duration.proto";
+import "google/protobuf/empty.proto";
+import "google/protobuf/field_mask.proto";
+import "google/rpc/status.proto";
+
+option go_package = "google.golang.org/genproto/googleapis/cloud/talent/v4;talent";
+option java_multiple_files = true;
+option java_outer_classname = "JobServiceProto";
+option java_package = "com.google.cloud.talent.v4";
+option objc_class_prefix = "CTS";
+
+// A service handles job management, including job CRUD, enumeration and search.
+service JobService {
+ option (google.api.default_host) = "jobs.googleapis.com";
+ option (google.api.oauth_scopes) =
+ "https://www.googleapis.com/auth/cloud-platform,"
+ "https://www.googleapis.com/auth/jobs";
+
+ // Creates a new job.
+ //
+ // Typically, the job becomes searchable within 10 seconds, but it may take
+ // up to 5 minutes.
+ rpc CreateJob(CreateJobRequest) returns (Job) {
+ option (google.api.http) = {
+ post: "/v4/{parent=projects/*/tenants/*}/jobs"
+ body: "job"
+ };
+ option (google.api.method_signature) = "parent,job";
+ }
+
+ // Begins executing a batch create jobs operation.
+ rpc BatchCreateJobs(BatchCreateJobsRequest) returns (google.longrunning.Operation) {
+ option (google.api.http) = {
+ post: "/v4/{parent=projects/*/tenants/*}/jobs:batchCreate"
+ body: "*"
+ };
+ option (google.api.method_signature) = "parent,jobs";
+ option (google.longrunning.operation_info) = {
+ response_type: "BatchCreateJobsResponse"
+ metadata_type: "BatchOperationMetadata"
+ };
+ }
+
+ // Retrieves the specified job, whose status is OPEN or recently EXPIRED
+ // within the last 90 days.
+ rpc GetJob(GetJobRequest) returns (Job) {
+ option (google.api.http) = {
+ get: "/v4/{name=projects/*/tenants/*/jobs/*}"
+ };
+ option (google.api.method_signature) = "name";
+ }
+
+ // Updates specified job.
+ //
+ // Typically, updated contents become visible in search results within 10
+ // seconds, but it may take up to 5 minutes.
+ rpc UpdateJob(UpdateJobRequest) returns (Job) {
+ option (google.api.http) = {
+ patch: "/v4/{job.name=projects/*/tenants/*/jobs/*}"
+ body: "job"
+ };
+ option (google.api.method_signature) = "job,update_mask";
+ }
+
+ // Begins executing a batch update jobs operation.
+ rpc BatchUpdateJobs(BatchUpdateJobsRequest) returns (google.longrunning.Operation) {
+ option (google.api.http) = {
+ post: "/v4/{parent=projects/*/tenants/*}/jobs:batchUpdate"
+ body: "*"
+ };
+ option (google.api.method_signature) = "parent,jobs";
+ option (google.longrunning.operation_info) = {
+ response_type: "BatchUpdateJobsResponse"
+ metadata_type: "BatchOperationMetadata"
+ };
+ }
+
+ // Deletes the specified job.
+ //
+ // Typically, the job becomes unsearchable within 10 seconds, but it may take
+ // up to 5 minutes.
+ rpc DeleteJob(DeleteJobRequest) returns (google.protobuf.Empty) {
+ option (google.api.http) = {
+ delete: "/v4/{name=projects/*/tenants/*/jobs/*}"
+ };
+ option (google.api.method_signature) = "name";
+ }
+
+ // Begins executing a batch delete jobs operation.
+ rpc BatchDeleteJobs(BatchDeleteJobsRequest) returns (google.longrunning.Operation) {
+ option (google.api.http) = {
+ post: "/v4/{parent=projects/*/tenants/*}/jobs:batchDelete"
+ body: "*"
+ };
+ option (google.api.method_signature) = "parent,names";
+ option (google.longrunning.operation_info) = {
+ response_type: "BatchDeleteJobsResponse"
+ metadata_type: "BatchOperationMetadata"
+ };
+ }
+
+ // Lists jobs by filter.
+ rpc ListJobs(ListJobsRequest) returns (ListJobsResponse) {
+ option (google.api.http) = {
+ get: "/v4/{parent=projects/*/tenants/*}/jobs"
+ };
+ option (google.api.method_signature) = "parent,filter";
+ }
+
+ // Searches for jobs using the provided [SearchJobsRequest][google.cloud.talent.v4.SearchJobsRequest].
+ //
+ // This call constrains the [visibility][google.cloud.talent.v4.Job.visibility] of jobs
+ // present in the database, and only returns jobs that the caller has
+ // permission to search against.
+ rpc SearchJobs(SearchJobsRequest) returns (SearchJobsResponse) {
+ option (google.api.http) = {
+ post: "/v4/{parent=projects/*/tenants/*}/jobs:search"
+ body: "*"
+ };
+ }
+
+ // Searches for jobs using the provided [SearchJobsRequest][google.cloud.talent.v4.SearchJobsRequest].
+ //
+ // This API call is intended for the use case of targeting passive job
+ // seekers (for example, job seekers who have signed up to receive email
+ // alerts about potential job opportunities), it has different algorithmic
+ // adjustments that are designed to specifically target passive job seekers.
+ //
+ // This call constrains the [visibility][google.cloud.talent.v4.Job.visibility] of jobs
+ // present in the database, and only returns jobs the caller has
+ // permission to search against.
+ rpc SearchJobsForAlert(SearchJobsRequest) returns (SearchJobsResponse) {
+ option (google.api.http) = {
+ post: "/v4/{parent=projects/*/tenants/*}/jobs:searchForAlert"
+ body: "*"
+ };
+ }
+}
+
+// Create job request.
+message CreateJobRequest {
+ // Required. The resource name of the tenant under which the job is created.
+ //
+ // The format is "projects/{project_id}/tenants/{tenant_id}". For example,
+ // "projects/foo/tenants/bar".
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ child_type: "jobs.googleapis.com/Job"
+ }
+ ];
+
+ // Required. The Job to be created.
+ Job job = 2 [(google.api.field_behavior) = REQUIRED];
+}
+
+// Get job request.
+message GetJobRequest {
+ // Required. The resource name of the job to retrieve.
+ //
+ // The format is
+ // "projects/{project_id}/tenants/{tenant_id}/jobs/{job_id}". For
+ // example, "projects/foo/tenants/bar/jobs/baz".
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "jobs.googleapis.com/Job"
+ }
+ ];
+}
+
+// Update job request.
+message UpdateJobRequest {
+ // Required. The Job to be updated.
+ Job job = 1 [(google.api.field_behavior) = REQUIRED];
+
+ // Strongly recommended for the best service experience.
+ //
+ // If [update_mask][google.cloud.talent.v4.UpdateJobRequest.update_mask] is provided, only the specified fields in
+ // [job][google.cloud.talent.v4.UpdateJobRequest.job] are updated. Otherwise all the fields are updated.
+ //
+ // A field mask to restrict the fields that are updated. Only
+ // top level fields of [Job][google.cloud.talent.v4.Job] are supported.
+ google.protobuf.FieldMask update_mask = 2;
+}
+
+// Delete job request.
+message DeleteJobRequest {
+ // Required. The resource name of the job to be deleted.
+ //
+ // The format is
+ // "projects/{project_id}/tenants/{tenant_id}/jobs/{job_id}". For
+ // example, "projects/foo/tenants/bar/jobs/baz".
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "jobs.googleapis.com/Job"
+ }
+ ];
+}
+
+// An enum that specifies the job attributes that are returned in the
+// [MatchingJob.job][google.cloud.talent.v4.SearchJobsResponse.MatchingJob.job] or
+// [ListJobsResponse.jobs][google.cloud.talent.v4.ListJobsResponse.jobs] fields.
+enum JobView {
+ // Default value.
+ JOB_VIEW_UNSPECIFIED = 0;
+
+ // A ID only view of job, with following attributes:
+ // [Job.name][google.cloud.talent.v4.Job.name], [Job.requisition_id][google.cloud.talent.v4.Job.requisition_id], [Job.language_code][google.cloud.talent.v4.Job.language_code].
+ JOB_VIEW_ID_ONLY = 1;
+
+ // A minimal view of the job, with the following attributes:
+ // [Job.name][google.cloud.talent.v4.Job.name], [Job.requisition_id][google.cloud.talent.v4.Job.requisition_id], [Job.title][google.cloud.talent.v4.Job.title],
+ // [Job.company][google.cloud.talent.v4.Job.company], [Job.DerivedInfo.locations][google.cloud.talent.v4.Job.DerivedInfo.locations], [Job.language_code][google.cloud.talent.v4.Job.language_code].
+ JOB_VIEW_MINIMAL = 2;
+
+ // A small view of the job, with the following attributes in the search
+ // results: [Job.name][google.cloud.talent.v4.Job.name], [Job.requisition_id][google.cloud.talent.v4.Job.requisition_id], [Job.title][google.cloud.talent.v4.Job.title],
+ // [Job.company][google.cloud.talent.v4.Job.company], [Job.DerivedInfo.locations][google.cloud.talent.v4.Job.DerivedInfo.locations], [Job.visibility][google.cloud.talent.v4.Job.visibility],
+ // [Job.language_code][google.cloud.talent.v4.Job.language_code], [Job.description][google.cloud.talent.v4.Job.description].
+ JOB_VIEW_SMALL = 3;
+
+ // All available attributes are included in the search results.
+ JOB_VIEW_FULL = 4;
+}
+
+// List jobs request.
+message ListJobsRequest {
+ // Required. The resource name of the tenant under which the job is created.
+ //
+ // The format is "projects/{project_id}/tenants/{tenant_id}". For example,
+ // "projects/foo/tenants/bar".
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ child_type: "jobs.googleapis.com/Job"
+ }
+ ];
+
+ // Required. The filter string specifies the jobs to be enumerated.
+ //
+ // Supported operator: =, AND
+ //
+ // The fields eligible for filtering are:
+ //
+ // * `companyName`
+ // * `requisitionId`
+ // * `status` Available values: OPEN, EXPIRED, ALL. Defaults to
+ // OPEN if no value is specified.
+ //
+ // At least one of `companyName` and `requisitionId` must present or an
+ // INVALID_ARGUMENT error is thrown.
+ //
+ // Sample Query:
+ //
+ // * companyName = "projects/foo/tenants/bar/companies/baz"
+ // * companyName = "projects/foo/tenants/bar/companies/baz" AND
+ // requisitionId = "req-1"
+ // * companyName = "projects/foo/tenants/bar/companies/baz" AND
+ // status = "EXPIRED"
+ // * requisitionId = "req-1"
+ // * requisitionId = "req-1" AND status = "EXPIRED"
+ string filter = 2 [(google.api.field_behavior) = REQUIRED];
+
+ // The starting point of a query result.
+ string page_token = 3;
+
+ // The maximum number of jobs to be returned per page of results.
+ //
+ // If [job_view][google.cloud.talent.v4.ListJobsRequest.job_view] is set to [JobView.JOB_VIEW_ID_ONLY][google.cloud.talent.v4.JobView.JOB_VIEW_ID_ONLY], the maximum allowed
+ // page size is 1000. Otherwise, the maximum allowed page size is 100.
+ //
+ // Default is 100 if empty or a number < 1 is specified.
+ int32 page_size = 4;
+
+ // The desired job attributes returned for jobs in the
+ // search response. Defaults to [JobView.JOB_VIEW_FULL][google.cloud.talent.v4.JobView.JOB_VIEW_FULL] if no value is
+ // specified.
+ JobView job_view = 5;
+}
+
+// List jobs response.
+message ListJobsResponse {
+ // The Jobs for a given company.
+ //
+ // The maximum number of items returned is based on the limit field
+ // provided in the request.
+ repeated Job jobs = 1;
+
+ // A token to retrieve the next page of results.
+ string next_page_token = 2;
+
+ // Additional information for the API invocation, such as the request
+ // tracking id.
+ ResponseMetadata metadata = 3;
+}
+
+// The Request body of the `SearchJobs` call.
+message SearchJobsRequest {
+ // A string-represented enumeration of the job search mode. The service
+ // operate differently for different modes of service.
+ enum SearchMode {
+ // The mode of the search method isn't specified. The default search
+ // behavior is identical to JOB_SEARCH search behavior.
+ SEARCH_MODE_UNSPECIFIED = 0;
+
+ // The job search matches against all jobs, and featured jobs
+ // (jobs with promotionValue > 0) are not specially handled.
+ JOB_SEARCH = 1;
+
+ // The job search matches only against featured jobs (jobs with a
+ // promotionValue > 0). This method doesn't return any jobs having a
+ // promotionValue <= 0. The search results order is determined by the
+ // promotionValue (jobs with a higher promotionValue are returned higher up
+ // in the search results), with relevance being used as a tiebreaker.
+ FEATURED_JOB_SEARCH = 2;
+ }
+
+ // Controls whether highly similar jobs are returned next to each other in
+ // the search results. Jobs are identified as highly similar based on
+ // their titles, job categories, and locations. Highly similar results are
+ // clustered so that only one representative job of the cluster is
+ // displayed to the job seeker higher up in the results, with the other jobs
+ // being displayed lower down in the results.
+ //
+ // If you are using pageToken to page through the result set,
+ // latency might be lower but we can't guarantee that all results are
+ // returned. If you are using page offset, latency might be higher but all
+ // results are returned.
+ enum DiversificationLevel {
+ // The diversification level isn't specified.
+ DIVERSIFICATION_LEVEL_UNSPECIFIED = 0;
+
+ // Disables diversification. Jobs that would normally be pushed to the last
+ // page would not have their positions altered. This may result in highly
+ // similar jobs appearing in sequence in the search results.
+ DISABLED = 1;
+
+ // Default diversifying behavior. The result list is ordered so that
+ // highly similar results are pushed to the end of the last page of search
+ // results.
+ SIMPLE = 2;
+
+ // Only one job from the same company will be shown at once, other jobs
+ // under same company are pushed to the end of the last page of search
+ // result.
+ ONE_PER_COMPANY = 3;
+
+ // Similar to ONE_PER_COMPANY, but it allows at most two jobs in the
+ // same company to be shown at once, the other jobs under same company are
+ // pushed to the end of the last page of search result.
+ TWO_PER_COMPANY = 4;
+
+ // The result list is ordered such that somewhat similar results are pushed
+ // to the end of the last page of the search results. This option is
+ // recommended if SIMPLE diversification does not diversify enough.
+ DIVERSIFY_BY_LOOSER_SIMILARITY = 5;
+ }
+
+ // Controls what keyword matching behavior the search has. When keyword
+ // matching is enabled, a keyword match returns jobs that may not match given
+ // category filters when there are matching keywords. For example, for the
+ // query "program manager" with KeywordMatchMode set to KEYWORD_MATCH_ALL, a
+ // job posting with the title "software developer," which doesn't fall into
+ // "program manager" ontology, and "program manager" appearing in its
+ // description will be surfaced.
+ //
+ // For queries like "cloud" that don't contain title or
+ // location specific ontology, jobs with "cloud" keyword matches are returned
+ // regardless of this enum's value.
+ //
+ // Use [Company.keyword_searchable_job_custom_attributes][google.cloud.talent.v4.Company.keyword_searchable_job_custom_attributes] if
+ // company-specific globally matched custom field/attribute string values are
+ // needed. Enabling keyword match improves recall of subsequent search
+ // requests.
+ enum KeywordMatchMode {
+ // The keyword match option isn't specified. Defaults to
+ // [KeywordMatchMode.KEYWORD_MATCH_ALL][google.cloud.talent.v4.SearchJobsRequest.KeywordMatchMode.KEYWORD_MATCH_ALL] behavior.
+ KEYWORD_MATCH_MODE_UNSPECIFIED = 0;
+
+ // Disables keyword matching.
+ KEYWORD_MATCH_DISABLED = 1;
+
+ // Enable keyword matching over [Job.title][google.cloud.talent.v4.Job.title],
+ // [Job.description][google.cloud.talent.v4.Job.description], [Job.company_display_name][google.cloud.talent.v4.Job.company_display_name], [Job.addresses][google.cloud.talent.v4.Job.addresses],
+ // [Job.qualifications][google.cloud.talent.v4.Job.qualifications], and keyword searchable [Job.custom_attributes][google.cloud.talent.v4.Job.custom_attributes]
+ // fields.
+ KEYWORD_MATCH_ALL = 2;
+
+ // Only enable keyword matching over [Job.title][google.cloud.talent.v4.Job.title].
+ KEYWORD_MATCH_TITLE_ONLY = 3;
+ }
+
+ // Custom ranking information for [SearchJobsRequest][google.cloud.talent.v4.SearchJobsRequest].
+ message CustomRankingInfo {
+ // The importance level for [CustomRankingInfo.ranking_expression][google.cloud.talent.v4.SearchJobsRequest.CustomRankingInfo.ranking_expression].
+ enum ImportanceLevel {
+ // Default value if the importance level isn't specified.
+ IMPORTANCE_LEVEL_UNSPECIFIED = 0;
+
+ // The given ranking expression is of None importance, existing relevance
+ // score (determined by API algorithm) dominates job's final ranking
+ // position.
+ NONE = 1;
+
+ // The given ranking expression is of Low importance in terms of job's
+ // final ranking position compared to existing relevance
+ // score (determined by API algorithm).
+ LOW = 2;
+
+ // The given ranking expression is of Mild importance in terms of job's
+ // final ranking position compared to existing relevance
+ // score (determined by API algorithm).
+ MILD = 3;
+
+ // The given ranking expression is of Medium importance in terms of job's
+ // final ranking position compared to existing relevance
+ // score (determined by API algorithm).
+ MEDIUM = 4;
+
+ // The given ranking expression is of High importance in terms of job's
+ // final ranking position compared to existing relevance
+ // score (determined by API algorithm).
+ HIGH = 5;
+
+ // The given ranking expression is of Extreme importance, and dominates
+ // job's final ranking position with existing relevance
+ // score (determined by API algorithm) ignored.
+ EXTREME = 6;
+ }
+
+ // Required. Controls over how important the score of
+ // [CustomRankingInfo.ranking_expression][google.cloud.talent.v4.SearchJobsRequest.CustomRankingInfo.ranking_expression] gets applied to job's final
+ // ranking position.
+ //
+ // An error is thrown if not specified.
+ ImportanceLevel importance_level = 1 [(google.api.field_behavior) = REQUIRED];
+
+ // Required. Controls over how job documents get ranked on top of existing relevance
+ // score (determined by API algorithm). A combination of the ranking
+ // expression and relevance score is used to determine job's final ranking
+ // position.
+ //
+ // The syntax for this expression is a subset of Google SQL syntax.
+ //
+ // Supported operators are: +, -, *, /, where the left and right side of
+ // the operator is either a numeric [Job.custom_attributes][google.cloud.talent.v4.Job.custom_attributes] key,
+ // integer/double value or an expression that can be evaluated to a number.
+ //
+ // Parenthesis are supported to adjust calculation precedence. The
+ // expression must be < 200 characters in length.
+ //
+ // The expression is considered invalid for a job if the expression
+ // references custom attributes that are not populated on the job or if the
+ // expression results in a divide by zero. If an expression is invalid for a
+ // job, that job is demoted to the end of the results.
+ //
+ // Sample ranking expression
+ // (year + 25) * 0.25 - (freshness / 0.5)
+ string ranking_expression = 2 [(google.api.field_behavior) = REQUIRED];
+ }
+
+ // Required. The resource name of the tenant to search within.
+ //
+ // The format is "projects/{project_id}/tenants/{tenant_id}". For example,
+ // "projects/foo/tenants/bar".
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ child_type: "jobs.googleapis.com/Job"
+ }
+ ];
+
+ // Mode of a search.
+ //
+ // Defaults to [SearchMode.JOB_SEARCH][google.cloud.talent.v4.SearchJobsRequest.SearchMode.JOB_SEARCH].
+ SearchMode search_mode = 2;
+
+ // Required. The meta information collected about the job searcher, used to improve the
+ // search quality of the service. The identifiers (such as `user_id`) are
+ // provided by users, and must be unique and consistent.
+ RequestMetadata request_metadata = 3 [(google.api.field_behavior) = REQUIRED];
+
+ // Query used to search against jobs, such as keyword, location filters, etc.
+ JobQuery job_query = 4;
+
+ // Controls whether to broaden the search when it produces sparse results.
+ // Broadened queries append results to the end of the matching results
+ // list.
+ //
+ // Defaults to false.
+ bool enable_broadening = 5;
+
+ // An expression specifies a histogram request against matching jobs.
+ //
+ // Expression syntax is an aggregation function call with histogram facets and
+ // other options.
+ //
+ // Available aggregation function calls are:
+ // * `count(string_histogram_facet)`: Count the number of matching entities,
+ // for each distinct attribute value.
+ // * `count(numeric_histogram_facet, list of buckets)`: Count the number of
+ // matching entities within each bucket.
+ //
+ // A maximum of 200 histogram buckets are supported.
+ //
+ // Data types:
+ //
+ // * Histogram facet: facet names with format `[a-zA-Z][a-zA-Z0-9_]+`.
+ // * String: string like "any string with backslash escape for quote(\")."
+ // * Number: whole number and floating point number like 10, -1 and -0.01.
+ // * List: list of elements with comma(,) separator surrounded by square
+ // brackets, for example, [1, 2, 3] and ["one", "two", "three"].
+ //
+ // Built-in constants:
+ //
+ // * MIN (minimum number similar to java Double.MIN_VALUE)
+ // * MAX (maximum number similar to java Double.MAX_VALUE)
+ //
+ // Built-in functions:
+ //
+ // * bucket(start, end[, label]): bucket built-in function creates a bucket
+ // with range of [start, end). Note that the end is exclusive, for example,
+ // bucket(1, MAX, "positive number") or bucket(1, 10).
+ //
+ // Job histogram facets:
+ //
+ // * company_display_name: histogram by [Job.company_display_name][google.cloud.talent.v4.Job.company_display_name].
+ // * employment_type: histogram by [Job.employment_types][google.cloud.talent.v4.Job.employment_types], for example,
+ // "FULL_TIME", "PART_TIME".
+ // * company_size: histogram by [CompanySize][google.cloud.talent.v4.CompanySize], for example, "SMALL",
+ // "MEDIUM", "BIG".
+ // * publish_time_in_day: histogram by the [Job.posting_publish_time][google.cloud.talent.v4.Job.posting_publish_time]
+ // in days.
+ // Must specify list of numeric buckets in spec.
+ // * publish_time_in_month: histogram by the [Job.posting_publish_time][google.cloud.talent.v4.Job.posting_publish_time]
+ // in months.
+ // Must specify list of numeric buckets in spec.
+ // * publish_time_in_year: histogram by the [Job.posting_publish_time][google.cloud.talent.v4.Job.posting_publish_time]
+ // in years.
+ // Must specify list of numeric buckets in spec.
+ // * degree_types: histogram by the [Job.degree_types][google.cloud.talent.v4.Job.degree_types], for example,
+ // "Bachelors", "Masters".
+ // * job_level: histogram by the [Job.job_level][google.cloud.talent.v4.Job.job_level], for example, "Entry
+ // Level".
+ // * country: histogram by the country code of jobs, for example, "US", "FR".
+ // * admin1: histogram by the admin1 code of jobs, which is a global
+ // placeholder referring to the state, province, or the particular term a
+ // country uses to define the geographic structure below the country level,
+ // for example, "CA", "IL".
+ // * city: histogram by a combination of the "city name, admin1 code". For
+ // example, "Mountain View, CA", "New York, NY".
+ // * admin1_country: histogram by a combination of the "admin1 code, country",
+ // for example, "CA, US", "IL, US".
+ // * city_coordinate: histogram by the city center's GPS coordinates (latitude
+ // and longitude), for example, 37.4038522,-122.0987765. Since the
+ // coordinates of a city center can change, customers may need to refresh
+ // them periodically.
+ // * locale: histogram by the [Job.language_code][google.cloud.talent.v4.Job.language_code], for example, "en-US",
+ // "fr-FR".
+ // * language: histogram by the language subtag of the [Job.language_code][google.cloud.talent.v4.Job.language_code],
+ // for example, "en", "fr".
+ // * category: histogram by the [JobCategory][google.cloud.talent.v4.JobCategory], for example,
+ // "COMPUTER_AND_IT", "HEALTHCARE".
+ // * base_compensation_unit: histogram by the
+ // [CompensationInfo.CompensationUnit][google.cloud.talent.v4.CompensationInfo.CompensationUnit] of base
+ // salary, for example, "WEEKLY", "MONTHLY".
+ // * base_compensation: histogram by the base salary. Must specify list of
+ // numeric buckets to group results by.
+ // * annualized_base_compensation: histogram by the base annualized salary.
+ // Must specify list of numeric buckets to group results by.
+ // * annualized_total_compensation: histogram by the total annualized salary.
+ // Must specify list of numeric buckets to group results by.
+ // * string_custom_attribute: histogram by string [Job.custom_attributes][google.cloud.talent.v4.Job.custom_attributes].
+ // Values can be accessed via square bracket notations like
+ // string_custom_attribute["key1"].
+ // * numeric_custom_attribute: histogram by numeric [Job.custom_attributes][google.cloud.talent.v4.Job.custom_attributes].
+ // Values can be accessed via square bracket notations like
+ // numeric_custom_attribute["key1"]. Must specify list of numeric buckets to
+ // group results by.
+ //
+ // Example expressions:
+ //
+ // * `count(admin1)`
+ // * `count(base_compensation, [bucket(1000, 10000), bucket(10000, 100000),
+ // bucket(100000, MAX)])`
+ // * `count(string_custom_attribute["some-string-custom-attribute"])`
+ // * `count(numeric_custom_attribute["some-numeric-custom-attribute"],
+ // [bucket(MIN, 0, "negative"), bucket(0, MAX, "non-negative")])`
+ repeated HistogramQuery histogram_queries = 7;
+
+ // The desired job attributes returned for jobs in the search response.
+ // Defaults to [JobView.JOB_VIEW_SMALL][google.cloud.talent.v4.JobView.JOB_VIEW_SMALL] if no value is specified.
+ JobView job_view = 8;
+
+ // An integer that specifies the current offset (that is, starting result
+ // location, amongst the jobs deemed by the API as relevant) in search
+ // results. This field is only considered if [page_token][google.cloud.talent.v4.SearchJobsRequest.page_token] is unset.
+ //
+ // The maximum allowed value is 5000. Otherwise an error is thrown.
+ //
+ // For example, 0 means to return results starting from the first matching
+ // job, and 10 means to return from the 11th job. This can be used for
+ // pagination, (for example, pageSize = 10 and offset = 10 means to return
+ // from the second page).
+ int32 offset = 9;
+
+ // A limit on the number of jobs returned in the search results.
+ // Increasing this value above the default value of 10 can increase search
+ // response time. The value can be between 1 and 100.
+ int32 max_page_size = 10;
+
+ // The token specifying the current offset within
+ // search results. See [SearchJobsResponse.next_page_token][google.cloud.talent.v4.SearchJobsResponse.next_page_token] for
+ // an explanation of how to obtain the next set of query results.
+ string page_token = 11;
+
+ // The criteria determining how search results are sorted. Default is
+ // `"relevance desc"`.
+ //
+ // Supported options are:
+ //
+ // * `"relevance desc"`: By relevance descending, as determined by the API
+ // algorithms. Relevance thresholding of query results is only available
+ // with this ordering.
+ // * `"posting_publish_time desc"`: By [Job.posting_publish_time][google.cloud.talent.v4.Job.posting_publish_time]
+ // descending.
+ // * `"posting_update_time desc"`: By [Job.posting_update_time][google.cloud.talent.v4.Job.posting_update_time]
+ // descending.
+ // * `"title"`: By [Job.title][google.cloud.talent.v4.Job.title] ascending.
+ // * `"title desc"`: By [Job.title][google.cloud.talent.v4.Job.title] descending.
+ // * `"annualized_base_compensation"`: By job's
+ // [CompensationInfo.annualized_base_compensation_range][google.cloud.talent.v4.CompensationInfo.annualized_base_compensation_range] ascending. Jobs
+ // whose annualized base compensation is unspecified are put at the end of
+ // search results.
+ // * `"annualized_base_compensation desc"`: By job's
+ // [CompensationInfo.annualized_base_compensation_range][google.cloud.talent.v4.CompensationInfo.annualized_base_compensation_range] descending. Jobs
+ // whose annualized base compensation is unspecified are put at the end of
+ // search results.
+ // * `"annualized_total_compensation"`: By job's
+ // [CompensationInfo.annualized_total_compensation_range][google.cloud.talent.v4.CompensationInfo.annualized_total_compensation_range] ascending. Jobs
+ // whose annualized base compensation is unspecified are put at the end of
+ // search results.
+ // * `"annualized_total_compensation desc"`: By job's
+ // [CompensationInfo.annualized_total_compensation_range][google.cloud.talent.v4.CompensationInfo.annualized_total_compensation_range] descending. Jobs
+ // whose annualized base compensation is unspecified are put at the end of
+ // search results.
+ // * `"custom_ranking desc"`: By the relevance score adjusted to the
+ // [SearchJobsRequest.CustomRankingInfo.ranking_expression][google.cloud.talent.v4.SearchJobsRequest.CustomRankingInfo.ranking_expression] with weight
+ // factor assigned by
+ // [SearchJobsRequest.CustomRankingInfo.importance_level][google.cloud.talent.v4.SearchJobsRequest.CustomRankingInfo.importance_level] in descending
+ // order.
+ // * Location sorting: Use the special syntax to order jobs by distance:<br>
+ // `"distance_from('Hawaii')"`: Order by distance from Hawaii.<br>
+ // `"distance_from(19.89, 155.5)"`: Order by distance from a coordinate.<br>
+ // `"distance_from('Hawaii'), distance_from('Puerto Rico')"`: Order by
+ // multiple locations. See details below.<br>
+ // `"distance_from('Hawaii'), distance_from(19.89, 155.5)"`: Order by
+ // multiple locations. See details below.<br>
+ // The string can have a maximum of 256 characters. When multiple distance
+ // centers are provided, a job that is close to any of the distance centers
+ // would have a high rank. When a job has multiple locations, the job
+ // location closest to one of the distance centers will be used. Jobs that
+ // don't have locations will be ranked at the bottom. Distance is calculated
+ // with a precision of 11.3 meters (37.4 feet). Diversification strategy is
+ // still applied unless explicitly disabled in
+ // [diversification_level][google.cloud.talent.v4.SearchJobsRequest.diversification_level].
+ string order_by = 12;
+
+ // Controls whether highly similar jobs are returned next to each other in
+ // the search results. Jobs are identified as highly similar based on
+ // their titles, job categories, and locations. Highly similar results are
+ // clustered so that only one representative job of the cluster is
+ // displayed to the job seeker higher up in the results, with the other jobs
+ // being displayed lower down in the results.
+ //
+ // Defaults to [DiversificationLevel.SIMPLE][google.cloud.talent.v4.SearchJobsRequest.DiversificationLevel.SIMPLE] if no value
+ // is specified.
+ DiversificationLevel diversification_level = 13;
+
+ // Controls over how job documents get ranked on top of existing relevance
+ // score (determined by API algorithm).
+ CustomRankingInfo custom_ranking_info = 14;
+
+ // This field is deprecated. Please use
+ // [SearchJobsRequest.keyword_match_mode][google.cloud.talent.v4.SearchJobsRequest.keyword_match_mode] going forward.
+ //
+ // To migrate, disable_keyword_match set to false maps to
+ // [KeywordMatchMode.KEYWORD_MATCH_ALL][google.cloud.talent.v4.SearchJobsRequest.KeywordMatchMode.KEYWORD_MATCH_ALL], and disable_keyword_match set to
+ // true maps to [KeywordMatchMode.KEYWORD_MATCH_DISABLED][google.cloud.talent.v4.SearchJobsRequest.KeywordMatchMode.KEYWORD_MATCH_DISABLED]. If
+ // [SearchJobsRequest.keyword_match_mode][google.cloud.talent.v4.SearchJobsRequest.keyword_match_mode] is set, this field is ignored.
+ //
+ // Controls whether to disable exact keyword match on [Job.title][google.cloud.talent.v4.Job.title],
+ // [Job.description][google.cloud.talent.v4.Job.description], [Job.company_display_name][google.cloud.talent.v4.Job.company_display_name], [Job.addresses][google.cloud.talent.v4.Job.addresses],
+ // [Job.qualifications][google.cloud.talent.v4.Job.qualifications]. When disable keyword match is turned off, a
+ // keyword match returns jobs that do not match given category filters when
+ // there are matching keywords. For example, for the query "program manager,"
+ // a result is returned even if the job posting has the title "software
+ // developer," which doesn't fall into "program manager" ontology, but does
+ // have "program manager" appearing in its description.
+ //
+ // For queries like "cloud" that don't contain title or
+ // location specific ontology, jobs with "cloud" keyword matches are returned
+ // regardless of this flag's value.
+ //
+ // Use [Company.keyword_searchable_job_custom_attributes][google.cloud.talent.v4.Company.keyword_searchable_job_custom_attributes] if
+ // company-specific globally matched custom field/attribute string values are
+ // needed. Enabling keyword match improves recall of subsequent search
+ // requests.
+ //
+ // Defaults to false.
+ bool disable_keyword_match = 16 [deprecated = true];
+
+ // Controls what keyword match options to use. If both keyword_match_mode and
+ // disable_keyword_match are set, keyword_match_mode will take precedence.
+ //
+ // Defaults to [KeywordMatchMode.KEYWORD_MATCH_ALL][google.cloud.talent.v4.SearchJobsRequest.KeywordMatchMode.KEYWORD_MATCH_ALL] if no value
+ // is specified.
+ KeywordMatchMode keyword_match_mode = 18;
+}
+
+// Response for SearchJob method.
+message SearchJobsResponse {
+ // Job entry with metadata inside [SearchJobsResponse][google.cloud.talent.v4.SearchJobsResponse].
+ message MatchingJob {
+ // Job resource that matches the specified [SearchJobsRequest][google.cloud.talent.v4.SearchJobsRequest].
+ Job job = 1;
+
+ // A summary of the job with core information that's displayed on the search
+ // results listing page.
+ string job_summary = 2;
+
+ // Contains snippets of text from the [Job.title][google.cloud.talent.v4.Job.title] field most
+ // closely matching a search query's keywords, if available. The matching
+ // query keywords are enclosed in HTML bold tags.
+ string job_title_snippet = 3;
+
+ // Contains snippets of text from the [Job.description][google.cloud.talent.v4.Job.description] and similar
+ // fields that most closely match a search query's keywords, if available.
+ // All HTML tags in the original fields are stripped when returned in this
+ // field, and matching query keywords are enclosed in HTML bold tags.
+ string search_text_snippet = 4;
+
+ // Commute information which is generated based on specified
+ // [CommuteFilter][google.cloud.talent.v4.CommuteFilter].
+ CommuteInfo commute_info = 5;
+ }
+
+ // Commute details related to this job.
+ message CommuteInfo {
+ // Location used as the destination in the commute calculation.
+ Location job_location = 1;
+
+ // The number of seconds required to travel to the job location from the
+ // query location. A duration of 0 seconds indicates that the job isn't
+ // reachable within the requested duration, but was returned as part of an
+ // expanded query.
+ google.protobuf.Duration travel_duration = 2;
+ }
+
+ // The Job entities that match the specified [SearchJobsRequest][google.cloud.talent.v4.SearchJobsRequest].
+ repeated MatchingJob matching_jobs = 1;
+
+ // The histogram results that match with specified
+ // [SearchJobsRequest.histogram_queries][google.cloud.talent.v4.SearchJobsRequest.histogram_queries].
+ repeated HistogramQueryResult histogram_query_results = 2;
+
+ // The token that specifies the starting position of the next page of results.
+ // This field is empty if there are no more results.
+ string next_page_token = 3;
+
+ // The location filters that the service applied to the specified query. If
+ // any filters are lat-lng based, the [Location.location_type][google.cloud.talent.v4.Location.location_type] is
+ // [Location.LocationType.LOCATION_TYPE_UNSPECIFIED][google.cloud.talent.v4.Location.LocationType.LOCATION_TYPE_UNSPECIFIED].
+ repeated Location location_filters = 4;
+
+ // Number of jobs that match the specified query.
+ //
+ // Note: This size is precise only if the total is less than 100,000.
+ int32 total_size = 6;
+
+ // Additional information for the API invocation, such as the request
+ // tracking id.
+ ResponseMetadata metadata = 7;
+
+ // If query broadening is enabled, we may append additional results from the
+ // broadened query. This number indicates how many of the jobs returned in the
+ // jobs field are from the broadened query. These results are always at the
+ // end of the jobs list. In particular, a value of 0, or if the field isn't
+ // set, all the jobs in the jobs list are from the original
+ // (without broadening) query. If this field is non-zero, subsequent requests
+ // with offset after this result set should contain all broadened results.
+ int32 broadened_query_jobs_count = 8;
+
+ // The spell checking result, and correction.
+ SpellingCorrection spell_correction = 9;
+}
+
+// Request to create a batch of jobs.
+message BatchCreateJobsRequest {
+ // Required. The resource name of the tenant under which the job is created.
+ //
+ // The format is "projects/{project_id}/tenants/{tenant_id}". For example,
+ // "projects/foo/tenants/bar".
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ child_type: "jobs.googleapis.com/Job"
+ }
+ ];
+
+ // Required. The jobs to be created.
+ // A maximum of 200 jobs can be created in a batch.
+ repeated Job jobs = 2 [(google.api.field_behavior) = REQUIRED];
+}
+
+// Request to update a batch of jobs.
+message BatchUpdateJobsRequest {
+ // Required. The resource name of the tenant under which the job is created.
+ //
+ // The format is "projects/{project_id}/tenants/{tenant_id}". For example,
+ // "projects/foo/tenants/bar".
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ child_type: "jobs.googleapis.com/Job"
+ }
+ ];
+
+ // Required. The jobs to be updated.
+ // A maximum of 200 jobs can be updated in a batch.
+ repeated Job jobs = 2 [(google.api.field_behavior) = REQUIRED];
+
+ // Strongly recommended for the best service experience. Be aware that it will
+ // also increase latency when checking the status of a batch operation.
+ //
+ // If [update_mask][google.cloud.talent.v4.BatchUpdateJobsRequest.update_mask] is provided, only the specified fields in
+ // [Job][google.cloud.talent.v4.Job] are updated. Otherwise all the fields are updated.
+ //
+ // A field mask to restrict the fields that are updated. Only
+ // top level fields of [Job][google.cloud.talent.v4.Job] are supported.
+ //
+ // If [update_mask][google.cloud.talent.v4.BatchUpdateJobsRequest.update_mask] is provided, The [Job][google.cloud.talent.v4.Job] inside
+ // [JobResult][JobOperationResult.JobResult]
+ // will only contains fields that is updated, plus the Id of the Job.
+ // Otherwise, [Job][google.cloud.talent.v4.Job] will include all fields, which can yield a very
+ // large response.
+ google.protobuf.FieldMask update_mask = 3;
+}
+
+// Request to delete a batch of jobs.
+message BatchDeleteJobsRequest {
+ // Required. The resource name of the tenant under which the job is created.
+ //
+ // The format is "projects/{project_id}/tenants/{tenant_id}". For example,
+ // "projects/foo/tenants/bar".
+ //
+ // The parent of all of the jobs specified in `names` must match this field.
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "jobs.googleapis.com/Tenant"
+ }
+ ];
+
+ // The names of the jobs to delete.
+ //
+ // The format is "projects/{project_id}/tenants/{tenant_id}/jobs/{job_id}".
+ // For example, "projects/foo/tenants/bar/jobs/baz".
+ //
+ // A maximum of 200 jobs can be deleted in a batch.
+ repeated string names = 2 [(google.api.resource_reference) = {
+ type: "jobs.googleapis.com/Job"
+ }];
+}
+
+// Mutation result of a job from a batch operation.
+message JobResult {
+ // Here [Job][google.cloud.talent.v4.Job] only contains basic information including [name][google.cloud.talent.v4.Job.name],
+ // [company][google.cloud.talent.v4.Job.company], [language_code][google.cloud.talent.v4.Job.language_code]
+ // and [requisition_id][google.cloud.talent.v4.Job.requisition_id], use getJob method to retrieve
+ // detailed information of the created/updated job.
+ Job job = 1;
+
+ // The status of the job processed. This field is populated if the
+ // processing of the [job][google.cloud.talent.v4.JobResult.job] fails.
+ google.rpc.Status status = 2;
+}
+
+// The result of [JobService.BatchCreateJobs][google.cloud.talent.v4.JobService.BatchCreateJobs]. It's used to
+// replace [google.longrunning.Operation.response][google.longrunning.Operation.response] in case of success.
+message BatchCreateJobsResponse {
+ // List of job mutation results from a batch create operation. It can change
+ // until operation status is FINISHED, FAILED or CANCELLED.
+ repeated JobResult job_results = 1;
+}
+
+// The result of [JobService.BatchUpdateJobs][google.cloud.talent.v4.JobService.BatchUpdateJobs]. It's used to
+// replace [google.longrunning.Operation.response][google.longrunning.Operation.response] in case of success.
+message BatchUpdateJobsResponse {
+ // List of job mutation results from a batch update operation. It can change
+ // until operation status is FINISHED, FAILED or CANCELLED.
+ repeated JobResult job_results = 1;
+}
+
+// The result of [JobService.BatchDeleteJobs][google.cloud.talent.v4.JobService.BatchDeleteJobs]. It's used to
+// replace [google.longrunning.Operation.response][google.longrunning.Operation.response] in case of success.
+message BatchDeleteJobsResponse {
+ // List of job mutation results from a batch delete operation. It can change
+ // until operation status is FINISHED, FAILED or CANCELLED.
+ repeated JobResult job_results = 1;
+}