◇はじめに
本記事はRPA Advent Calendar 2024 7日目の記事になります。
今回は、kintoneアドカレで作成した以下の記事をベースにし、iPhoneのオートメーション機能も活用して、kintoneへのデータ自動登録アプリを追加していきます。
仮のユースケースとして、出退勤のタイムカード打刻を自動化するシステムをつくってみます。
◇最終的にできたもの(イメージ図)
下の画像がイメージ図となります。
社員が出社して会社支給のiPhoneが社内Wi-Fiにつながったことをトリガとして、kintone上にあらかじめつくっておいたタイムカードアプリに出勤レコードを登録します。
逆にWi-Fiの接続が切れた場合は退勤レコードを登録するといった流れになります。

◇環境等
- 使用デバイス
- iPhone SE3
- OS:iOS18.1
- WindowsPC
- Windows 11
- iPhone SE3
- 使用アプリ
- ショートカットアプリ
- 使用ツール・サービス
- Edge
- kintone(PCブラウザ経由)
- (kintone開発者ライセンスを使用)
アプリ設計
今回つくるアプリ間の関係をイメージしてみます。
まず、メインとなるタイムカードアプリが必要になります。
タイムカードアプリでは、
- 打刻日時
- 出退勤のステータス(出勤or退勤)
- 従業員情報
あたりが最低限必要になると想定されます。
この際、従業員情報は別テーブルで持っていたほうがいいので、従業員マスタは別に作ることにします。
また、今回はiPhoneから自動でタイムカードの打刻レコードを登録する予定です。
iPhone側で従業員情報を持たせてもいいのですが、iPhoneの端末毎の固有IDからレコード登録時に従業員情報を取り出す仕組みにしたいと考え、端末マスタを別に持たせることとしました。
これらを踏まえて、簡易的なER図を描いてみました。
※あくまで設計時点のイメージ図で、kintoneでの実装はこれとは一致していませんので注意

◇実装手順
- マスタテーブル用のkintoneアプリ作成
- タイムカードkintoneアプリ作成&REST API用のトークン発行
- Postmanを使ったREST APIの動作確認
- iPhoneショートカットの作成
- iPhoneオートメーションの作成
の順で記載していきます。
マスタテーブル用のkintoneアプリ作成
最初に、従業員マスタと端末マスタ用のアプリをつくっていきます。
2つのアプリの作る順序ですが、端末マスタから従業員マスタの情報を参照する形になりますので、先に従業員マスタからつくっていきます。
従業員マスタについては、サンプルアプリの中に「従業員名簿」アプリを含む「人事労務パック」があるため、こちらを使用します。
アプリ作成を選択し、「人事労務パック」を選択します。
「サンプルデータを含める」のチェックが入っていることを確認し、アプリパックを追加します。


アプリを開くと、架空の従業員情報が入っていることが確認できます。

次に、端末マスタ用のアプリをつくります。
こちらは、流用できそうなサンプルアプリが見つからなかったため、「はじめから作成」を行います。
下のように、4つのフィールドを配置しています。



従業員名フィールドには、ルックアップを設定し、先ほど追加した[従業員マスタ] - [氏名]のフィールドと紐づけます。

ルックアップの設定方法については、公式ヘルプを参考にしてください。
アプリを公開したら、サンプルデータとして何件かデータを入力しておきます。(今回は3件入力)
従業員名は従業員マスタから好きな名前を選択します。

タイムカードkintoneアプリ作成&REST API用のトークン発行
次に、タイムカードアプリをつくっていきます。
こちらもサンプルアプリ内に「タイムカード」アプリがあるため、とりあえずこちらを使って必要に応じてカスタマイズしていきます。


サンプルアプリのフォームを確認してみます。

このアプリでは、出勤時刻と退勤時刻を同時に入力し、さらにプロセス管理で承認フローも行う仕様となっています。
この中で、今回のアプリでは必要ない
- 承認者フィールド
- 退勤時刻フィールド
- 勤務時間フィールド
- レコードタイトル
を削除します。
このとき、「承認者フィールド」については、プロセス管理でフィールドが使用されているため、そのままだと削除できません。
そのため、まず[設定] - [プロセス管理]から、承認者フィールドが入ってる箇所を削除します。


最後にプロセス管理を無効にしたら、改めて不要なフィールドを削除します。

フィールドを削除したら、今回のアプリで必要なフィールドを新規追加します。
- 時刻フィールド(出勤時刻フィールドの名前変更で対応)
- 出退勤ステータス
- 端末ホスト名
- 従業員名

出退勤ステータスフィールドについては、ドロップダウンを使用しています。

端末ホスト名フィールドは先ほど作成した端末マスタからドロップダウンで紐づけます。
その際、従業員名のフィールドもコピーします。

ここまででフォームの配置が完了したので、レコード一覧の表示形式も変更します。
今回は、以下のように配置しています。

ここまででアプリができましたので、最後にAPIトークンを発行して保存します。

