Cloud Talent Solution は、求人検索体験に機械学習を導入するサービスであり、一般的なキーワード ベース方式の制約をはるかに超えた高品質の結果を求職者に返します。 CTS により、関連性モデルと求人 / スキルのオントロジーが、求人情報に自動的に適用されます。求職者の活動に基づいてクライアント イベントを記録することで、求職者に返される結果を改善できます。
createClientEventRequest
を使用してクライアント イベントを記録する
求職者が特定のアクションを行ったときに、求人検索を使用してそのアクションを記録できます。たとえば、求職者やその他のエンティティは、サービスを操作しているときに、検索結果のリストを圧縮したりクリップしたりするなど、求人(または求人リスト)を自分のビューでレンダリングすることがあります。Cloud Talent Solution に IMPRESSION イベントを送信して、検索のコンテキストと求職者に表示される結果を提供できます。また、求職者が求人結果をクリックして詳しい職務内容を表示したときに、VIEW イベントを送信してこの求職者の関心をこの職位に登録できます。
次の例は、この API を使用して、Cloud Talent Solution にメッセージを送信する方法を示しています。求職者や他のエンティティは、サービスを操作しているときに、検索結果のリストを圧縮したりクリップしたりするなど、求人(または求人リスト)を自分のビューにレンダリングすることがあります。このイベントは、一般に求職者による 1 ページでの求人リストの表示に関連付けられます。
Go
CTS 用のクライアント ライブラリをインストールして使用する方法については、CTS クライアント ライブラリをご覧ください。 詳細については、CTS Go API のリファレンス ドキュメントをご覧ください。
CTS への認証を行うには、アプリケーションのデフォルト認証情報を設定します。詳細については、ローカル開発環境の認証の設定をご覧ください。
Java
CTS 用のクライアント ライブラリをインストールして使用する方法については、CTS クライアント ライブラリをご覧ください。 詳細については、CTS Java API のリファレンス ドキュメントをご覧ください。
CTS への認証を行うには、アプリケーションのデフォルト認証情報を設定します。詳細については、ローカル開発環境の認証の設定をご覧ください。
Node.js
CTS 用のクライアント ライブラリをインストールして使用する方法については、CTS クライアント ライブラリをご覧ください。 詳細については、CTS Node.js API のリファレンス ドキュメントをご覧ください。
CTS への認証を行うには、アプリケーションのデフォルト認証情報を設定します。詳細については、ローカル開発環境の認証の設定をご覧ください。
Python
CTS 用のクライアント ライブラリをインストールして使用する方法については、CTS クライアント ライブラリをご覧ください。 詳細については、CTS Python API のリファレンス ドキュメントをご覧ください。
CTS への認証を行うには、アプリケーションのデフォルト認証情報を設定します。詳細については、ローカル開発環境の認証の設定をご覧ください。
イベント メッセージ
必須フィールド:
eventId
(お客様が定義する項目): Cloud Talent Solution に送信される各メッセージには固有のeventId
が必要です。この項目を定義する際は、重複が起こらないようにタイムスタンプを組み込むことをおすすめします。この項目の最大長は 255 文字です。requestId
: 検索レスポンス オブジェクトによって返されたrequestId
の値。この値は、SearchJobsRequest
API 呼び出しごとに固有です。これは、最初の検索の IMPRESSION イベントから派生する後続のすべてのメッセージに使用されます。新しいSearchJobsRequest
API 呼び出しが行われると(たとえば、求職者が次の結果ページに移動した場合)、requestId
は変わります。createTime
: イベントのタイムスタンプ(Timestamp 形式、精度はナノ秒)。このタイムスタンプは、メッセージが送信された時点ではなくイベントが実際に発生した時点を反映します。共用体フィールド
event
:jobEvent
オブジェクトは求人検索機能で使用され、求職者がサービスを操作したときに発行されます。
イベント メッセージの例
上記のコードサンプルの API 呼び出しは、次の形式の JSON メッセージを生成します。
JSON
{ "requestId": string, "eventId": string, "createTime": string, "eventNotes": string,// Union field event can be only be a jobEvent: "jobEvent": { object (JobEvent) }, // End of list of possible types for union field event. }
シナリオとワークフロー
以下では、求職者が求人を検索して表示し、求人に応募する 2 つのシナリオ例を紹介します。
ワークフロー 1
求職者が検索を行います。 たとえば、Product mgr SF です。
検索結果が求職者に返されます。
お客様のサーバーに返される求人検索レスポンス オブジェクトには固有の
requestId
(例:8d2bdd5d-1361-42a5-a0fd-bd2b58b7d8fb:APAb7ISd4Sc5faibw2V5hTU/OoC2WAW5AA==
)が含まれます。このrequestId
は、対応する SearchJobsRequest API 呼び出しに関連する以降のすべてのメッセージに使用します。Cloud Talent Solution に IMPRESSION メッセージを送信します。
イベント メッセージの例:
{ "requestId": "8d2bdd5d-1361-42a5-a0fd-bd2b58b7d8fb:APAb7ISd4Sc5faibw2V5hTU/OoC2WAW5AA==", "eventId": "ID1", "createTime": "2018-12-19T16:39:57-08:00", "jobEvent": {"type":"IMPRESSION", "jobs":["jobs/4000000000", "jobs/4000000001","jobs/4000000002", "jobs/4000000003", "jobs/4000000004"]} }
求職者は結果(求人の投稿)を選択し、その求人の詳細を表示します。
Cloud Talent Solution に VIEW メッセージを送信します。
{ "requestId": "8d2bdd5d-1361-42a5-a0fd-bd2b58b7d8fb:APAb7ISd4Sc5faibw2V5hTU/OoC2WAW5AA==", "eventId": "ID2", "createTime": "2018-12-19T16:40:57-08:00", "jobEvent": {"type":"VIEW", "jobs":["jobs/4000000000"]} }
求職者は表示された求人の投稿に応募します。
a. 求職者が同じドメイン内のページ(内部の応募ページ)にリダイレクトされた場合は、Cloud Talent Solution に APPLICATION_START メッセージを送信します。
{ "requestId": "8d2bdd5d-1361-42a5-a0fd-bd2b58b7d8fb:APAb7ISd4Sc5faibw2V5hTU/OoC2WAW5AA==", "eventId": "ID3", "createTime": "2018-12-19T16:41:57-08:00", "jobEvent": {"type":"APPLICATION_START", "jobs":["jobs/4000000000"]} }
b. 求職者が外部の応募ページにリダイレクトされた場合は、Cloud Talent Solution に APPLICATION_REDIRECT メッセージを送信します。
{ "requestId": "8d2bdd5d-1361-42a5-a0fd-bd2b58b7d8fb:APAb7ISd4Sc5faibw2V5hTU/OoC2WAW5AA==", "eventId": "ID3", "createTime": "2018-12-19T16:41:57-08:00", "jobEvent": {"type":"APPLICATION_REDIRECT", "jobs":["jobs/4000000000"]} }
求職者が内部の応募を完了したら、Cloud Talent Solution に APPICATION_FINISH メッセージを送信します。
{ "requestId": "8d2bdd5d-1361-42a5-a0fd-bd2b58b7d8fb:APAb7ISd4Sc5faibw2V5hTU/OoC2WAW5AA==", "eventId": "ID4", "createTime": "2018-12-19T16:43:57-08:00", "jobEvent": {"type":"APPLICATION_FINISH", "jobs":["jobs/4000000000"]} }
求職者は検索結果に戻り、引き続き 2 ページ目に進みます(または、求人の投稿をクリックせずに 2 ページ目に進みます)。
2 ページ目に表示される次の結果セットで Cloud Talent Solution に IMPRESSION メッセージを送信します。注: 2 ページ目の結果を生成する
SearchJobsRequest
API 呼び出しのレスポンスでは、新しいrequestId
が生成されています(例:99e5b99c-f1ba-4f85-b17d-ccf878f451f9:APAb7IRESj+/Hzwa3bBd54P3qPx2yOWm5w==
)。{ "requestId": "99e5b99c-f1ba-4f85-b17d-ccf878f451f9:APAb7IRESj+/Hzwa3bBd54P3qPx2yOWm5w==", "eventId": "ID5", "createTime": "2018-12-19T18:39:57-08:00", "jobEvent": {"type":"IMPRESSION", "jobs":["jobs/4000000005", "jobs/4000000006","jobs/4000000007", "jobs/4000000008", "jobs/4000000009"]} }
求職者は引き続き 3 ページ目の検索結果を表示します。
次の結果セットで Cloud Talent Solution に IMPRESSION メッセージを送信します。 注: 新しい
requestId
(e2d2b916-78c3-4c65-aecc-d8452bc0afb0:APAb7IRvCsNPiRXYkgF8PN5e8BkbFzKOyg==
など)があります。{ "requestId": "e2d2b916-78c3-4c65-aecc-d8452bc0afb0:APAb7IRvCsNPiRXYkgF8PN5e8BkbFzKOyg==", "eventId": "ID6", "createTime": "2018-12-19T16:41:57-08:00", "jobEvent": {"type":"IMPRESSION", "jobs":["jobs/4000000010", "jobs/4000000011","jobs/4000000012", "jobs/400000013", "jobs/4000000014"]} }
ワークフロー 2
求職者が検索を行います。 たとえば、Product mgr SF です。
検索結果が求職者に返されます。
求人検索レスポンス オブジェクトには、固有の
requestId
(例:a2179a9b-cf73-413e-8076-98af08b991ad
)が含まれています。このrequestId
は、このSearchJobsRequest
API 呼び出しに関連する以降のすべてのメッセージに使用します。Cloud Talent Solution に IMPRESSION メッセージを送信します。
{ "requestId": "a2179a9b-cf73-413e-8076-98af08b991ad", "eventId": "ID1", "createTime": "2018-12-19T16:39:57-08:00", "jobEvent": {"type":"IMPRESSION", "jobs":["jobs/4000000000", "jobs/4000000001","jobs/4000000002", "jobs/4000000003", "jobs/4000000004"]} }
求職者は結果(求人の投稿)を選択し、その求人の詳細を表示します。
Cloud Talent Solution に VIEW メッセージを送信します。
{ "requestId": "8d2bdd5d-1361-42a5-a0fd-bd2b58b7d8fb:APAb7ISd4Sc5faibw2V5hTU/OoC2WAW5AA==", "eventId": "ID2", "createTime": "2018-12-19T16:40:57-08:00", "jobEvent": {"type":"VIEW", "jobs":["jobs/4000000000"]} }
求職者は、APPLICATION_QUICK_SUBMISSION に概要が示されているように、1 回のクリックで求人に応募します。
次の結果セットで Cloud Talent Solution に APPLICATION_QUICK_SUBMISSION メッセージを送信します。
{ "requestId": "8d2bdd5d-1361-42a5-a0fd-bd2b58b7d8fb:APAb7ISd4Sc5faibw2V5hTU/OoC2WAW5AA==", "eventId": "ID3", "createTime": "2018-12-19T16:41:57-08:00", "jobEvent": {"type":"APPLICATION_QUICK_SUBMISSION", "jobs":["jobs/4000000000"]} }
求職者は以下の行動をとります。
a. 求職者は検索結果に戻り、検索結果ページから直接求人に応募します。この応募プロセスは APPLICATION_QUICK_SUBMISSION に定義されているものより時間のかかるプロセスです(複数ステップの応募プロセスであるためです)。
Cloud Talent Solution に APPLICATION_START_FROM_SERP メッセージを送信します。
{ "requestId": "8d2bdd5d-1361-42a5-a0fd-bd2b58b7d8fb:APAb7ISd4Sc5faibw2V5hTU/OoC2WAW5AA==", "eventId": "ID4", "createTime": "2018-12-19T16:43:57-08:00", "jobEvent": {"type":"APPLICATION_START_FROM_SERP", "jobs":["jobs/4000000000"]} }
b. 求職者は求人への応募を完了します。 Cloud Talent Solution に APPLICATION_FINISH メッセージを送信します。
{ "requestId": "8d2bdd5d-1361-42a5-a0fd-bd2b58b7d8fb:APAb7ISd4Sc5faibw2V5hTU/OoC2WAW5AA==", "eventId": "ID5", "createTime": "2018-12-19T16:44:57-08:00", "jobEvent": {"type":"APPLICATION_FINISH", "jobs":["jobs/4000000000"]} }
求職者は検索結果に戻り、検索結果ページから直接求人に応募します。この応募プロセスでは求職者がテナントサイトの外部にある別のドメイン(外部の応募)にリダイレクトされます。これ以降、その応募者の進行状況はトラッキングできません。
Cloud Talent Solution に APPLICATION_REDIRECT_FROM_SERP メッセージを送信します。
{ "requestId": "8d2bdd5d-1361-42a5-a0fd-bd2b58b7d8fb:APAb7ISd4Sc5faibw2V5hTU/OoC2WAW5AA==", "eventId": "ID6", "createTime": "2018-12-19T16:45:57-08:00", "jobEvent": {"type":"APPLICATION_START_FROM_SERP", "jobs":["jobs/4000000001"]} }
これは、求職者が再ルーティングされる際に求人の説明ページを表示している APPLICATION_REDIRECT とは異なります。
クライアント イベントの実装を検証する
Cloud Talent Solution には、クライアント イベントの実装を検証できるセルフサービス ツールが用意されています。利用可能なセルフサービス オプションの詳細については、管理ツールをご覧ください。