Yuigo・ん・・・湿っぽい

モルック、システムエンジニア、その他趣味。大学生のころから使っているので、昔の記事は恥ずかしいし今の思想とは異なっていることが多いです。

Slackにカスタム絵文字を一括登録する

概要

f:id:m4usta13ng:20190610004123p:plain

Slackへのカスタム絵文字追加作業って面倒だな-と思っていたので、前から気になっていた一括登録ツールを利用してみました。そうしたところ、ちょっとしたエラーが出て回り道することになったので共有します。

環境

node環境が必要です。windowsであれば公式サイトからインストールすればそのまま使えます。

Windows 10 Home
$ node -v
v10.15.3
$ npm -v
6.4.1

手順

emojipacksのインストール

github.com/lambtron/emojipacks

$ npm install -g emojipacks

これで後はREADME.mdに書いてある手順を実行するだけだったのですが...

(一部マスクしています)

$ emojipacks.cmd
Slack subdomain: hogehoge
Email address login: hogehoge@gmail.com
Password: **********
Path or URL of Emoji yaml file: https://raw.githubusercontent.com/lambtron/emojipacks/master/packs/mario-8bit.yaml
Starting import
Got tokens
Logged in
Uh oh! Error: Login error: could not get emoji upload crumb for https://hogehoge.slack.com
(node:41512) UnhandledPromiseRejectionWarning: Error: Login error: could not get emoji upload crumb for https://hogehoge.slack.com
    at Slack.emoji (C:\Users\XXXXX\AppData\Roaming\npm\node_modules\emojipacks\lib\slack.js:162:34)
    at Slack.emoji.next (<anonymous>)
    at onFulfilled (C:\Users\XXXXX\AppData\Roaming\npm\node_modules\emojipacks\node_modules\co\index.js:65:19)
    at process._tickCallback (internal/process/next_tick.js:68:7)
(node:41512) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). (rejection id: 1)
(node:41512) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.

このようにログインに失敗してしまうみたいです。

emoji-importのインストール

代替手段としてemoji-importというツールを利用すると良いという情報がemojipacksのissueに書かれていたので、以下をインストール&実行します。

参考: https://github.com/itslenny/slack-emoji-import

$ npm i -g slack-emoji-import
slack-emoji-import path/to/emoji-pack.yaml

$ slack-emoji-import C:\Users\XXXXX\Downloads\emojipacks\packs\twitch.yaml
prompt: Slack Host:  hogehoge
prompt: Slack login email:  hogehoge@gmail.com
prompt: Slack password:
prompt: Show browser:  (false) true

上記のように、プロンプトにしたがって追加対象のワークスペース、ログイン情報を入力すればあとはpuppeteerという自動ブラウジングしてくれる方がせっせと追加してくれるみたいです。prompt: Show browser:trueにするとその様子が見られます。せっせと動くさまはとっても愛らしいのですが、そういう趣味がない大多数の人は基本falseでOKです。

追加するemoji情報について

どのemojiを追加するということに関しては、上のコマンドでもしれっと書いていますがyamlファイルを指定します。これは自分で作らなければならないわけではなく、すでにネット上にあがっているものを使います。

もちろん、自分でyamlを作ることもできます。yamlの構造はシンプルなのでそこまで難しい作業ではありません(面倒だけど)。

たとえば、emojipacksのリポジトリ内にもサンプルが保存されているので、これを利用することもできます。ローカルにダウンロードする必要はなく、raw表示したURLを指定すればOKです。

注意点

当たり前ですが、ログインに使うユーザーがemoji登録権限を持っている必要があります。その他、各Slackワークスペースのマナー・ルールに従いemojiを登録しましょう。

また、emoji-importを使ってもログインに失敗することがあるので、その際はprompt: Show browser:trueにして、ブラウジングのどこで止まっているかを見てみると良いと思います。私の場合、ログインボタンを押す手前で止まってしまっていたので、ここを手動で押下してあげるとあとはいつも通り動いてくれました。

参考

Slackに絵文字をバルクアップロードする方法 - Qiita