Postmanを使ったREST APIの動作確認
前回の記事と同じ手順でレコードの登録を試します。
APIトークンやAppIDの変数の値を変更し、リクエストのボディの中身を今回の実装に合わせてデータを送信したところ、エラーが発生しました。
{
"code": "xxxxx",
"id": "xxxxx",
"message": "フィールド「端末ホスト名」の値「社用スマホ1号」が、ルックアップの参照先のフィールドにないか、またはアプリやフィールドの閲覧権限がありません。"
}
エラーログを見ると、ルックアップの参照先のフィールドにない
といった記載があります。
このログを調べたところ、以下の公式ドキュメントに記載がありました。
複数のAPIトークンを指定すると、ルックアップフィールドがあるアプリで、ルックアップ元のアプリの値をコピーしてレコードを登録できます。
複数のAPIトークンを指定するには、カンマ区切り、または別のヘッダーでAPIトークンを指定します。
1回のリクエストで指定できるAPIトークンは9個までです。10個以上指定すると、エラーになります。
公式ドキュメントを読むと、ルックアップフィールドがある場合、ルックアップ元(今回の場合は端末マスタ)のレコードに対する参照権限が必要であり、そのためのAPIトークン(端末マスタアプリ側で発行)が必要ということがわかりました。
そこで、端末マスタアプリでも同様にAPIトークン(こちらは閲覧権限のみでOK)を発行し、トークンを結合します。
Postman上では、2個目のトークン用の変数を追加し、呼び出す際に2つの変数をカンマ区切りで結合しています。


改めてリクエストを実行すると、問題なくレコードが追加されました。
iPhoneショートカットの作成
Postmanを使ったレコード登録ができたので、続いてiPhoneショートカットを作成します。
基本的な手順は前回と同じため、詳細は省略しますが、今回端末固有の情報を取るためのアクションを使う必要があります。
当初予定では、端末固有のIDなどを取得する予定でしたが、それらを取得する方法が見つけられなかったため、今回はデバイス名を取得する形としました。


record
には、端末ホスト名
に先ほど取得したホスト名、出退勤ステータス
には、出勤or退勤の文字列を入力します。

ショートカットが作成できたら、試してみます。
その際の注意点として、iPhoneの設定から端末の名前を先ほどkintoneの端末マスタに登録した端末ホスト名と一致させておきます。
※iPhoneの名前を変えたくない場合は、kintoneの端末マスタにiPhoneの端末名を新規レコードとして追加する形でもOK
ショートカットを実行して、kintoneのレコードが新規追加されていればOKです。
ちなみに、初めてショートカットを実行した場合は以下の確認画面が出ることがあります。
常に許可を選択すればその後は確認画面は出てきません(1度だけ許可の場合はその都度表示されます)。

ショートカットを作ったら、そのショートカットを複製してもう一つショートカットを作成します。
最初に出勤用のショートカットを作成した場合、つぎは退勤用のショートカットを作成します。
「ショートカット名」と出退勤ステータス
に入力するテキストを修正し保存します。

iPhoneオートメーションの作成
ここまでで、iPhoneショートカット機能を使ってkintoneのタイムカードアプリにデータを追加できるようになったので、次にオートメーション機能を使って自動化します。
オートメーションの概要は公式のユーザーガイドをご覧ください。
iPhoneオートメーションの使い方については以前に別記事でも手順を載せているので、こちらも参考にしてもらええればと思います。
出退勤を模擬するため、会社に到着した条件でオートメーションを動かす形にしたかったので、今回は特定のWi-Fiへの接続時をトリガとしてオートメーションを動かす形としました。
このほか、GPSを使った方法もありましたが、動作確認する際に手間がかかるので、今回は見送ってます。
オートメーションの中から、Wi-Fi
を選択し、ネットワークの中から特定のSSIDを選択します。
接続時は出勤用ショートカットを実行するように選択して完了ボタンを選択します。

同様に、、Wi-Fi
接続解除時は退勤用のショートカットを実行するオートメーションを作成します。

これでタイムカード打刻自動化の準備ができたので実際に動作確認してみます。
◇動作確認
動作確認は単純にオートメーションで設定したWi-Fiへつないだり、接続を切ってみるだけです。
もちろんWi-Fiの接続を切った場合はLTE回線等でインターネットアクセスができないとオートメーションは失敗します。
Wi-Fi接続時or接続解除時のタイミングで画面の上部にオートメーション実行中のテキストが表示されます。

しばらくすると、画面上にレスポンス結果が表示されるので、完了をタップします。

Wi-Fi接続、Wi-Fi接続解除後にそれぞれ完了画面が表示されるのを確認し、kintoneのレコード一覧に出勤と退勤のレコードが追加されていればOKです。

◇おわりに
前回の記事をベースにkintoneのタイムカードアプリの打刻の自動化をしてみました。
そのままこのアプリが使えるユースケースはなかなかないかもしれませんが、自動化の一例として参考になれば幸いです。
このあともRPA Advent Calendar 2024は続いていくので、ぜひほかの記事もご覧ください。