# frozen_string_literal: true
# Copyright 2020 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
#
# https://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.
# Auto-generated by gapic-generator-ruby. DO NOT EDIT!
module Google
module Cloud
module Talent
module V4beta1
# Create job request.
# @!attribute [rw] parent
# @return [::String]
# 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/tenant/bar". If tenant id is unspecified a default tenant
# is created. For example, "projects/foo".
# @!attribute [rw] job
# @return [::Google::Cloud::Talent::V4beta1::Job]
# Required. The Job to be created.
class CreateJobRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Get job request.
# @!attribute [rw] name
# @return [::String]
# 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".
#
# If tenant id is unspecified, the default tenant is used. For
# example, "projects/foo/jobs/bar".
class GetJobRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Update job request.
# @!attribute [rw] job
# @return [::Google::Cloud::Talent::V4beta1::Job]
# Required. The Job to be updated.
# @!attribute [rw] update_mask
# @return [::Google::Protobuf::FieldMask]
# Strongly recommended for the best service experience.
#
# If {::Google::Cloud::Talent::V4beta1::UpdateJobRequest#update_mask update_mask} is provided, only the specified fields in
# {::Google::Cloud::Talent::V4beta1::UpdateJobRequest#job job} are updated. Otherwise all the fields are updated.
#
# A field mask to restrict the fields that are updated. Only
# top level fields of {::Google::Cloud::Talent::V4beta1::Job Job} are supported.
class UpdateJobRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Delete job request.
# @!attribute [rw] name
# @return [::String]
# 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".
#
# If tenant id is unspecified, the default tenant is used. For
# example, "projects/foo/jobs/bar".
class DeleteJobRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Batch delete jobs request.
# @!attribute [rw] parent
# @return [::String]
# 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/tenant/bar". If tenant id is unspecified, a default tenant
# is created. For example, "projects/foo".
# @!attribute [rw] filter
# @return [::String]
# 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/foo/companies/bar" AND
# requisitionId = "req-1"
class BatchDeleteJobsRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# List jobs request.
# @!attribute [rw] parent
# @return [::String]
# 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/tenant/bar". If tenant id is unspecified, a default tenant
# is created. For example, "projects/foo".
# @!attribute [rw] filter
# @return [::String]
# 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"
# @!attribute [rw] page_token
# @return [::String]
# The starting point of a query result.
# @!attribute [rw] page_size
# @return [::Integer]
# The maximum number of jobs to be returned per page of results.
#
# If {::Google::Cloud::Talent::V4beta1::ListJobsRequest#job_view job_view} is set to {::Google::Cloud::Talent::V4beta1::JobView::JOB_VIEW_ID_ONLY 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.
# @!attribute [rw] job_view
# @return [::Google::Cloud::Talent::V4beta1::JobView]
# The desired job attributes returned for jobs in the
# search response. Defaults to {::Google::Cloud::Talent::V4beta1::JobView::JOB_VIEW_FULL JobView.JOB_VIEW_FULL} if no value is
# specified.
class ListJobsRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# List jobs response.
# @!attribute [rw] jobs
# @return [::Array<::Google::Cloud::Talent::V4beta1::Job>]
# The Jobs for a given company.
#
# The maximum number of items returned is based on the limit field
# provided in the request.
# @!attribute [rw] next_page_token
# @return [::String]
# A token to retrieve the next page of results.
# @!attribute [rw] metadata
# @return [::Google::Cloud::Talent::V4beta1::ResponseMetadata]
# Additional information for the API invocation, such as the request
# tracking id.
class ListJobsResponse
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# The Request body of the `SearchJobs` call.
# @!attribute [rw] parent
# @return [::String]
# Required. The resource name of the tenant to search within.
#
# The format is "projects/\\{project_id}/tenants/\\{tenant_id}". For example,
# "projects/foo/tenant/bar". If tenant id is unspecified, a default tenant
# is created. For example, "projects/foo".
# @!attribute [rw] search_mode
# @return [::Google::Cloud::Talent::V4beta1::SearchJobsRequest::SearchMode]
# Mode of a search.
#
# Defaults to {::Google::Cloud::Talent::V4beta1::SearchJobsRequest::SearchMode::JOB_SEARCH SearchMode.JOB_SEARCH}.
# @!attribute [rw] request_metadata
# @return [::Google::Cloud::Talent::V4beta1::RequestMetadata]
# 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.
# @!attribute [rw] job_query
# @return [::Google::Cloud::Talent::V4beta1::JobQuery]
# Query used to search against jobs, such as keyword, location filters, etc.
# @!attribute [rw] enable_broadening
# @return [::Boolean]
# 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.
# @!attribute [rw] require_precise_result_size
# @return [::Boolean]
# This field is deprecated.
# @!attribute [rw] histogram_queries
# @return [::Array<::Google::Cloud::Talent::V4beta1::HistogramQuery>]
# 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 {::Google::Cloud::Talent::V4beta1::Job#company_display_name Job.company_display_name}.
# * employment_type: histogram by {::Google::Cloud::Talent::V4beta1::Job#employment_types Job.employment_types}, for example,
# "FULL_TIME", "PART_TIME".
# * company_size (DEPRECATED): histogram by {::Google::Cloud::Talent::V4beta1::CompanySize CompanySize}, for example,
# "SMALL", "MEDIUM", "BIG".
# * publish_time_in_day: histogram by the {::Google::Cloud::Talent::V4beta1::Job#posting_publish_time Job.posting_publish_time}
# in days.
# Must specify list of numeric buckets in spec.
# * publish_time_in_month: histogram by the {::Google::Cloud::Talent::V4beta1::Job#posting_publish_time Job.posting_publish_time}
# in months.
# Must specify list of numeric buckets in spec.
# * publish_time_in_year: histogram by the {::Google::Cloud::Talent::V4beta1::Job#posting_publish_time Job.posting_publish_time}
# in years.
# Must specify list of numeric buckets in spec.
# * degree_types: histogram by the {::Google::Cloud::Talent::V4beta1::Job#degree_types Job.degree_types}, for example,
# "Bachelors", "Masters".
# * job_level: histogram by the {::Google::Cloud::Talent::V4beta1::Job#job_level 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 {::Google::Cloud::Talent::V4beta1::Job#language_code Job.language_code}, for example, "en-US",
# "fr-FR".
# * language: histogram by the language subtag of the {::Google::Cloud::Talent::V4beta1::Job#language_code Job.language_code},
# for example, "en", "fr".
# * category: histogram by the {::Google::Cloud::Talent::V4beta1::JobCategory JobCategory}, for example,
# "COMPUTER_AND_IT", "HEALTHCARE".
# * base_compensation_unit: histogram by the
# {::Google::Cloud::Talent::V4beta1::CompensationInfo::CompensationUnit 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 {::Google::Cloud::Talent::V4beta1::Job#custom_attributes Job.custom_attributes}.
# Values can be accessed via square bracket notations like
# string_custom_attribute["key1"].
# * numeric_custom_attribute: histogram by numeric {::Google::Cloud::Talent::V4beta1::Job#custom_attributes 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")])`
# @!attribute [rw] job_view
# @return [::Google::Cloud::Talent::V4beta1::JobView]
# The desired job attributes returned for jobs in the search response.
# Defaults to {::Google::Cloud::Talent::V4beta1::JobView::JOB_VIEW_SMALL JobView.JOB_VIEW_SMALL} if no value is specified.
# @!attribute [rw] offset
# @return [::Integer]
# 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 {::Google::Cloud::Talent::V4beta1::SearchJobsRequest#page_token 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).
# @!attribute [rw] page_size
# @return [::Integer]
# 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.
# @!attribute [rw] page_token
# @return [::String]
# The token specifying the current offset within
# search results. See {::Google::Cloud::Talent::V4beta1::SearchJobsResponse#next_page_token SearchJobsResponse.next_page_token} for
# an explanation of how to obtain the next set of query results.
# @!attribute [rw] order_by
# @return [::String]
# 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 {::Google::Cloud::Talent::V4beta1::Job#posting_publish_time Job.posting_publish_time}
# descending.
# * `"posting_update_time desc"`: By {::Google::Cloud::Talent::V4beta1::Job#posting_update_time Job.posting_update_time}
# descending.
# * `"title"`: By {::Google::Cloud::Talent::V4beta1::Job#title Job.title} ascending.
# * `"title desc"`: By {::Google::Cloud::Talent::V4beta1::Job#title Job.title} descending.
# * `"annualized_base_compensation"`: By job's
# {::Google::Cloud::Talent::V4beta1::CompensationInfo#annualized_base_compensation_range 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
# {::Google::Cloud::Talent::V4beta1::CompensationInfo#annualized_base_compensation_range 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
# {::Google::Cloud::Talent::V4beta1::CompensationInfo#annualized_total_compensation_range 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
# {::Google::Cloud::Talent::V4beta1::CompensationInfo#annualized_total_compensation_range 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
# {::Google::Cloud::Talent::V4beta1::SearchJobsRequest::CustomRankingInfo#ranking_expression SearchJobsRequest.CustomRankingInfo.ranking_expression} with weight
# factor assigned by
# {::Google::Cloud::Talent::V4beta1::SearchJobsRequest::CustomRankingInfo#importance_level 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
# {::Google::Cloud::Talent::V4beta1::SearchJobsRequest#diversification_level diversification_level}.
# @!attribute [rw] diversification_level
# @return [::Google::Cloud::Talent::V4beta1::SearchJobsRequest::DiversificationLevel]
# 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 {::Google::Cloud::Talent::V4beta1::SearchJobsRequest::DiversificationLevel::SIMPLE DiversificationLevel.SIMPLE} if no value
# is specified.
# @!attribute [rw] custom_ranking_info
# @return [::Google::Cloud::Talent::V4beta1::SearchJobsRequest::CustomRankingInfo]
# Controls over how job documents get ranked on top of existing relevance
# score (determined by API algorithm).
# @!attribute [rw] disable_keyword_match
# @return [::Boolean]
# This field is deprecated. Please use
# {::Google::Cloud::Talent::V4beta1::SearchJobsRequest#keyword_match_mode SearchJobsRequest.keyword_match_mode} going forward.
#
# To migrate, disable_keyword_match set to false maps to
# {::Google::Cloud::Talent::V4beta1::SearchJobsRequest::KeywordMatchMode::KEYWORD_MATCH_ALL KeywordMatchMode.KEYWORD_MATCH_ALL}, and disable_keyword_match set to
# true maps to {::Google::Cloud::Talent::V4beta1::SearchJobsRequest::KeywordMatchMode::KEYWORD_MATCH_DISABLED KeywordMatchMode.KEYWORD_MATCH_DISABLED}. If
# {::Google::Cloud::Talent::V4beta1::SearchJobsRequest#keyword_match_mode SearchJobsRequest.keyword_match_mode} is set, this field is ignored.
#
# Controls whether to disable exact keyword match on {::Google::Cloud::Talent::V4beta1::Job#title Job.title},
# {::Google::Cloud::Talent::V4beta1::Job#description Job.description}, {::Google::Cloud::Talent::V4beta1::Job#company_display_name Job.company_display_name}, {::Google::Cloud::Talent::V4beta1::Job#addresses Job.addresses},
# {::Google::Cloud::Talent::V4beta1::Job#qualifications 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 {::Google::Cloud::Talent::V4beta1::Company#keyword_searchable_job_custom_attributes 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.
# @!attribute [rw] keyword_match_mode
# @return [::Google::Cloud::Talent::V4beta1::SearchJobsRequest::KeywordMatchMode]
# Controls what keyword match options to use.
#
# Defaults to {::Google::Cloud::Talent::V4beta1::SearchJobsRequest::KeywordMatchMode::KEYWORD_MATCH_ALL KeywordMatchMode.KEYWORD_MATCH_ALL} if no value
# is specified.
class SearchJobsRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
# Custom ranking information for {::Google::Cloud::Talent::V4beta1::SearchJobsRequest SearchJobsRequest}.
# @!attribute [rw] importance_level
# @return [::Google::Cloud::Talent::V4beta1::SearchJobsRequest::CustomRankingInfo::ImportanceLevel]
# Required. Controls over how important the score of
# {::Google::Cloud::Talent::V4beta1::SearchJobsRequest::CustomRankingInfo#ranking_expression CustomRankingInfo.ranking_expression} gets applied to job's final
# ranking position.
#
# An error is thrown if not specified.
# @!attribute [rw] ranking_expression
# @return [::String]
# 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 {::Google::Cloud::Talent::V4beta1::Job#custom_attributes 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)
class CustomRankingInfo
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
# The importance level for {::Google::Cloud::Talent::V4beta1::SearchJobsRequest::CustomRankingInfo#ranking_expression CustomRankingInfo.ranking_expression}.
module 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
end
end
# A string-represented enumeration of the job search mode. The service
# operate differently for different modes of service.
module 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
end
# 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.
module 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. 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.
SIMPLE = 2
end
# 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 {::Google::Cloud::Talent::V4beta1::Company#keyword_searchable_job_custom_attributes 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.
module KeywordMatchMode
# The keyword match option isn't specified. Defaults to
# {::Google::Cloud::Talent::V4beta1::SearchJobsRequest::KeywordMatchMode::KEYWORD_MATCH_ALL KeywordMatchMode.KEYWORD_MATCH_ALL} behavior.
KEYWORD_MATCH_MODE_UNSPECIFIED = 0
# Disables keyword matching.
KEYWORD_MATCH_DISABLED = 1
# Enable keyword matching over {::Google::Cloud::Talent::V4beta1::Job#title Job.title},
# {::Google::Cloud::Talent::V4beta1::Job#description Job.description}, {::Google::Cloud::Talent::V4beta1::Job#company_display_name Job.company_display_name}, {::Google::Cloud::Talent::V4beta1::Job#addresses Job.addresses},
# {::Google::Cloud::Talent::V4beta1::Job#qualifications Job.qualifications}, and keyword searchable {::Google::Cloud::Talent::V4beta1::Job#custom_attributes Job.custom_attributes}
# fields.
KEYWORD_MATCH_ALL = 2
# Only enable keyword matching over {::Google::Cloud::Talent::V4beta1::Job#title Job.title}.
KEYWORD_MATCH_TITLE_ONLY = 3
end
end
# Response for SearchJob method.
# @!attribute [rw] matching_jobs
# @return [::Array<::Google::Cloud::Talent::V4beta1::SearchJobsResponse::MatchingJob>]
# The Job entities that match the specified {::Google::Cloud::Talent::V4beta1::SearchJobsRequest SearchJobsRequest}.
# @!attribute [rw] histogram_query_results
# @return [::Array<::Google::Cloud::Talent::V4beta1::HistogramQueryResult>]
# The histogram results that match with specified
# {::Google::Cloud::Talent::V4beta1::SearchJobsRequest#histogram_queries SearchJobsRequest.histogram_queries}.
# @!attribute [rw] next_page_token
# @return [::String]
# The token that specifies the starting position of the next page of results.
# This field is empty if there are no more results.
# @!attribute [rw] location_filters
# @return [::Array<::Google::Cloud::Talent::V4beta1::Location>]
# The location filters that the service applied to the specified query. If
# any filters are lat-lng based, the {::Google::Cloud::Talent::V4beta1::Location#location_type Location.location_type} is
# {::Google::Cloud::Talent::V4beta1::Location::LocationType::LOCATION_TYPE_UNSPECIFIED Location.LocationType.LOCATION_TYPE_UNSPECIFIED}.
# @!attribute [rw] estimated_total_size
# @return [::Integer]
# An estimation of the number of jobs that match the specified query.
#
# This number isn't guaranteed to be accurate. For accurate results,
# see {::Google::Cloud::Talent::V4beta1::SearchJobsResponse#total_size SearchJobsResponse.total_size}.
# @!attribute [rw] total_size
# @return [::Integer]
# The precise result count with limit 100,000.
# @!attribute [rw] metadata
# @return [::Google::Cloud::Talent::V4beta1::ResponseMetadata]
# Additional information for the API invocation, such as the request
# tracking id.
# @!attribute [rw] broadened_query_jobs_count
# @return [::Integer]
# 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.
# @!attribute [rw] spell_correction
# @return [::Google::Cloud::Talent::V4beta1::SpellingCorrection]
# The spell checking result, and correction.
class SearchJobsResponse
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
# Job entry with metadata inside {::Google::Cloud::Talent::V4beta1::SearchJobsResponse SearchJobsResponse}.
# @!attribute [rw] job
# @return [::Google::Cloud::Talent::V4beta1::Job]
# Job resource that matches the specified {::Google::Cloud::Talent::V4beta1::SearchJobsRequest SearchJobsRequest}.
# @!attribute [rw] job_summary
# @return [::String]
# A summary of the job with core information that's displayed on the search
# results listing page.
# @!attribute [rw] job_title_snippet
# @return [::String]
# Contains snippets of text from the {::Google::Cloud::Talent::V4beta1::Job#title Job.title} field most
# closely matching a search query's keywords, if available. The matching
# query keywords are enclosed in HTML bold tags.
# @!attribute [rw] search_text_snippet
# @return [::String]
# Contains snippets of text from the {::Google::Cloud::Talent::V4beta1::Job#description 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.
# @!attribute [rw] commute_info
# @return [::Google::Cloud::Talent::V4beta1::SearchJobsResponse::CommuteInfo]
# Commute information which is generated based on specified
# {::Google::Cloud::Talent::V4beta1::CommuteFilter CommuteFilter}.
class MatchingJob
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Commute details related to this job.
# @!attribute [rw] job_location
# @return [::Google::Cloud::Talent::V4beta1::Location]
# Location used as the destination in the commute calculation.
# @!attribute [rw] travel_duration
# @return [::Google::Protobuf::Duration]
# 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.
class CommuteInfo
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
end
# Request to create a batch of jobs.
# @!attribute [rw] parent
# @return [::String]
# 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/tenant/bar". If tenant id is unspecified, a default tenant
# is created. For example, "projects/foo".
# @!attribute [rw] jobs
# @return [::Array<::Google::Cloud::Talent::V4beta1::Job>]
# Required. The jobs to be created.
class BatchCreateJobsRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# Request to update a batch of jobs.
# @!attribute [rw] parent
# @return [::String]
# 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/tenant/bar". If tenant id is unspecified, a default tenant
# is created. For example, "projects/foo".
# @!attribute [rw] jobs
# @return [::Array<::Google::Cloud::Talent::V4beta1::Job>]
# Required. The jobs to be updated.
# @!attribute [rw] update_mask
# @return [::Google::Protobuf::FieldMask]
# Strongly recommended for the best service experience. Be aware that it will
# also increase latency when checking the status of a batch operation.
#
# If {::Google::Cloud::Talent::V4beta1::BatchUpdateJobsRequest#update_mask update_mask} is provided, only the specified fields in
# {::Google::Cloud::Talent::V4beta1::Job Job} are updated. Otherwise all the fields are updated.
#
# A field mask to restrict the fields that are updated. Only
# top level fields of {::Google::Cloud::Talent::V4beta1::Job Job} are supported.
#
# If {::Google::Cloud::Talent::V4beta1::BatchUpdateJobsRequest#update_mask update_mask} is provided, The {::Google::Cloud::Talent::V4beta1::Job Job} inside
# {::Google::Cloud::Talent::V4beta1::JobOperationResult::JobResult JobResult}
# will only contains fields that is updated, plus the Id of the Job.
# Otherwise, {::Google::Cloud::Talent::V4beta1::Job Job} will include all fields, which can yield a very
# large response.
class BatchUpdateJobsRequest
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
# The result of {::Google::Cloud::Talent::V4beta1::JobService::Client#batch_create_jobs JobService.BatchCreateJobs} or
# {::Google::Cloud::Talent::V4beta1::JobService::Client#batch_update_jobs JobService.BatchUpdateJobs} APIs. It's used to
# replace {::Google::Longrunning::Operation#response google.longrunning.Operation.response} in case of success.
# @!attribute [rw] job_results
# @return [::Array<::Google::Cloud::Talent::V4beta1::JobOperationResult::JobResult>]
# List of job mutation results from a batch mutate operation. It can change
# until operation status is FINISHED, FAILED or CANCELLED.
class JobOperationResult
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
# Mutation result of a job.
# @!attribute [rw] job
# @return [::Google::Cloud::Talent::V4beta1::Job]
# Here {::Google::Cloud::Talent::V4beta1::Job Job} only contains basic information including {::Google::Cloud::Talent::V4beta1::Job#name name},
# {::Google::Cloud::Talent::V4beta1::Job#company company}, {::Google::Cloud::Talent::V4beta1::Job#language_code language_code}
# and {::Google::Cloud::Talent::V4beta1::Job#requisition_id requisition_id}, use getJob method to retrieve
# detailed information of the created/updated job.
# @!attribute [rw] status
# @return [::Google::Rpc::Status]
# The status of the job processed. This field is populated if the
# processing of the {::Google::Cloud::Talent::V4beta1::JobOperationResult::JobResult#job job} fails.
class JobResult
include ::Google::Protobuf::MessageExts
extend ::Google::Protobuf::MessageExts::ClassMethods
end
end
# An enum that specifies the job attributes that are returned in the
# {::Google::Cloud::Talent::V4beta1::SearchJobsResponse::MatchingJob#job MatchingJob.job} or
# {::Google::Cloud::Talent::V4beta1::ListJobsResponse#jobs ListJobsResponse.jobs} fields.
module JobView
# Default value.
JOB_VIEW_UNSPECIFIED = 0
# A ID only view of job, with following attributes:
# {::Google::Cloud::Talent::V4beta1::Job#name Job.name}, {::Google::Cloud::Talent::V4beta1::Job#requisition_id Job.requisition_id}, {::Google::Cloud::Talent::V4beta1::Job#language_code Job.language_code}.
JOB_VIEW_ID_ONLY = 1
# A minimal view of the job, with the following attributes:
# {::Google::Cloud::Talent::V4beta1::Job#name Job.name}, {::Google::Cloud::Talent::V4beta1::Job#requisition_id Job.requisition_id}, {::Google::Cloud::Talent::V4beta1::Job#title Job.title},
# {::Google::Cloud::Talent::V4beta1::Job#company Job.company}, {::Google::Cloud::Talent::V4beta1::Job::DerivedInfo#locations Job.DerivedInfo.locations}, {::Google::Cloud::Talent::V4beta1::Job#language_code Job.language_code}.
JOB_VIEW_MINIMAL = 2
# A small view of the job, with the following attributes in the search
# results: {::Google::Cloud::Talent::V4beta1::Job#name Job.name}, {::Google::Cloud::Talent::V4beta1::Job#requisition_id Job.requisition_id}, {::Google::Cloud::Talent::V4beta1::Job#title Job.title},
# {::Google::Cloud::Talent::V4beta1::Job#company Job.company}, {::Google::Cloud::Talent::V4beta1::Job::DerivedInfo#locations Job.DerivedInfo.locations}, {::Google::Cloud::Talent::V4beta1::Job#visibility Job.visibility},
# {::Google::Cloud::Talent::V4beta1::Job#language_code Job.language_code}, {::Google::Cloud::Talent::V4beta1::Job#description Job.description}.
JOB_VIEW_SMALL = 3
# All available attributes are included in the search results.
JOB_VIEW_FULL = 4
end
end
end
end
end