Box: ファイル削除 (Box: Delete File)
Box 上のファイルを削除します。一度に複数の削除が可能です。複数削除する場合、データ項目では1行につき1つずつIDを書くようにしてください。
Configs:共通設定
  • 工程名
  • メモ
Configs
  • C1: OAuth2 設定 *
  • C2: 削除するファイル ID が保存されているデータ項目 *
Script (click to open)

main();
function main(){
  const fileIds = engine.findDataByNumber(configs.get("conf_FileIds"));
  if (fileIds === "" ||fileIds === null){
    throw "File IDs aren't set.";
  }

  let linesArray = fileIds.split("\n");
  linesArray = linesArray.filter(lines => lines !== ""); // 空文字列を削除
  if (linesArray.length === 0) {
    throw "File IDs aren't set.";
  }

  const numOfLines = linesArray.length;
  if (numOfLines > httpClient.getRequestingLimit()){
  	throw "Number of File IDs is over the limit."
  }
  const oauth2 = configs.get("conf_OAuth2");
  for (let i = 0; i < numOfLines; i++){
    deleteFile(oauth2, linesArray[i])
  }
}

function deleteFile(oauth2, fileId) {
  const url = `https://api.box.com/2.0/files/${fileId}`;

  const response = httpClient.begin()
    .authSetting(oauth2)
    .delete(url);
    
  const status = response.getStatusCode();
  const responseTxt = response.getResponseAsString();
  engine.log(`status: ${status}`);
  if (status >= 300) {
    engine.log(responseTxt)
    throw `Failed to delete File ID:${fileId}`;
  }else{
    engine.log(`Succeeded to delete File ID:${fileId}`);
  }
}

Notes

  • ファイル ID は、URL に含まれています。https://app.box.com/file/(ファイル ID)
  • Box のリフレッシュトークンには、期限があります。期限を超えないよう、定期的に利用する必要があります。(Box: トークンおよびURLの有効期限)

Capture

See also

Appendix

  • box-file-delete.xml (C) Questetra, Inc. (MIT License)
    • Professional をご利用であればファイルの内容を改変することでオリジナルのアドオンとして活用できます
%d人のブロガーが「いいね」をつけました。