// Copyright 2024 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 = "cloud.google.com/go/talent/apiv4/talentpb;talentpb"; 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; // Similar to ONE_PER_COMPANY, but it allows at most three jobs in the // same company to be shown at once, the other jobs under same company are // dropped. MAX_THREE_PER_COMPANY = 6; // 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 (DEPRECATED): 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:
// `"distance_from('Hawaii')"`: Order by distance from Hawaii.
// `"distance_from(19.89, 155.5)"`: Order by distance from a coordinate.
// `"distance_from('Hawaii'), distance_from('Puerto Rico')"`: Order by // multiple locations. See details below.
// `"distance_from('Hawaii'), distance_from(19.89, 155.5)"`: Order by // multiple locations. See details below.
// 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; }