4
1

【UiPath】タイムトリガーの情報をAPIで取得する

Last updated at Posted at 2024-07-19

はじめに

  • 本記事では、OCのタイムトリガーの情報をWebAPIで操作する方法を紹介します。
  • 記事の内容は、個人の見解または確認結果であり、UiPath の公式見解ではありません。
  • 製品仕様や参考画像は 23.10 バージョンのもので構成しています。

OC Manager だとスケジュールはCRON式しかとれない。。。

↑↑こんなお悩みをお持ちの方向けの実装サンプル(WebAPI をもちいた専用ロボ)を紹介します。
サンプルはタイムトリガーの情報を取得する内容ですが、エンドポイントや設定を少し変えるだけで様々な自動化に応用できます。

OCのUIアクセスは制限しているが、ジョブのスケジュール(タイムトリガーの設定)は最新のものをユーザーに参照させたいケースなどで役に立ちます!

実装サンプル

まず、WebAPIでOCにアクセスするために、外部アプリケーションを登録しましょう!以下は参考

トリガーの有効無効操作1.JPG

➀:上で作成した外部アプリケーションの「アプリID」と「シークレットの値」を Credential型のアセットとして登録し、「資格情報を取得」アクティビティを配置して呼び出します。(出力変数には「client_id」と「client_secret」を設定)

➁:「HTTP要求」アクティビティを配置し、次の内容を設定します。

  • 本文形式:application/x-www-form-urlencoded
  • パラメーター>grant_type:"client_credentials"
  • パラメーター>client_id:client_id
  • パラメーター>client_secret:new System.Net.NetworkCredential("",client_secret).Password
  • パラメーター>scope:{★外部アプリケーションで許可したスコープ} (例)"OR.Jobs OR.Jobs.Read"
  • 要求URL:"https://cloud.uipath.com/identity_/connect/token"
  • 要求メソッド:POST
  • 応答コンテンツ:応答コンテンツ
  • 応答ステータス:ステータスコード

トリガーの有効無効操作2.JPG

➂:「JSON を逆シリアル化」アクティビティを配置し、次の内容を設定します。

  • JSON文字列:応答コンテンツ
  • 出力>JSONオブジェクト:応答コンテンツのJオブジェクト

➃:「代入」アクティビティを配置し、次の内容を設定します。

  • 左辺:アクセストークン
  • 右辺:応答コンテンツのJオブジェクト("access_token").ToString

トリガー情報取得1.JPG

➄:「HTTP要求」アクティビティを配置し、次の内容を設定します。

「JSONを逆シリアル化」アクティビティで『応答コンテンツのJオブジェクト(JObject)』を作成します。

トリガー情報取得2.JPG

次の様に入出力を設定します↓↓
入力:
応答コンテンツのJオブジェクト.Properties.ElementAt(2).Value.ToString
出力:
JSON配列のオブジェクト(JArray)

(JSON配列のオブジェクト(JArray)の繰り返し)
トリガー情報取得3.JPG

トリガー情報の補完例

  • トリガーの表示名称 = currentArrayItem.Item("Name").ToString
  • CRON式の設定概要 = currentArrayItem.Item("StartProcessCronSummary").ToString
  • トリガーID = currentArrayItem.Item("Id").ToString
  • 有効無効 = currentArrayItem.Item("Enabled").ToString
## 参考:フィールド名と値のサンプル
   ""Key"": ""789c346e-efa9-477a-ad46-533d15d12e6f"",
   ""Enabled"": false,
   ""Name"": ""テスト"",
   ""ReleaseId"": 594227,
   ""ReleaseKey"": ""37b7a354-288e-44ef-8ad0-0e02dcebbdd6"",
   ""ReleaseName"": ""待機時間コントロール"",
   ""PackageName"": ""待機時間コントロール"",
   ""EnvironmentName"": null,
   ""EnvironmentId"": """",
   ""JobPriority"": null,
   ""SpecificPriorityValue"": null,
   ""RuntimeType"": ""Unattended"",
   ""StartProcessCron"": ""0 0/5 * 1/1 * ? *"",
   ""StartProcessCronDetails"": ""{\""type\"":0,\""minutely\"":{\""atMinute\"":5},\""hourly\"":{},\""daily\"":{},\""weekly\"":{\""weekdays\"":[]},\""monthly\"":{\""weekdays\"":[]},\""advancedCronExpression\"":\""\""}"",
   ""StartProcessCronSummary"": ""Every 5 minutes"",
   ""StartProcessNextOccurrence"": null,
   ""StartStrategy"": 1,
   ""StopProcessExpression"": """",
   ""StopStrategy"": null,
   ""KillProcessExpression"": null,
   ""ExternalJobKey"": null,
   ""ExternalJobKeyScheduler"": ""69d4d92a-0e8c-0100-6340-0b43f321794b"",
   ""TimeZoneId"": ""UTC"",
   ""TimeZoneIana"": ""UTC"",
   ""UseCalendar"": false,
   ""CalendarId"": null,
   ""CalendarName"": null,
   ""CalendarKey"": null,
   ""StopProcessDate"": null,
   ""InputArguments"": ""{\""繰り返し回数\"":10,\""指定経過時間_分\"":3}"",
   ""QueueDefinitionId"": null,
   ""QueueDefinitionName"": null,
   ""ActivateOnJobComplete"": null,
   ""ItemsActivationThreshold"": 1,
   ""ItemsPerJobActivationTarget"": 1,
   ""MaxJobsForActivation"": 2,
   ""ResumeOnSameContext"": false,
   ""Description"": null,
   ""AlertPendingExpression"": null,
   ""AlertRunningExpression"": null,
   ""RunAsMe"": false,
   ""ConsecutiveJobFailuresThreshold"": 0,
   ""JobFailuresGracePeriodInHours"": 0,
   ""IsConnected"": false,
   ""Id"": 132887,
   ""MachineRobots"": [
     {
       ""MachineId"": 1808144,
       ""MachineName"": ""URテスト"",
       ""RobotId"": 711192,
       ""RobotUserName"": null,
       ""SessionId"": 11364007,
       ""SessionName"": null
     }

(出力例)
トリガー情報取得4.JPG

さいごに

いかがでしたでしょうか。
WebAPI をつかった自動化は、必要な情報さえあれば実装は容易ですし、処理も安定しやすいので、ニーズがありそうな際は是非上を参考に試してみていただければとおもいます。
最後までお読みいただきありがとうございます!(・ω・)ノ

関連記事

4
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
1