Class: Google::Apis::JobsV3::Job
- Inherits:
- 
      Object
      
        - Object
- Google::Apis::JobsV3::Job
 
- Includes:
- Core::Hashable, Core::JsonObjectSupport
- Defined in:
- generated/google/apis/jobs_v3/classes.rb,
 generated/google/apis/jobs_v3/representations.rb,
 generated/google/apis/jobs_v3/representations.rb
Overview
A Job resource represents a job posting (also referred to as a "job listing" or "job requisition"). A job belongs to a Company, which is the hiring entity responsible for the job.
Instance Attribute Summary collapse
- 
  
    
      #addresses  ⇒ Array<String> 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional but strongly recommended for the best service experience. 
- 
  
    
      #application_info  ⇒ Google::Apis::JobsV3::ApplicationInfo 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Application related details of a job posting. 
- 
  
    
      #company_display_name  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Output only. 
- 
  
    
      #company_name  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Required. 
- 
  
    
      #compensation_info  ⇒ Google::Apis::JobsV3::CompensationInfo 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Job compensation details. 
- 
  
    
      #custom_attributes  ⇒ Hash<String,Google::Apis::JobsV3::CustomAttribute> 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #degree_types  ⇒ Array<String> 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #department  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #derived_info  ⇒ Google::Apis::JobsV3::JobDerivedInfo 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Output only. 
- 
  
    
      #description  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Required. 
- 
  
    
      #employment_types  ⇒ Array<String> 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #incentives  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #job_benefits  ⇒ Array<String> 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #job_end_time  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #job_level  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #job_start_time  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #language_code  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #name  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Required during job update. 
- 
  
    
      #posting_create_time  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Output only. 
- 
  
    
      #posting_expire_time  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional but strongly recommended for the best service experience. 
- 
  
    
      #posting_publish_time  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #posting_region  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #posting_update_time  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Output only. 
- 
  
    
      #processing_options  ⇒ Google::Apis::JobsV3::ProcessingOptions 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Input only. 
- 
  
    
      #promotion_value  ⇒ Fixnum 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #qualifications  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #requisition_id  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Required. 
- 
  
    
      #responsibilities  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Optional. 
- 
  
    
      #title  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Required. 
- 
  
    
      #visibility  ⇒ String 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    Deprecated. 
Instance Method Summary collapse
- 
  
    
      #initialize(**args)  ⇒ Job 
    
    
  
  
  
    constructor
  
  
  
  
  
  
  
    A new instance of Job. 
- 
  
    
      #update!(**args)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Update properties of this object. 
