Help us understand the problem. What is going on with this article?

iOS 12 のショートカットアプリ入門あるいは「はてブを開く」を作った話

More than 1 year has passed since last update.

「はてブを開く」ショートカット

iOS 12 から新しく使えるようになったショートカットアプリで「はてブを開く」というショートカットを作りました。これは、iOS 内の様々なアプリで URL をシェアする際に、そこから直接はてブを開けるというショートカットです。ショートカットアプリの使い方は分かってる、細かいことはいいからとりあえず使ってみたい!という人は下記リンクからインストールしてみて下さい。

「はてブを開く」ショートカット

以降では、ショートカットの使い方と作り方、「はてブを開く」ショートカットがどのように動作しているかなどを紹介していきたいと思います。

なぜこれを作ったのか

多くの iOS アプリが URL をシェアする機能を持っており、大抵はこんなアイコンが用意されていたりします。
app-share-icon.png
そして URL をシェアしようとする時に、はてなブックマークのアプリがインストールされていると、シェアする対象のアプリに表示されます。
app-share-hatebu.png
ところがこのアイコン、はてなブックマークを投稿するための機能であって、はてなブックマークのページを開くことが出来ません。
hatebu-app.png
単に他の人のコメントだけ参照したい、とか、ブックマークする前に他の人のコメントを確認して恥ずかしいことを書いてしまうのを避けたい、とか、そういう時ってありませんか?ありますよね?ね?でもこのデフォルトの機能だと出来ないんです。

詳しくは知りませんが、URL をシェアする時に別のブラウザ (もしくはそれ相当のアプリ) で直接開くことを Apple が規約で禁じているのだと思っています。URL を別アプリで開くのを Safari に限定させるためですね。だって、Google が「Chrome で開く」を実装しないのあまりに不自然じゃないですか?なので、はてなを責めないであげて下さい。

ですので、ずっと長いこと、わざわざクリップボードを経由して開くっていう手順を踏んでいました。ですが、iOS 12 で利用できるようになったショートカットアプリだったら、やりたい事が実現できるんじゃないかと思って、会社の昼休みに試してみたところ、首尾良く出来たのでここでやり方を共有します。

ショートカットの使い方

さて、この記事の後半ではどのように「はてブを開く」ショートカットが動作しているか、という解説をしますが、それより先に、まだあまり良く知られていないと思われるショートカットの使い方から説明します。
まずは App Store でショートカットアプリをインストールして下さい。全てはそれからです。

ショートカットアプリには、ギャラリーというタブがあって、そこからあらかじめ定義された様々なショートカットをインストールすることが出来ます。自分で作ったショートカットもそこで公開出来るかと思ったのですが、どうやらそういう UI が見つからないので、まだ外部の開発者には開放されていないのかも知れません。

ですが、後述のショートカットを公開する機能を使うと、ショートカットごとにユニークな URL が生成されるので、それを公開することで自分の作ったショートカットをインストールしてもらう事が出来ます。今回作ったショートカットはこちらです。

「はてブを開く」ショートカット

ここで「はてブを開く」ショートカットをインストールしたら、以下の手順で初期設定すると、それを別のアプリから呼び出せるようになります。

まずは任意のアプリで URL をシェアしようとして下さい。二段目のアイコンの一番右端に、その他、という項目があるはずです。
app-share-others.png
ここで「ショートカット」を有効にし、必要に応じて並び順も変更して下さい。
app-share-config.png
すると、URL をシェアしようとする時の候補に「ショートカット」が現れます。
app-share-shortcut.png
ここで「ショートカット」を選択すると、インストール済みのショートカットの中から利用するショートカットが選べるようになります。
やろうとしていることは、単にはてなブックマークのページを開くことですが、はてなブックマークのアプリをインストールしているとそれが URL スキーマとして動作し、はてなブックマークアプリが直接起動します。
animation.gif

「はてブを開く」の動作

さて、ショートカットの使い方が分かった所で、この「はてブを開く」ショートカットがどのように動作しているかを解説していきます。

それにはまず、はてなブックマークのページの URL がどういう構成になっているかを理解する必要があります。二つ三つの例を見てもらえれば一目瞭然かと思うのですが、はてなブックマークのページの URL は、ブックマークされたページが http の場合は http://b.hatena.ne.jp/entry/https の場合はそれに s/ を追加した http://b.hatena.ne.jp/entry/s/で始まります。そしてその後に、ブックマークされたページの URL から http(s):// をのぞいた部分を URL エンコードしたものを続けます。

つまり、「はてブを開く」ショートカットを作るにあたっては、上に書いたような事を自動化すれば良いことになります。

ではここで、「はてブを開く」ショートカットの全容を公開しましょう。
editor-full.png
思ったより長かったですか?短かったですか?全く同じ事をするブックマークレットも使っているのですが、それが JavaScript で高々 114 文字なので、真っ当なプログラミング言語と比べたら圧倒的に長いことは否めません。とはいえ、ビジュアル言語ってそんなものですし、iOS が公式でここまでカスタマイズできるようになった事を喜びましょう。

