Class Job
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.
Implements
Inherited Members
Namespace: Google.Apis.CloudTalentSolution.v3.Data
Assembly: Google.Apis.CloudTalentSolution.v3.dll
Syntax
public class Job : IDirectResponseSchema
Properties
Addresses
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. Jobs with multiple addresses must have their addresses with the same LocationType to allow location filtering to work properly. (For example, a Job with addresses "1600 Amphitheatre Parkway, Mountain View, CA, USA" and "London, UK" may not have location filters applied correctly at search time since the first is a LocationType.STREET_ADDRESS and the second is a LocationType.LOCALITY.) If a job needs to have multiple addresses, it is suggested to split it into multiple jobs with same LocationTypes. The maximum number of allowed characters is 500.
Declaration
[JsonProperty("addresses")]
public virtual IList<string> Addresses { get; set; }
Property Value
Type | Description |
---|---|
IList<string> |
ApplicationInfo
Required. At least one field within ApplicationInfo must be specified. Job application information.
Declaration
[JsonProperty("applicationInfo")]
public virtual ApplicationInfo ApplicationInfo { get; set; }
Property Value
Type | Description |
---|---|
ApplicationInfo |
CompanyDisplayName
Output only. Display name of the company listing the job.
Declaration
[JsonProperty("companyDisplayName")]
public virtual string CompanyDisplayName { get; set; }
Property Value
Type | Description |
---|---|
string |
CompanyName
Required. The resource name of the company listing the job, such as "projects/api-test-project/companies/foo".
Declaration
[JsonProperty("companyName")]
public virtual string CompanyName { get; set; }
Property Value
Type | Description |
---|---|
string |
CompensationInfo
Optional. Job compensation information.
Declaration
[JsonProperty("compensationInfo")]
public virtual CompensationInfo CompensationInfo { get; set; }
Property Value
Type | Description |
---|---|
CompensationInfo |
CustomAttributes
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.
Declaration
[JsonProperty("customAttributes")]
public virtual IDictionary<string, CustomAttribute> CustomAttributes { get; set; }
Property Value
Type | Description |
---|---|
IDictionary<string, CustomAttribute> |
DegreeTypes
Optional. The desired education degrees for the job, such as Bachelors, Masters.
Declaration
[JsonProperty("degreeTypes")]
public virtual IList<string> DegreeTypes { get; set; }
Property Value
Type | Description |
---|---|
IList<string> |
Department
Optional. The department or functional area within the company with the open position. The maximum number of allowed characters is 255.
Declaration
[JsonProperty("department")]
public virtual string Department { get; set; }
Property Value
Type | Description |
---|---|
string |
DerivedInfo
Output only. Derived details about the job posting.
Declaration
[JsonProperty("derivedInfo")]
public virtual JobDerivedInfo DerivedInfo { get; set; }
Property Value
Type | Description |
---|---|
JobDerivedInfo |
Description
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.
Declaration
[JsonProperty("description")]
public virtual string Description { get; set; }
Property Value
Type | Description |
---|---|
string |
ETag
The ETag of the item.
Declaration
public virtual string ETag { get; set; }
Property Value
Type | Description |
---|---|
string |
EmploymentTypes
Optional. The employment type(s) of a job, for example, full time or part time.
Declaration
[JsonProperty("employmentTypes")]
public virtual IList<string> EmploymentTypes { get; set; }
Property Value
Type | Description |
---|---|
IList<string> |
Incentives
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.
Declaration
[JsonProperty("incentives")]
public virtual string Incentives { get; set; }
Property Value
Type | Description |
---|---|
string |
JobBenefits
Optional. The benefits included with the job.
Declaration
[JsonProperty("jobBenefits")]
public virtual IList<string> JobBenefits { get; set; }
Property Value
Type | Description |
---|---|
IList<string> |
JobEndTime
object representation of JobEndTimeRaw.
Declaration
[JsonIgnore]
[Obsolete("This property is obsolete and may behave unexpectedly; please use JobEndTimeDateTimeOffset instead.")]
public virtual object JobEndTime { get; set; }
Property Value
Type | Description |
---|---|
object |
JobEndTimeDateTimeOffset
DateTimeOffset representation of JobEndTimeRaw.
Declaration
[JsonIgnore]
public virtual DateTimeOffset? JobEndTimeDateTimeOffset { get; set; }
Property Value
Type | Description |
---|---|
DateTimeOffset? |
JobEndTimeRaw
Optional. The end timestamp of the job. Typically this field is used for contracting engagements. Invalid timestamps are ignored.
Declaration
[JsonProperty("jobEndTime")]
public virtual string JobEndTimeRaw { get; set; }
Property Value
Type | Description |
---|---|
string |
JobLevel
Optional. The experience level associated with the job, such as "Entry Level".
Declaration
[JsonProperty("jobLevel")]
public virtual string JobLevel { get; set; }
Property Value
Type | Description |
---|---|
string |
JobStartTime
object representation of JobStartTimeRaw.
Declaration
[JsonIgnore]
[Obsolete("This property is obsolete and may behave unexpectedly; please use JobStartTimeDateTimeOffset instead.")]
public virtual object JobStartTime { get; set; }
Property Value
Type | Description |
---|---|
object |
JobStartTimeDateTimeOffset
DateTimeOffset representation of JobStartTimeRaw.
Declaration
[JsonIgnore]
public virtual DateTimeOffset? JobStartTimeDateTimeOffset { get; set; }
Property Value
Type | Description |
---|---|
DateTimeOffset? |
JobStartTimeRaw
Optional. The start timestamp of the job in UTC time zone. Typically this field is used for contracting engagements. Invalid timestamps are ignored.
Declaration
[JsonProperty("jobStartTime")]
public virtual string JobStartTimeRaw { get; set; }
Property Value
Type | Description |
---|---|
string |
LanguageCode
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'.
Declaration
[JsonProperty("languageCode")]
public virtual string LanguageCode { get; set; }
Property Value
Type | Description |
---|---|
string |
Name
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.
Declaration
[JsonProperty("name")]
public virtual string Name { get; set; }
Property Value
Type | Description |
---|---|
string |
PostingCreateTime
object representation of PostingCreateTimeRaw.
Declaration
[JsonIgnore]
[Obsolete("This property is obsolete and may behave unexpectedly; please use PostingCreateTimeDateTimeOffset instead.")]
public virtual object PostingCreateTime { get; set; }
Property Value
Type | Description |
---|---|
object |
PostingCreateTimeDateTimeOffset
DateTimeOffset representation of PostingCreateTimeRaw.
Declaration
[JsonIgnore]
public virtual DateTimeOffset? PostingCreateTimeDateTimeOffset { get; set; }
Property Value
Type | Description |
---|---|
DateTimeOffset? |
PostingCreateTimeRaw
Output only. The timestamp when this job posting was created.
Declaration
[JsonProperty("postingCreateTime")]
public virtual string PostingCreateTimeRaw { get; set; }
Property Value
Type | Description |
---|---|
string |
PostingExpireTime
object representation of PostingExpireTimeRaw.
Declaration
[JsonIgnore]
[Obsolete("This property is obsolete and may behave unexpectedly; please use PostingExpireTimeDateTimeOffset instead.")]
public virtual object PostingExpireTime { get; set; }
Property Value
Type | Description |
---|---|
object |
PostingExpireTimeDateTimeOffset
DateTimeOffset representation of PostingExpireTimeRaw.
Declaration
[JsonIgnore]
public virtual DateTimeOffset? PostingExpireTimeDateTimeOffset { get; set; }
Property Value
Type | Description |
---|---|
DateTimeOffset? |
PostingExpireTimeRaw
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.
Declaration
[JsonProperty("postingExpireTime")]
public virtual string PostingExpireTimeRaw { get; set; }
Property Value
Type | Description |
---|---|
string |
PostingPublishTime
object representation of PostingPublishTimeRaw.
Declaration
[JsonIgnore]
[Obsolete("This property is obsolete and may behave unexpectedly; please use PostingPublishTimeDateTimeOffset instead.")]
public virtual object PostingPublishTime { get; set; }
Property Value
Type | Description |
---|---|
object |
PostingPublishTimeDateTimeOffset
DateTimeOffset representation of PostingPublishTimeRaw.
Declaration
[JsonIgnore]
public virtual DateTimeOffset? PostingPublishTimeDateTimeOffset { get; set; }
Property Value
Type | Description |
---|---|
DateTimeOffset? |
PostingPublishTimeRaw
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.
Declaration
[JsonProperty("postingPublishTime")]
public virtual string PostingPublishTimeRaw { get; set; }
Property Value
Type | Description |
---|---|
string |
PostingRegion
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.
Declaration
[JsonProperty("postingRegion")]
public virtual string PostingRegion { get; set; }
Property Value
Type | Description |
---|---|
string |
PostingUpdateTime
object representation of PostingUpdateTimeRaw.
Declaration
[JsonIgnore]
[Obsolete("This property is obsolete and may behave unexpectedly; please use PostingUpdateTimeDateTimeOffset instead.")]
public virtual object PostingUpdateTime { get; set; }
Property Value
Type | Description |
---|---|
object |
PostingUpdateTimeDateTimeOffset
DateTimeOffset representation of PostingUpdateTimeRaw.
Declaration
[JsonIgnore]
public virtual DateTimeOffset? PostingUpdateTimeDateTimeOffset { get; set; }
Property Value
Type | Description |
---|---|
DateTimeOffset? |
PostingUpdateTimeRaw
Output only. The timestamp when this job posting was last updated.
Declaration
[JsonProperty("postingUpdateTime")]
public virtual string PostingUpdateTimeRaw { get; set; }
Property Value
Type | Description |
---|---|
string |
ProcessingOptions
Optional. Options for job processing.
Declaration
[JsonProperty("processingOptions")]
public virtual ProcessingOptions ProcessingOptions { get; set; }
Property Value
Type | Description |
---|---|
ProcessingOptions |
PromotionValue
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.
Declaration
[JsonProperty("promotionValue")]
public virtual int? PromotionValue { get; set; }
Property Value
Type | Description |
---|---|
int? |
Qualifications
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.
Declaration
[JsonProperty("qualifications")]
public virtual string Qualifications { get; set; }
Property Value
Type | Description |
---|---|
string |
RequisitionId
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.
Declaration
[JsonProperty("requisitionId")]
public virtual string RequisitionId { get; set; }
Property Value
Type | Description |
---|---|
string |
Responsibilities
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.
Declaration
[JsonProperty("responsibilities")]
public virtual string Responsibilities { get; set; }
Property Value
Type | Description |
---|---|
string |
Title
Required. The title of the job, such as "Software Engineer" The maximum number of allowed characters is 500.
Declaration
[JsonProperty("title")]
public virtual string Title { get; set; }
Property Value
Type | Description |
---|---|
string |
Visibility
Deprecated. The job is only visible to the owner. The visibility of the job. Defaults to Visibility.ACCOUNT_ONLY if not specified.
Declaration
[JsonProperty("visibility")]
public virtual string Visibility { get; set; }
Property Value
Type | Description |
---|---|
string |