Kintoneにて、同一アプリ内の2テーブルで添付ファイルの同期を行うことを考えています。
テーブル1に、ファイルを添付した状態のレコードを追加し、そのデータをテーブル2にコピーしたいです。
レコード追加時にイベントを発火させることができ、追加されたレコードのデータを取得できるので、そのデータを成形し、テーブル2にコピーするところまではうまくいくのですが、添付ファイルをどうしてもコピー出来ません。
添付ファイルにはレコード追加用のfilekeyとダウンロード用のfilekeyが割り当てられており、添付ファイルは一度Kintoneサーバーにアップロードされ、アップロード用のfilekeyを取得し、そのkeyをレコードに関連付けして添付ファイルとして保存されるような流れなのですが、イベント発火時に取得できるデータに含まれてるのはダウンロード用のものです。テーブル2にコピーするには、ここからアップロード用のfilekeyを取得し、それをコピー先のレコードに登録しなければいけません。なので私は、ここの処理に
0. レコードをテーブル2にコピー
0. 添付ファイルが存在していたら下の処理を、なかったら終了
0. ダウンロード用のkeyを取得し、ブラウザ内で添付ファイルのblobデータをダウンロード
0. ダウンロードしたblobを再度アップロードし、アップロード用のfilekeyを取得
0. filekeyをコピー先レコードに関連付けし更新
この流れで処理を進めているのですが、ファイルのblobを取得する時点でうまく動きません。
Promiseやコールバックなどを活用してはいるつもりですが、理解度が浅くうまく使えていないのか非同期処理の終了を待たずにブラウザの画面が遷移して処理が止まってしまいます。
そのためテーブル2には添付ファイルだけがないレコードがコピーされた状態になってしまっています。どうすれば解決できますでしょうか
あなたの回答
tips
プレビュー