上部にあるこのアイコンからは、ショートカット自体の設定が行えます。
editor-top-config-icon.png
ここでショートカットの名前やアイコンなどの設定が出来るのですが、重要なのは「共有シートに表示」を有効にすることと、「受け入れの種類」に「URL」を指定する事です。こうすることで、他のアプリで URL をシェアしようとした時に、このショートカットを選ぶことが出来るようになります。
config.png

続いて、ショートカットに設定した各項目について順に説明していきます。

入力から URL を取得

入力されているのが URL という前提なのに、なぜこんなものが必要か疑問に思うでしょうか?それは URL をシェアしようとした時にショートカットに渡ってくる情報が、URL だけではないからです。実際にはそのページのタイトルと URL の両方が渡されてくるので、ここで URL のみを取得します。

これ以降の全てで基本的には同様ですが、ここで処理した結果が次の項目に渡されていくことになります。Unix のコマンドラインのパイプをイメージすると近いですね。

URL を展開

前の項目から URL のみを受け取ったあとでそれを展開します。これは、bit.ly などの短縮 URL を元の URL に戻してくれるもので、今回の用途では必須でありません。将来的にそういった URL をクリップボードから読み込みたい場合もあるかと思って念のため追加しています。
これがあるとパフォーマンスにかなり影響がある事が分かったので (考えてみれば当たり前) 最新版のショートカットからは削除しました。

URL エンコード

受け取った文字列を URL エンコードします。シンプルですね。これが後々、はてなブックマークのページの URL の一部として使われることになります。

テキストを分割

はてなブックマークのページの URL で使われているのは、元の URL 全体では無く、プロトコル部分を省いたものだというのを覚えているでしょうか。ここでは受け取った文字列を :// で分割することによって、プロトコル部分とそれ以外に分割しています。

ここでちょっと面白いのは、この「テキストを分割」した結果は、次の項目にリストとして渡されていくという事です。シンプルに標準出力と入力を繋ぐだけのパイプよりも賢いですね。

次の場合

さあ来ました!いわゆる if 文です。一つ前の項目から渡されたリストの中に https が含まれるかどうかで分岐しています。分岐自体はその出力に影響を与えないので、「テキストを分割」した結果のリストがそのまま次の項目に渡されていきます。

リストから項目を取得

リストに対して「最後の項目」を取得するように指示します。これによって、元の URL から :// より後の文字列が取り出せたことになります。

URL

新たに URL を生成することが出来ます。ここでは http://b.hatena.ne.jp/entry/s/ の後ろに一つ前の結果をつなげることで、最終的に https 向けの URL を生成しています。

その他の場合

まあ else 句ですね。https の代わりに http 向けの URL にする以外は if 句と同じです。

次の場合に終了

誤訳だと思います。「"次の場合"終了」とすべきではないでしょうか。これは if-else 文の終了を表します。

URL を開く

一つ前までで、httpshttp の両方にあわせた、はてなブックマークのページの URL が生成されているので、それを開くように命令して終わりです。
ここでその URL が特に何の URL スキーマにも引っかからなかったら、シンプルに Safari が立ち上がるのだと思いますが、前述のように、はてなブックマークのアプリがインストールされた環境では、そちらが立ち上がります。

ショートカットを公開する

最後の項目は、作成したショートカットを公開する手順です。ショートカットアプリのギャラリータブで公開出来るのがもちろんベストなのですが、現状では難しいようです。ですので、下記の手順で公開用 URL を取得して、それをシェアしてみましょう。

とはいえ、めっちゃシンプルです。設定用のアイコンの隣にシェア用のアイコンがあるのでそれを選択します。
editor-top-share-icon.png
そこに「iCloud リンクをコピー」というのが見つかるはずなのでそれを選択すれば、ユニークな URL が取得出来ます。シンプル…ですが、この説明で分かるか!とは思います。
app-icloud-link.png
一点、注意点としては、このユニークな URL はバージョンも自動的に管理されていて、ショートカットの内容を変更すると URL も変更になる点です。ですので、酷いバグのあるバージョンを公開して例えば Twitter などで拡散してしまったら、そのバグを後で直したとしても公開済みの URL では修正が反映されません。気をつけましょう。

まとめ

まあ正直に言って普通にプログラムする方がずっと楽です。このくらいシンプルな処理だったらそのままショートカットのロジックに落とし込んでも大したことないですが、より複雑なことをしようと思ったら、どっかのサーバでほぼ全部動かして、ショートカットは API 呼ぶだけ、みたいにしたくなりそうです。
それはそれでネットワークのレイテンシの分、動作が絶対的に遅くなるのでトレードオフではあるのですが…。

なので、この記事を読んでやる気を出した人達が、有用なショートカットをいっぱい公開してくれるようになったら嬉しいな、と思っています。

Why not register and get more from Qiita?
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
Comments
No comments
Sign up for free and join this conversation.
If you already have a Qiita account
Why do not you register as a user and use Qiita more conveniently?
You need to log in to use this function. Qiita can be used more conveniently after logging in.
You seem to be reading articles frequently this month. Qiita can be used more conveniently after logging in.
  1. We will deliver articles that match you
    By following users and tags, you can catch up information on technical fields that you are interested in as a whole
  2. you can read useful information later efficiently
    By "stocking" the articles you like, you can search right away
ユーザーは見つかりませんでした