You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
832 lines
33 KiB
832 lines
33 KiB
6 years ago
|
// Copyright 2019 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.v4beta1;
|
||
|
|
||
|
import "google/api/annotations.proto";
|
||
|
import "google/cloud/talent/v4beta1/common.proto";
|
||
|
import "google/cloud/talent/v4beta1/filters.proto";
|
||
|
import "google/cloud/talent/v4beta1/histogram.proto";
|
||
|
import "google/cloud/talent/v4beta1/job.proto";
|
||
|
import "google/longrunning/operations.proto";
|
||
|
import "google/protobuf/duration.proto";
|
||
|
import "google/protobuf/empty.proto";
|
||
|
import "google/protobuf/field_mask.proto";
|
||
|
|
||
|
option go_package = "google.golang.org/genproto/googleapis/cloud/talent/v4beta1;talent";
|
||
|
option java_multiple_files = true;
|
||
|
option java_outer_classname = "JobServiceProto";
|
||
|
option java_package = "com.google.cloud.talent.v4beta1";
|
||
|
option objc_class_prefix = "CTS";
|
||
|
|
||
|
// A service handles job management, including job CRUD, enumeration and search.
|
||
|
service JobService {
|
||
|
// 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: "/v4beta1/{parent=projects/*/tenants/*}/jobs"
|
||
|
body: "*"
|
||
|
additional_bindings {
|
||
|
post: "/v4beta1/{parent=projects/*}/jobs"
|
||
|
body: "*"
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
|
||
|
// 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: "/v4beta1/{name=projects/*/tenants/*/jobs/*}"
|
||
|
additional_bindings {
|
||
|
get: "/v4beta1/{name=projects/*/jobs/*}"
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
|
||
|
// 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: "/v4beta1/{job.name=projects/*/tenants/*/jobs/*}"
|
||
|
body: "*"
|
||
|
additional_bindings {
|
||
|
patch: "/v4beta1/{job.name=projects/*/jobs/*}"
|
||
|
body: "*"
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
|
||
|
// 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: "/v4beta1/{name=projects/*/tenants/*/jobs/*}"
|
||
|
additional_bindings {
|
||
|
delete: "/v4beta1/{name=projects/*/jobs/*}"
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
|
||
|
// Lists jobs by filter.
|
||
|
rpc ListJobs(ListJobsRequest) returns (ListJobsResponse) {
|
||
|
option (google.api.http) = {
|
||
|
get: "/v4beta1/{parent=projects/*/tenants/*}/jobs"
|
||
|
additional_bindings {
|
||
|
get: "/v4beta1/{parent=projects/*}/jobs"
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
|
||
|
// Deletes a list of [Job][google.cloud.talent.v4beta1.Job]s by filter.
|
||
|
rpc BatchDeleteJobs(BatchDeleteJobsRequest) returns (google.protobuf.Empty) {
|
||
|
option (google.api.http) = {
|
||
|
post: "/v4beta1/{parent=projects/*/tenants/*}/jobs:batchDelete"
|
||
|
body: "*"
|
||
|
additional_bindings {
|
||
|
post: "/v4beta1/{parent=projects/*}/jobs:batchDelete"
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
|
||
|
// Searches for jobs using the provided [SearchJobsRequest][google.cloud.talent.v4beta1.SearchJobsRequest].
|
||
|
//
|
||
|
// This call constrains the [visibility][google.cloud.talent.v4beta1.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: "/v4beta1/{parent=projects/*/tenants/*}/jobs:search"
|
||
|
body: "*"
|
||
|
additional_bindings {
|
||
|
post: "/v4beta1/{parent=projects/*}/jobs:search"
|
||
|
body: "*"
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
|
||
|
// Searches for jobs using the provided [SearchJobsRequest][google.cloud.talent.v4beta1.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), and has different algorithmic
|
||
|
// adjustments that are targeted to passive job seekers.
|
||
|
//
|
||
|
// This call constrains the [visibility][google.cloud.talent.v4beta1.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: "/v4beta1/{parent=projects/*/tenants/*}/jobs:searchForAlert"
|
||
|
body: "*"
|
||
|
additional_bindings {
|
||
|
post: "/v4beta1/{parent=projects/*}/jobs:searchForAlert"
|
||
|
body: "*"
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// Input only.
|
||
|
//
|
||
|
// 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/api-test-project/tenant/foo".
|
||
|
//
|
||
|
// Tenant id is optional and a default tenant is created if unspecified, for
|
||
|
// example, "projects/api-test-project".
|
||
|
string parent = 1;
|
||
|
|
||
|
// Required.
|
||
|
//
|
||
|
// The Job to be created.
|
||
|
Job job = 2;
|
||
|
}
|
||
|
|
||
|
// Input only.
|
||
|
//
|
||
|
// 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/api-test-project/tenants/foo/jobs/1234".
|
||
|
//
|
||
|
// Tenant id is optional and the default tenant is used if unspecified, for
|
||
|
// example, "projects/api-test-project/jobs/1234".
|
||
|
string name = 1;
|
||
|
}
|
||
|
|
||
|
// Input only.
|
||
|
//
|
||
|
// Update job request.
|
||
|
message UpdateJobRequest {
|
||
|
// Required.
|
||
|
//
|
||
|
// The Job to be updated.
|
||
|
Job job = 1;
|
||
|
|
||
|
// Optional but strongly recommended to be provided for the best service
|
||
|
// experience.
|
||
|
//
|
||
|
// If [update_mask][google.cloud.talent.v4beta1.UpdateJobRequest.update_mask] is provided, only the specified fields in
|
||
|
// [job][google.cloud.talent.v4beta1.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.v4beta1.Job] are supported.
|
||
|
google.protobuf.FieldMask update_mask = 2;
|
||
|
}
|
||
|
|
||
|
// Input only.
|
||
|
//
|
||
|
// 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/api-test-project/tenants/foo/jobs/1234".
|
||
|
//
|
||
|
// Tenant id is optional and the default tenant is used if unspecified, for
|
||
|
// example, "projects/api-test-project/jobs/1234".
|
||
|
string name = 1;
|
||
|
}
|
||
|
|
||
|
// Input only.
|
||
|
//
|
||
|
// Batch delete jobs request.
|
||
|
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/api-test-project/tenant/foo".
|
||
|
//
|
||
|
// Tenant id is optional and the default tenant is used if unspecified, for
|
||
|
// example, "projects/api-test-project".
|
||
|
string parent = 1;
|
||
|
|
||
|
// Required.
|
||
|
//
|
||
|
// The filter string specifies the jobs to be deleted.
|
||
|
//
|
||
|
// Supported operator: =, AND
|
||
|
//
|
||
|
// The fields eligible for filtering are:
|
||
|
//
|
||
|
// * `companyName` (Required)
|
||
|
// * `requisitionId` (Required)
|
||
|
//
|
||
|
// Sample Query: companyName = "projects/api-test-project/companies/123" AND
|
||
|
// requisitionId = "req-1"
|
||
|
string filter = 2;
|
||
|
}
|
||
|
|
||
|
// Input only.
|
||
|
//
|
||
|
// 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/api-test-project/tenant/foo".
|
||
|
//
|
||
|
// Tenant id is optional and the default tenant is used if unspecified, for
|
||
|
// example, "projects/api-test-project".
|
||
|
string parent = 1;
|
||
|
|
||
|
// Required.
|
||
|
//
|
||
|
// The filter string specifies the jobs to be enumerated.
|
||
|
//
|
||
|
// Supported operator: =, AND
|
||
|
//
|
||
|
// The fields eligible for filtering are:
|
||
|
//
|
||
|
// * `companyName` (Required)
|
||
|
// * `requisitionId` (Optional)
|
||
|
// * `status` (Optional) Available values: OPEN, EXPIRED, ALL. Defaults to
|
||
|
// OPEN if no value is specified.
|
||
|
//
|
||
|
// Sample Query:
|
||
|
//
|
||
|
// * companyName = "projects/api-test-project/tenants/foo/companies/bar"
|
||
|
// * companyName = "projects/api-test-project/tenants/foo/companies/bar" AND
|
||
|
// requisitionId = "req-1"
|
||
|
// * companyName = "projects/api-test-project/tenants/foo/companies/bar" AND
|
||
|
// status = "EXPIRED"
|
||
|
string filter = 2;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// The starting point of a query result.
|
||
|
string page_token = 3;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// The maximum number of jobs to be returned per page of results.
|
||
|
//
|
||
|
// If [job_view][google.cloud.talent.v4beta1.ListJobsRequest.job_view] is set to [JobView.JOB_VIEW_ID_ONLY][google.cloud.talent.v4beta1.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;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// The desired job attributes returned for jobs in the
|
||
|
// search response. Defaults to [JobView.JOB_VIEW_FULL][google.cloud.talent.v4beta1.JobView.JOB_VIEW_FULL] if no value is
|
||
|
// specified.
|
||
|
JobView job_view = 5;
|
||
|
}
|
||
|
|
||
|
// An enum that specifies the job attributes that are returned in the
|
||
|
// [MatchingJob.Job][] in [SearchJobsResponse][google.cloud.talent.v4beta1.SearchJobsResponse] or [Job][google.cloud.talent.v4beta1.Job] objects in
|
||
|
// [ListJobsResponse][google.cloud.talent.v4beta1.ListJobsResponse].
|
||
|
enum JobView {
|
||
|
// Default value.
|
||
|
JOB_VIEW_UNSPECIFIED = 0;
|
||
|
|
||
|
// A ID only view of job, with following attributes:
|
||
|
// [Job.name][google.cloud.talent.v4beta1.Job.name], [Job.requisition_id][google.cloud.talent.v4beta1.Job.requisition_id], [Job.language_code][google.cloud.talent.v4beta1.Job.language_code].
|
||
|
JOB_VIEW_ID_ONLY = 1;
|
||
|
|
||
|
// A minimal view of the job, with the following attributes:
|
||
|
// [Job.name][google.cloud.talent.v4beta1.Job.name], [Job.requisition_id][google.cloud.talent.v4beta1.Job.requisition_id], [Job.job_title][],
|
||
|
// [Job.company][google.cloud.talent.v4beta1.Job.company], [Job.DerivedInfo.locations][google.cloud.talent.v4beta1.Job.DerivedInfo.locations], [Job.language_code][google.cloud.talent.v4beta1.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.v4beta1.Job.name], [Job.requisition_id][google.cloud.talent.v4beta1.Job.requisition_id], [Job.job_title][],
|
||
|
// [Job.company][google.cloud.talent.v4beta1.Job.company], [Job.DerivedInfo.locations][google.cloud.talent.v4beta1.Job.DerivedInfo.locations], [Job.visibility][google.cloud.talent.v4beta1.Job.visibility],
|
||
|
// [Job.language_code][google.cloud.talent.v4beta1.Job.language_code], [Job.description][google.cloud.talent.v4beta1.Job.description].
|
||
|
JOB_VIEW_SMALL = 3;
|
||
|
|
||
|
// All available attributes are included in the search results.
|
||
|
JOB_VIEW_FULL = 4;
|
||
|
}
|
||
|
|
||
|
// Output only.
|
||
|
//
|
||
|
// 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;
|
||
|
}
|
||
|
|
||
|
// Input only.
|
||
|
//
|
||
|
// The Request body of the `SearchJobs` call.
|
||
|
message SearchJobsRequest {
|
||
|
// Input only.
|
||
|
//
|
||
|
// Custom ranking information for [SearchJobsRequest][google.cloud.talent.v4beta1.SearchJobsRequest].
|
||
|
message CustomRankingInfo {
|
||
|
// The importance level for [CustomRankingInfo.ranking_expression][google.cloud.talent.v4beta1.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.v4beta1.SearchJobsRequest.CustomRankingInfo.ranking_expression] gets applied to job's final
|
||
|
// ranking position.
|
||
|
//
|
||
|
// An error is thrown if not specified.
|
||
|
ImportanceLevel importance_level = 1;
|
||
|
|
||
|
// Required.
|
||
|
//
|
||
|
// Controls over how job documents get ranked on top of existing relevance
|
||
|
// score (determined by API algorithm). The product of 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.v4beta1.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 < 100 characters in length.
|
||
|
//
|
||
|
// Sample ranking expression
|
||
|
// (year + 25) * 0.25 - (freshness / 0.5)
|
||
|
string ranking_expression = 2;
|
||
|
}
|
||
|
|
||
|
// 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.
|
||
|
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.
|
||
|
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;
|
||
|
}
|
||
|
|
||
|
// Required.
|
||
|
//
|
||
|
// The resource name of the tenant to search within.
|
||
|
//
|
||
|
// The format is "projects/{project_id}/tenants/{tenant_id}", for example,
|
||
|
// "projects/api-test-project/tenant/foo".
|
||
|
//
|
||
|
// Tenant id is optional and the default tenant is used if unspecified, for
|
||
|
// example, "projects/api-test-project".
|
||
|
string parent = 1;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// Mode of a search.
|
||
|
//
|
||
|
// Defaults to [SearchMode.JOB_SEARCH][google.cloud.talent.v4beta1.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;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// Query used to search against jobs, such as keyword, location filters, etc.
|
||
|
JobQuery job_query = 4;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// 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;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// Controls if the search job request requires the return of a precise
|
||
|
// count of the first 300 results. Setting this to `true` ensures
|
||
|
// consistency in the number of results per page. Best practice is to set this
|
||
|
// value to true if a client allows users to jump directly to a
|
||
|
// non-sequential search results page.
|
||
|
//
|
||
|
// Enabling this flag may adversely impact performance.
|
||
|
//
|
||
|
// Defaults to false.
|
||
|
bool require_precise_result_size = 6;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// 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.
|
||
|
//
|
||
|
// 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_id: histogram by [Job.distributor_company_id][].
|
||
|
// * company_display_name: histogram by [Job.company_display_name][google.cloud.talent.v4beta1.Job.company_display_name].
|
||
|
// * employment_type: histogram by [Job.employment_types][google.cloud.talent.v4beta1.Job.employment_types], for example,
|
||
|
// "FULL_TIME", "PART_TIME".
|
||
|
// * company_size: histogram by [CompanySize][google.cloud.talent.v4beta1.CompanySize], for example, "SMALL",
|
||
|
// "MEDIUM", "BIG".
|
||
|
// * publish_time_in_month: histogram by the [Job.publish_time][] in months.
|
||
|
// Must specify list of numeric buckets in spec.
|
||
|
// * publish_time_in_year: histogram by the [Job.publish_time][] in years.
|
||
|
// Must specify list of numeric buckets in spec.
|
||
|
// * degree_type: histogram by the [Job.degree_type][], for example,
|
||
|
// "Bachelors", "Masters".
|
||
|
// * job_level: histogram by the [Job.job_level][google.cloud.talent.v4beta1.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.v4beta1.Job.language_code], for example, "en-US",
|
||
|
// "fr-FR".
|
||
|
// * language: histogram by the language subtag of the [Job.language_code][google.cloud.talent.v4beta1.Job.language_code],
|
||
|
// for example, "en", "fr".
|
||
|
// * category: histogram by the [JobCategory][google.cloud.talent.v4beta1.JobCategory], for example,
|
||
|
// "COMPUTER_AND_IT", "HEALTHCARE".
|
||
|
// * base_compensation_unit: histogram by the [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.v4beta1.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.v4beta1.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;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// The desired job attributes returned for jobs in the
|
||
|
// search response. Defaults to [JobView.SMALL][] if no value is specified.
|
||
|
JobView job_view = 8;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// 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.v4beta1.SearchJobsRequest.page_token] is unset.
|
||
|
//
|
||
|
// 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;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// 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 page_size = 10;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// The token specifying the current offset within
|
||
|
// search results. See [SearchJobsResponse.next_page_token][google.cloud.talent.v4beta1.SearchJobsResponse.next_page_token] for
|
||
|
// an explanation of how to obtain the next set of query results.
|
||
|
string page_token = 11;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// 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.v4beta1.Job.posting_publish_time]
|
||
|
// descending.
|
||
|
// * "posting`_`update`_`time desc": By [Job.posting_update_time][google.cloud.talent.v4beta1.Job.posting_update_time]
|
||
|
// descending.
|
||
|
// * "title": By [Job.title][google.cloud.talent.v4beta1.Job.title] ascending.
|
||
|
// * "title desc": By [Job.title][google.cloud.talent.v4beta1.Job.title] descending.
|
||
|
// * "annualized`_`base`_`compensation": By job's
|
||
|
// [CompensationInfo.annualized_base_compensation_range][google.cloud.talent.v4beta1.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.v4beta1.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.v4beta1.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.v4beta1.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.custom_ranking_info.ranking_expression][] with weight
|
||
|
// factor assigned by
|
||
|
// [SearchJobsRequest.custom_ranking_info.importance_level][] in descending
|
||
|
// order.
|
||
|
// * "location`_`distance": By the distance between the location on jobs and
|
||
|
// locations specified in the
|
||
|
// [SearchJobsRequest.job_query.location_filters][].
|
||
|
// When this order is selected, the
|
||
|
// [SearchJobsRequest.job_query.location_filters][] must not be empty. When
|
||
|
// a job has multiple locations, the location closest to one of the locations
|
||
|
// specified in the location filter will be used to calculate location
|
||
|
// distance. Distance is calculated by the distance between two lat/long
|
||
|
// coordinates, with a precision of 10e-4 degrees (11.3 meters).
|
||
|
// Jobs that don't have locations specified will be ranked below jobs having
|
||
|
// locations.
|
||
|
// Diversification strategy is still applied unless explicitly disabled in
|
||
|
// [SearchJobsRequest.diversification_level][google.cloud.talent.v4beta1.SearchJobsRequest.diversification_level].
|
||
|
string order_by = 12;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// 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.v4beta1.SearchJobsRequest.DiversificationLevel.SIMPLE] if no value
|
||
|
// is specified.
|
||
|
DiversificationLevel diversification_level = 13;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// Controls over how job documents get ranked on top of existing relevance
|
||
|
// score (determined by API algorithm).
|
||
|
CustomRankingInfo custom_ranking_info = 14;
|
||
|
|
||
|
// Optional.
|
||
|
//
|
||
|
// Controls whether to disable exact keyword match on [Job.job_title][],
|
||
|
// [Job.description][google.cloud.talent.v4beta1.Job.description], [Job.company_display_name][google.cloud.talent.v4beta1.Job.company_display_name], [Job.locations][0],
|
||
|
// [Job.qualifications][google.cloud.talent.v4beta1.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.
|
||
|
//
|
||
|
// Please use [Company.keyword_searchable_custom_fields][] or
|
||
|
// [Company.keyword_searchable_custom_attributes][] if company specific
|
||
|
// globally matched custom field/attribute string values is needed. Enabling
|
||
|
// keyword match improves recall of subsequent search requests.
|
||
|
//
|
||
|
// Defaults to false.
|
||
|
bool disable_keyword_match = 16;
|
||
|
}
|
||
|
|
||
|
// Output only.
|
||
|
//
|
||
|
// Response for SearchJob method.
|
||
|
message SearchJobsResponse {
|
||
|
// Output only.
|
||
|
//
|
||
|
// Job entry with metadata inside [SearchJobsResponse][google.cloud.talent.v4beta1.SearchJobsResponse].
|
||
|
message MatchingJob {
|
||
|
// Job resource that matches the specified [SearchJobsRequest][google.cloud.talent.v4beta1.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.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.v4beta1.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.v4beta1.CommuteFilter].
|
||
|
CommuteInfo commute_info = 5;
|
||
|
}
|
||
|
|
||
|
// Output only.
|
||
|
//
|
||
|
// 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.v4beta1.SearchJobsRequest].
|
||
|
repeated MatchingJob matching_jobs = 1;
|
||
|
|
||
|
// The histogram results that match with specified
|
||
|
// [SearchJobsRequest.histogram_queries][google.cloud.talent.v4beta1.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 [JobLocation.location_type][] is
|
||
|
// [JobLocation.LocationType#LOCATION_TYPE_UNSPECIFIED][].
|
||
|
repeated Location location_filters = 4;
|
||
|
|
||
|
// An estimation of the number of jobs that match the specified query.
|
||
|
//
|
||
|
// This number isn't guaranteed to be accurate. For accurate results,
|
||
|
// see [enable_precise_result_size][].
|
||
|
int32 estimated_total_size = 5;
|
||
|
|
||
|
// The precise result count, which is available only if the client set
|
||
|
// [enable_precise_result_size][] to `true`, or if the response
|
||
|
// is the last page of results. Otherwise, the value is `-1`.
|
||
|
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;
|
||
|
}
|