Constructor Details
#initialize(**args) ⇒ Job
Returns a new instance of Job.
| 1258 1259 1260 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1258 def initialize(**args) update!(**args) end | 
Instance Attribute Details
#addresses ⇒ Array<String>
Optional but strongly recommended for the best service experience. Location(s)
where the employer is looking to hire for this job posting. Specifying the
full street address(es) of the hiring location enables better API results,
especially job searches by commute time. At most 50 locations are allowed for
best search performance. If a job has more locations, it is suggested to split
it into multiple jobs with unique requisition_ids (e.g. 'ReqA' becomes 'ReqA-1'
, 'ReqA-2', etc.) as multiple jobs with the same company_name, language_code
and requisition_id are not allowed. If the original requisition_id must be
preserved, a custom field should be used for storage. It is also suggested to
group the locations that close to each other in the same job for better search
experience. The maximum number of allowed characters is 500.
Corresponds to the JSON property addresses
| 1034 1035 1036 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1034 def addresses @addresses end | 
#application_info ⇒ Google::Apis::JobsV3::ApplicationInfo
Application related details of a job posting.
Corresponds to the JSON property applicationInfo
| 1039 1040 1041 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1039 def application_info @application_info end | 
#company_display_name ⇒ String
Output only. Display name of the company listing the job.
Corresponds to the JSON property companyDisplayName
| 1044 1045 1046 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1044 def company_display_name @company_display_name end | 
#company_name ⇒ String
Required. The resource name of the company listing the job, such as "projects/
api-test-project/companies/foo".
Corresponds to the JSON property companyName
| 1050 1051 1052 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1050 def company_name @company_name end | 
#compensation_info ⇒ Google::Apis::JobsV3::CompensationInfo
Job compensation details.
Corresponds to the JSON property compensationInfo
| 1055 1056 1057 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1055 def compensation_info @compensation_info end | 
#custom_attributes ⇒ Hash<String,Google::Apis::JobsV3::CustomAttribute>
Optional. A map of fields to hold both filterable and non-filterable custom
job attributes that are not covered by the provided structured fields. The
keys of the map are strings up to 64 bytes and must match the pattern: a-zA-Z*.
For example, key0LikeThis or KEY_1_LIKE_THIS. At most 100 filterable and at
most 100 unfilterable keys are supported. For filterable string_values,
across all keys at most 200 values are allowed, with each string no more than
255 characters. For unfilterable string_values, the maximum total size of 
string_values across all keys is 50KB.
Corresponds to the JSON property customAttributes
| 1067 1068 1069 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1067 def custom_attributes @custom_attributes end | 
#degree_types ⇒ Array<String>
Optional. The desired education degrees for the job, such as Bachelors,
Masters.
Corresponds to the JSON property degreeTypes
| 1073 1074 1075 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1073 def degree_types @degree_types end | 
#department ⇒ String
Optional. The department or functional area within the company with the open
position. The maximum number of allowed characters is 255.
Corresponds to the JSON property department
| 1079 1080 1081 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1079 def department @department end | 
#derived_info ⇒ Google::Apis::JobsV3::JobDerivedInfo
Output only. Derived details about the job posting.
Corresponds to the JSON property derivedInfo
| 1084 1085 1086 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1084 def derived_info @derived_info end | 
#description ⇒ String
Required. The description of the job, which typically includes a multi-
paragraph description of the company and related information. Separate fields
are provided on the job object for responsibilities, qualifications, and other
job characteristics. Use of these separate job fields is recommended. This
field accepts and sanitizes HTML input, and also accepts bold, italic, ordered
list, and unordered list markup tags. The maximum number of allowed characters
is 100,000.
Corresponds to the JSON property description
| 1095 1096 1097 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1095 def description @description end | 
#employment_types ⇒ Array<String>
Optional. The employment type(s) of a job, for example, full time or part time.
Corresponds to the JSON property employmentTypes
| 1100 1101 1102 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1100 def employment_types @employment_types end | 
#incentives ⇒ String
Optional. A description of bonus, commission, and other compensation
incentives associated with the job not including salary or pay. The maximum
number of allowed characters is 10,000.
Corresponds to the JSON property incentives
| 1107 1108 1109 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1107 def incentives @incentives end | 
#job_benefits ⇒ Array<String>
Optional. The benefits included with the job.
Corresponds to the JSON property jobBenefits
| 1112 1113 1114 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1112 def job_benefits @job_benefits end | 
#job_end_time ⇒ String
Optional. The end timestamp of the job. Typically this field is used for
contracting engagements. Invalid timestamps are ignored.
Corresponds to the JSON property jobEndTime
| 1118 1119 1120 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1118 def job_end_time @job_end_time end | 
#job_level ⇒ String
Optional. The experience level associated with the job, such as "Entry Level".
Corresponds to the JSON property jobLevel
| 1123 1124 1125 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1123 def job_level @job_level end | 
#job_start_time ⇒ String
Optional. The start timestamp of the job in UTC time zone. Typically this
field is used for contracting engagements. Invalid timestamps are ignored.
Corresponds to the JSON property jobStartTime
| 1129 1130 1131 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1129 def job_start_time @job_start_time end | 
#language_code ⇒ String
Optional. The language of the posting. This field is distinct from any
requirements for fluency that are associated with the job. Language codes must
be in BCP-47 format, such as "en-US" or "sr-Latn". For more information, see 
Tags for Identifying Languages: class="
external" target="_blank". If this field is unspecified and Job.description
is present, detected language code based on Job.description is assigned,
otherwise defaults to 'en_US'.
Corresponds to the JSON property languageCode
| 1140 1141 1142 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1140 def language_code @language_code end | 
#name ⇒ String
Required during job update. The resource name for the job. This is generated
by the service when a job is created. The format is "projects/project_id/
jobs/job_id", for example, "projects/api-test-project/jobs/1234". Use of
this field in job queries and API calls is preferred over the use of
requisition_id since this value is unique.
Corresponds to the JSON property name
| 1149 1150 1151 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1149 def name @name end | 
#posting_create_time ⇒ String
Output only. The timestamp when this job posting was created.
Corresponds to the JSON property postingCreateTime
| 1154 1155 1156 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1154 def posting_create_time @posting_create_time end | 
#posting_expire_time ⇒ String
Optional but strongly recommended for the best service experience. The
expiration timestamp of the job. After this timestamp, the job is marked as
expired, and it no longer appears in search results. The expired job can't be
deleted or listed by the DeleteJob and ListJobs APIs, but it can be retrieved
with the GetJob API or updated with the UpdateJob API. An expired job can be
updated and opened again by using a future expiration timestamp. Updating an
expired job fails if there is another existing open job with same company_name,
language_code and requisition_id. The expired jobs are retained in our system
for 90 days. However, the overall expired job count cannot exceed 3 times the
maximum of open jobs count over the past week, otherwise jobs with earlier
expire time are cleaned first. Expired jobs are no longer accessible after
they are cleaned out. Invalid timestamps are ignored, and treated as expire
time not provided. Timestamp before the instant request is made is considered
valid, the job will be treated as expired immediately. If this value is not
provided at the time of job creation or is invalid, the job posting expires
after 30 days from the job's creation time. For example, if the job was
created on 2017/01/01 13:00AM UTC with an unspecified expiration date, the job
expires after 2017/01/31 13:00AM UTC. If this value is not provided on job
update, it depends on the field masks set by UpdateJobRequest.update_mask. If
the field masks include expiry_time, or the masks are empty meaning that every
field is updated, the job posting expires after 30 days from the job's last
update time. Otherwise the expiration date isn't updated.
Corresponds to the JSON property postingExpireTime
| 1180 1181 1182 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1180 def posting_expire_time @posting_expire_time end | 
#posting_publish_time ⇒ String
Optional. The timestamp this job posting was most recently published. The
default value is the time the request arrives at the server. Invalid
timestamps are ignored.
Corresponds to the JSON property postingPublishTime
| 1187 1188 1189 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1187 def posting_publish_time @posting_publish_time end | 
#posting_region ⇒ String
Optional. The job PostingRegion (for example, state, country) throughout which
the job is available. If this field is set, a LocationFilter in a search query
within the job region finds this job posting if an exact location match isn't
specified. If this field is set to PostingRegion.NATION or PostingRegion.
ADMINISTRATIVE_AREA, setting job Job.addresses to the same location level as
this field is strongly recommended.
Corresponds to the JSON property postingRegion
| 1197 1198 1199 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1197 def posting_region @posting_region end | 
#posting_update_time ⇒ String
Output only. The timestamp when this job posting was last updated.
Corresponds to the JSON property postingUpdateTime
| 1202 1203 1204 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1202 def posting_update_time @posting_update_time end | 
#processing_options ⇒ Google::Apis::JobsV3::ProcessingOptions
Input only. Options for job processing.
Corresponds to the JSON property processingOptions
| 1207 1208 1209 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1207 def @processing_options end | 
#promotion_value ⇒ Fixnum
Optional. A promotion value of the job, as determined by the client. The value
determines the sort order of the jobs returned when searching for jobs using
the featured jobs search call, with higher promotional values being returned
first and ties being resolved by relevance sort. Only the jobs with a
promotionValue >0 are returned in a FEATURED_JOB_SEARCH. Default value is 0,
and negative values are treated as 0.
Corresponds to the JSON property promotionValue
| 1217 1218 1219 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1217 def promotion_value @promotion_value end | 
#qualifications ⇒ String
Optional. A description of the qualifications required to perform the job. The
use of this field is recommended as an alternative to using the more general
description field. This field accepts and sanitizes HTML input, and also
accepts bold, italic, ordered list, and unordered list markup tags. The
maximum number of allowed characters is 10,000.
Corresponds to the JSON property qualifications
| 1226 1227 1228 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1226 def qualifications @qualifications end | 
#requisition_id ⇒ String
Required. The requisition ID, also referred to as the posting ID, assigned by
the client to identify a job. This field is intended to be used by clients for
client identification and tracking of postings. A job is not allowed to be
created if there is another job with the same [company_name], language_code
and requisition_id. The maximum number of allowed characters is 255.
Corresponds to the JSON property requisitionId
| 1235 1236 1237 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1235 def requisition_id @requisition_id end | 
#responsibilities ⇒ String
Optional. A description of job responsibilities. The use of this field is
recommended as an alternative to using the more general description field.
This field accepts and sanitizes HTML input, and also accepts bold, italic,
ordered list, and unordered list markup tags. The maximum number of allowed
characters is 10,000.
Corresponds to the JSON property responsibilities
| 1244 1245 1246 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1244 def responsibilities @responsibilities end | 
#title ⇒ String
Required. The title of the job, such as "Software Engineer" The maximum number
of allowed characters is 500.
Corresponds to the JSON property title
| 1250 1251 1252 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1250 def title @title end | 
#visibility ⇒ String
Deprecated. The job is only visible to the owner. The visibility of the job.
Defaults to Visibility.ACCOUNT_ONLY if not specified.
Corresponds to the JSON property visibility
| 1256 1257 1258 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1256 def visibility @visibility end | 
Instance Method Details
#update!(**args) ⇒ Object
Update properties of this object
| 1263 1264 1265 1266 1267 1268 1269 1270 1271 1272 1273 1274 1275 1276 1277 1278 1279 1280 1281 1282 1283 1284 1285 1286 1287 1288 1289 1290 1291 1292 1293 1294 | # File 'generated/google/apis/jobs_v3/classes.rb', line 1263 def update!(**args) @addresses = args[:addresses] if args.key?(:addresses) @application_info = args[:application_info] if args.key?(:application_info) @company_display_name = args[:company_display_name] if args.key?(:company_display_name) @company_name = args[:company_name] if args.key?(:company_name) @compensation_info = args[:compensation_info] if args.key?(:compensation_info) @custom_attributes = args[:custom_attributes] if args.key?(:custom_attributes) @degree_types = args[:degree_types] if args.key?(:degree_types) @department = args[:department] if args.key?(:department) @derived_info = args[:derived_info] if args.key?(:derived_info) @description = args[:description] if args.key?(:description) @employment_types = args[:employment_types] if args.key?(:employment_types) @incentives = args[:incentives] if args.key?(:incentives) @job_benefits = args[:job_benefits] if args.key?(:job_benefits) @job_end_time = args[:job_end_time] if args.key?(:job_end_time) @job_level = args[:job_level] if args.key?(:job_level) @job_start_time = args[:job_start_time] if args.key?(:job_start_time) @language_code = args[:language_code] if args.key?(:language_code) @name = args[:name] if args.key?(:name) @posting_create_time = args[:posting_create_time] if args.key?(:posting_create_time) @posting_expire_time = args[:posting_expire_time] if args.key?(:posting_expire_time) @posting_publish_time = args[:posting_publish_time] if args.key?(:posting_publish_time) @posting_region = args[:posting_region] if args.key?(:posting_region) @posting_update_time = args[:posting_update_time] if args.key?(:posting_update_time) @processing_options = args[:processing_options] if args.key?(:processing_options) @promotion_value = args[:promotion_value] if args.key?(:promotion_value) @qualifications = args[:qualifications] if args.key?(:qualifications) @requisition_id = args[:requisition_id] if args.key?(:requisition_id) @responsibilities = args[:responsibilities] if args.key?(:responsibilities) @title = args[:title] if args.key?(:title) @visibility = args[:visibility] if args.key?(:visibility) end |