curl \
  -X POST \
  -H "Content-Type: application/json" \
  -d '{"Action": "Find", "Properties":{}, Rows:[]}'\
  'https://api.appsheet.com/api/v2/.... '
 
AppSheet API は比較的簡単に実行できるのだが、実際の利用では以下のような注意点があった。
AppSheet でアプリを作成する手順的に(スプレッドシートの内容からデータのカラムを構成するなど)、日本語のテーブル名やカラム名が利用される傾向は高くなる。
TypeScript の型定義などでは日本語も使えるようだが、トラブルを避けるために受信したデータを英語カラム名へマッピングすることになった。
[
  {
    "_RowNumber": "2",
    "id": "d9c9210f",
    "created": "09/16/2021 08:27:59",
    "updated": "09/18/2021 15:40:15",
    "タイトル": "テスト 1",
    "本文": "本文のテスト 1。",
    "og:title": "",
    "og:description": "",
    "og:image": "テスト_Images/d9c9210f.og-image.987023.jpg"
  }
]
 
AppSheet の Selector を組み立てるようなライブラリーは(ざっと探した限りでは)なさそうだったので、独自に組み立てることになる。
しかし、エスケープの方法などの具体的な手順が見当たらなかったので、独自に処理するなら注意が必要になる。
今回は、危ない橋はわたらずに「全件受信してから必要な部分だけ取りだす」方法で対応となった。
Reading Records from a Table の API Response HTTP Status Codes に記載はないが、429 Too Many Requests も返ってくる。
過去数時間で数回しか API を実行していないときに返ってくることもあり(直後に再実行するとほぼ成功する)、「なにをやったら 429 になるのか?」が現状では不明。
現状ではエラーメッセージを表示することで対応しているが、別途対応が必要になる可能性もある。
API レスポンス内でのImage 型は、ファイル名がテスト_Images/d9c9210f.og-image.987023.jpg のよう格納される(データファイルからの相対パス)。
よって、単純に Rest API を利用しただけでは画像を表示できない。
これについてはアクセスの手順があるので次章に記述。
gettablefileurl の利用AppSheet ではアプリ外部から画像ファイルなどへアクセスする方法が提供されている。
事前に CONTEXT('AppName') がわかっているならば、仮想カラムを用意しなくとも URL を取得できる(ただし、公式な保証はない)。
https://www.appsheet.com/template/gettablefileurl
  ?appName={URL エンコードされた AppName}
    &tableName={URL エンコードされたテーブル名}
      &fileName={URL エンコードされたファイル名}
 
画像の扱いなどで少し戸惑うことがありつつも、「AppSheet でのデータ管理を軸に入出力を補佐するアプリを作成する」という構成は比較的容易に行えた。
また、ヘッドレス CMS の主な使い方である「静的サイトの生成」にも利用可能であった。
ただし、ブログなどのメディアを更新する場合は「コンテンツのエディターや公開管理機能なども必要となってくる」ので、専用サービスを置き換えるものではないと思われる(おそらく補完的な利用が適している)。