12
13

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Slackのファイルを一気に削除する

Last updated at Posted at 2018-01-13

はじめに

raspberry piでslack botを遊んでいるとslackに写真や動画のファイルをアップしすぎて大変なことに。。。
必要のないファイルを削除しようと思ったのですが、slackでファイルを削除しようと思うと、ファイル1個1個選択して削除するという大変面倒くさいインターフェース。
そういえば、会社で使っている時もファイル整理しようと思って一気に削除する方法が分からなくて困った記憶が。。。
どうにも方法がなさそうなので、slack api使ってやればいいじゃないかと。

必要なもの

今回の方法はphpのスクリプトなので、phpが動く環境が必要です。うちのパソコンはMacなので、さくっと動きました。

slack apiを使うための準備

slack apiを使うためには準備が必要です。
要するにslack apiにアクセスするためのtokenが必要なので、これを発行する必要があります。
以下に @ykhirao さんが丁寧にまとめてくれてますので、そちらを参照して下さい。

注意
今回は、ファイル一覧とファイル削除のAPIを使用します。
2. スコープ設定 で設定するスコープは以下のように「files:read」と「files:write:user」の2つを追加して下さい。
scope.png
ちなみにscopeを変更した時にはアプリの再インストールが必要になるので注意が必要です。

無事にアプリをインストールできたらtokenを取得します。tokenを忘れたときの取得方法も @ykhirao さんが丁寧にまとめてくれてますので、そちらを参照して下さい。
https://qiita.com/ykhirao/items/3b19ee6a1458cfb4ba21#4-token%E3%82%92%E6%8E%A2%E3%81%99

PHPスクリプト

phpのcurl(Client URL Library)を使用してWeb apiを呼び出します。
phpのcurlでjsonをpostする方法は、以下のサイトのスクリプトを利用して修正させて頂きました。
http://nanase.hatenablog.jp/entry/2013/04/12/160836
slack apiでは、「charset=utf-8」を設定しないと怒られます。
$token には前述のslack apiのtokenを設定します。
$count には1回で削除するファイルの上限を設定します。

delete_slack_files.php
<?php
$token ='xoxp-XXXXXXXXXXX-XXXXXXXXXXX-XXXXXXXXXXXX-XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX';
$count = 100;
# このスクリプトはファイル一覧で取得出来たファイルをすべて削除します。
# 特定のchannelやファイル種別で絞り込むにはオプションを追加してください。
# 以下のAPIリファレンスを参照願います。
# https://api.slack.com/methods/files.list
# 例:channel IDのファイルを取得
# $op ='token=' . $token . "&count=$count" . "&channel=ABCDEF";
$op ='token=' . $token . "&count=$count";
$curl = curl_init();
curl_setopt($curl, CURLOPT_URL, 'https://slack.com/api/files.list?'.$op);
curl_setopt($curl, CURLOPT_CUSTOMREQUEST, 'GET');
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
$response = curl_exec($curl);
$result = json_decode($response, true);
$n = $result['paging']['total'];
curl_close($curl);
$files = $result['files'];

# https://slack.com/api/files.list で取得したファイルを削除します。
$json_data = array('file' => 'XXX');
$i = 0;
foreach ($files as $file) {
  echo $file['id'].":".$file['name'];
  $json_data['file'] = $file['id'];
  $data = json_encode($json_data);
  $ret = postFromHTTP('https://slack.com/api/files.delete',$data,$token);
  if($ret['ok']){ echo ' Delete!';}
  else { echo ' ERROR.';}
  echo "\n";
  $i++;
}
echo "$n files found.\n";
echo "delete $i files.\n";


function postFromHTTP($url, $data, $token) {
    $options = array(
		CURLOPT_RETURNTRANSFER => true,
		CURLOPT_FOLLOWLOCATION => true,
		CURLOPT_AUTOREFERER => true,
    );
    $authorization = "Authorization: Bearer ".$token;
    $ch = curl_init();
    curl_setopt($ch, CURLOPT_URL, $url);
    curl_setopt($ch, CURLOPT_HTTPHEADER,
    array('Content-Type: application/json; charset=utf-8' , $authorization ));
    curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
    curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
    curl_setopt($ch, CURLOPT_VERBOSE, false);
    curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
    curl_setopt($ch, CURLOPT_POST, true);
    curl_setopt_array($ch, $options);
    $result = curl_exec($ch);
    curl_close($ch);
    $ret = json_decode($result, true);
    return $ret;
}
?>

これでサクサクとファイルを削除できるのでslackの容量を気にせずに色々できるようになります。
なお、web apiの結果が反映されるのには多少タイムラグがあるみたいで、大量にファイル削除していたら結果が反映されるのに数秒かかりました。ファイルは削除済みなのに、ファイル一覧は取得できる状態になりました。そのため、上記のスクリプトを連続して使用すると思ったようにファイルが削除されないことがあります。連続して使用する時には数秒待ってから実行するようにしてください。

12
13
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
12
13

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?