2
0

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 1 year has passed since last update.

Stripe Apps を25日間紹介し続けるAdvent Calendar 2022

Day 16

Stripe Appsから外部のAPIやフィードを呼び出す方法とその設定方法

Posted at

この記事は、Stripe Apps を25日間紹介し続ける Advent Calendar 2022 16日目の記事です。

スクリーンショット 2022-11-24 17.56.45.png

Stripeアプリを開発する上で、Stripe以外のAPIが必要となることは少なくありません。

この記事では、Stripe Appsアプリで外部のAPIを呼び出すための設定・実装方法を紹介します。

外部のAPIを呼び出すための設定

Stripe Appsのアプリは、Stripeが用意するサンドボックス内で動作します。

extensions-structure.d6d4d0512ef2194eda5c7ffd214e894e.jpg

そのため、アプリから外部のAPIを呼び出すには、Stripe CLIを利用してstripe-apps.jsonに設定する必要があります。

Stripe CLIで呼び出すURLを登録する

今回は、Public API for Public APIsを利用してPublic APIの一覧を取得してみましょう。

Stripe CLIで次のコマンドを実行します。

$ stripe apps grant url "https://api.publicapis.org/" "Load public API data"
✔ Granted url https://api.publicapis.org/

stripe-app.jsonを見ると、content-srcにURLが登録されていることが確認できます。

{
  "id": "com.example.first-stripe-app",
  "version": "0.0.1",
  "name": "First Stripe App",
  "ui_extension": {
...
    "content_security_policy": {
+      "connect-src": [
+        "https://api.publicapis.org/"
+      ],
      "image-src": null,
+      "purpose": "Load public API data"
    }
  },
  "post_install_action": null
...

登録できるURLのタイプについて

登録できるURLの種類は、2022/12時点では次のとおりです。

Backlogやkintoneなど、ユーザーやプロジェクトごとにサブドメインが変わるサービスのAPIでは、ワイルドカードを利用しましょう。

登録解除の方法

登録の解除もStripe CLIから行えます。

$ stripe apps revoke connect-src https://api.publicapis.org/

もしコマンドで指定したURLがconnect-srcに存在しない場合、対話形式で選択できます。

? Unable to find connect-src https://qiita.com/hideokamot. Select a connect-src to revoke: 
  ▸ https://qiita.com/hideokamoto/feed.atom
    https://api.publicapis.org/

アプリの再有効化で設定を反映する

stripe-app.jsonを変更しますので、アプリのプレビューを再度有効化する必要があります。

スクリーンショット 2022-12-12 18.33.40.png

有効化が漏れている場合、設定が反映されませんのでご注意ください。

Stripe Appsから、外部のAPIを呼び出す

アクセス権の設定が完了すれば、あとは設定したURLへのリクエストをアプリから送信するだけです。

import { ContextView, List, ListItem } from "@stripe/ui-extension-sdk/ui"
import BrandIcon from "./brand_icon.svg"
import { useEffect, useState} from 'react'

type PublicAPI = {
  API: string
  Auth: string
  Category: string
  Cors: string
  Description: string
  HTTPS: boolean
  Link: string
}


const App = () => {
  const [items, setItems] = useState<Array<PublicAPI>>([])

  useEffect(() => {
    fetch("https://api.publicapis.org/entries")
      .then(data => data.json())
      .then(data => {
        setItems(data.entries)
      })
      .catch(console.log)
  }, [])
  return (
    <ContextView
      title="Hello World"
      brandColor="#F6F8FA" // replace this with your brand color
      brandIcon={BrandIcon} // replace this with your brand icon
    >
      <List>
        {items.map((item, i) => {
          return (
            <ListItem
              title={`#${i}: ${item.API}`}
              key={i}
            />
          )
        })}
      </List>
    </ContextView>
  )
}

export default App

権限設定に成功していれば、次のようにAPIのリストが表示されます。

スクリーンショット 2022-12-12 18.49.02.png

テストアカウントのローカル環境プレビューモードで、localhostのAPIを呼び出す方法

APIも並行して開発している場合、テストアカウントのローカル環境プレビューモードではlocalhostへのアクセスに設定したくなります。

その場合は、stripe-app.jsonを拡張させましょう。

stripe-app.local.jsonを作成し、次のように設定します。

{
  "extends": "stripe-app.json",
  "ui_extension": {
    "content_security_policy": {
      "connect-src": ["http://localhost:3000/api/"]
    }
  },
  "constants": {
    "API_BASE": "http://localhost:3000/api"
  }
}

stripe-app.jsonにもconstantsを追加しましょう。


    "actions": [],
    "content_security_policy": {
      "connect-src": [
        "https://api.publicapis.org/"
      ],
      "image-src": null,
      "purpose": "Load api data"
    }
  },
  "post_install_action": null,
+  "constants": {
+    "API_BASE": "https://api.publicapis.org"
+  }
}

続いてsrc/view/App.tsxのAPI呼び出し箇所を次のように変更しましょう。

import { useEffect, useState } from 'react'
+import { ExtensionContextValue } from "@stripe/ui-extension-sdk/context"


...


-const App = () => {
+const App = ({environment}: ExtensionContextValue) => {
  const [items, setItems] = useState<Array<PublicAPI>>([])

  useEffect(() => {
  useEffect(() => {
-    fetch("https://api.publicapis.org/entries")
+    fetch(`${environment?.constants.API_BASE}/entries`)
      .then(data => data.json())
      .then(data => {
        setItems(data.entries)
      })
      .catch(console.log)
  }, [])

マニフェストファイルを指定して、起動する

Stripe CLIで、ローカル環境用のマニフェストファイルを指定して、アプリを起動させましょう。

$ stripe ap start --manifest ./stripe-app.local.json 
[18:58:04] ERROR ./stripe-app.local.json
found violations for connect-src "http://localhost:3100/api/": protocol has to be https, publicsuffix: cannot derive eTLD+1 for domain "localhost"
[18:58:04] compiled successfully
💻 Running development server on http://localhost:4242 (^C to quit)
✨ You can now preview First Stripe App in your Stripe account.

エラーメッセージが表示されますが、アプリ自体は起動します。

あくまでローカル環境でのプレビュー用途ですので、stripe-app.jsonそのものにはlocalhostを設定しないようにしましょう。

Stripe Appsひとりアドベントカレンダー 2022

今年ベータリリースされたばかりのStripe Appsは、まだ日本語の情報が多くありません。

そこでQiita Advent Calendar 2022にて、毎日Stripe Appsについての情報を投稿します。

ノーコードで利用する方法や、開発するためのTipsなども紹介予定ですので、ぜひ購読をお願いします。

2
0
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
2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?