LoginSignup
1
1

iOS, iPadOSからphonelink(tel:...)を開く仕様差分に苦労した話

Last updated at Posted at 2024-02-15

まえがき

アプリ内からdeeplinkで電話アプリを起動する実装で、基本設計時に見落としていたハマりポイントがあったので共有。
今回のGOALは、PhoneLinkを処理できる端末を使用しているユーザーにのみ、Phone Linkのdeeplink関連の機能を提供すること。そのために、デバイスがPhoneLinkを使用できるか判断できるようにする

FaceTimeとPhoneアプリの仕様差分について

読み進めていく前に理解しておきたい機能群を抜粋.

FaceTime

  • Wi-Fi経由でAppleユーザーの端末(iOS, iPadOS)への通話、デバイスのセルラー経由での通話ができる

WiFi経由で、またはサポートされている iOS または iPadOS デバイスのセルラー経由で FaceTime を使用できます。

  • 設定 > FaceTime > FaceTimeのノブをONにしないと受信などが使えない (方法は以下)

1.「設定」を開きます。
2. 「FaceTime」をタップし、「FaceTime に Apple ID を使用する」をタップします。
3. Apple ID でサインインします。

Phone

  • デバイスのセルラー経由で電話するアプリ
  • 固定電話、国際電話も考慮されて設計されている
  • (個人的なメモ)+ボタンは、+が表示されるまで0を押すと入力することができる

国際電話で「+」を入力する: 「+」が表示されるまで「0」キーをタッチしたままにします。

PhoneLinkを開いた時のiOSとiPadOSの仕様差分

iPadOS:

  • 電話に使用するアプリはFacetime
  • 近くに同じAppleIDにサインインされている&適切なSIMが挿入されているiPhone or iPadがあれば、そちらの端末のFaceTimeからセルラー経由で発信
  • iPad側で設定 > FaceTimeをONにしていないと、通話モーダルが表示されず何も起きない

iOS📱

  • 電話に使用するアプリはPhone
  • 通常の電話アプリなので、固定電話への電話も想定されている

困ったこと発生

※2023/11/21現在
iPadでデフォルトで立ち上がるFaceTimeでは、冒頭が2桁の電話番号の冒頭に国別番号を追加して次の0が省略されず発信されることが判明。Appleのサポートに問い合わせてみたところ、明確な返答が得られなかったため、共有。

  1. 05-1111-2222の冒頭に、+81の国別コードを付与して、+8105-1111-2222に電話
  2. FaceTimeに表記上は、+81(0)5-1111-2222に電話をかけられているものの、期待値+815-1111-2222ではない電話番号に通話されている

今回使用するAPIについて

UIApplication - canOpenURL

func canOpenURL(_ url: URL) -> Bool
  • 戻り値について

アプリがURLスキームを処理できるかどうかを示すブール値を返します。

ここで言うアプリはOSのこと?インストールされているアプリのこと?

  • 引数について...(一部抜粋)

実行時に、システムは、デバイスにURLのスキームを処理するために登録されたアプリがインストールされているかどうかを判断します。デバイスには、1つのスキームを処理するために複数のアプリが登録されている可能性があります。

つまり、メソッドの説明の「アプリ」と言うのはインストールされているアプリのことだったんだ!

仮説を立てる

=> ここまでの見解が正であれば、

telスキーマのPhoneLinkを直接処理できるアプリ(Phone, FaceTime)を全て削除すれば、

UIApplication.shared.canOpenURL(URL(string: "tel:080000"))

上記の構文でfalseが返ってくるはず

試したこと1

Phone, FaceTimeアプリを削除する

  1. iPadでFaceTimeを削除(Setting > Storage > FaceTime > delete)
  2. 設定 > FaceTime > Call from iPhoneをオフ(近くのiPhoneを検出して電話しないようにする)

=> 変わらずtrueがまだ返ってくる...

試したこと2

info.plistのLSApplicationQueriesSchemesにtelを追加する

<key>LSApplicationQueriesSchemes</key>
<array>
    <string>tel</string>
</array>

=> 変わらずtrueがまだ返ってくる...

結果(考察)

  • Appleのドキュメンテーションに記載の以下の「アプリ」は「OS」を示している可能性が高い

アプリがURLスキームを処理できるかどうかを示すブール値を返します。

参考文献

※1 国立国会図書館サーチ - 国別コード一覧

PhoneLink

UIApplication

canOpenURL

1
1
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
1
1