REST API の型定義とドキュメンテーション

すばる / su8ru

北大 B1 / HUIT

slides.su8.run/231215-typesafe-api-client

2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

自己紹介

すばる / su8ru

  • 北海道大学 総合教育部 1 年
    (総合理系物理重点; 情エレ情理志望)
  • HUIT
  • 20 y.o.
  • su8ru.dev
2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

自己紹介

すきなもの

  • TypeScript
  • React
  • にじさんじ
  • 飛行機 🔴
2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

いまから TypeScript の話をします

前提

フロントエンドの話です

  1. 動的型付けである JS に静的型検査を導入します
  2. ブラウザで動くのは JavaScript であり、実行時は型検査が行われません

実行しないと型が定まらない場合に問題となる

その最たる例が REST API リクエスト

2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

TypeScript を用いたフロントエンド実装での

API クライアントの選択どうしてますか?

TypeScript の様々な「型の割れ窓」の中でも、
HTTP 通信や JSON 周りは特に厄介

2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

一番簡単なのは any を握りつぶすこと🥴 :論外

安全にやろうとすると型ガードだらけで一番難しいかも

2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

理想はフルスタック TypeScript✨ だけど難しい

既存のサーバーがあるとか、安全性の問題とか……

→ 現実的には「実装に合わせて型定義を作る」方向で対処する

2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

OpenAPI はドキュメントとしても使えるけど大変

バックエンドから自動生成

型が弱い、フロントエンドの実装が遅れる

人が手書き

書くのがとても大変

2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

コード生成ツールは書きやすく表現力も高いが可読性 ✕

API 全体を俯瞰するには不向き

そもそもドキュメントを書くためのツールじゃない

2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

src/apis/reservations/search/index.ts

export interface Methods {
  /**
   * 予約情報の検索
   *
   * @remarks
   * 必要な権限:
   * - reservation
   *
   * @throws Error
   * 400: 誤ったパラメータが含まれている
   *
   * @returns 検索条件をすべて満たした予約情報の配列
   * 該当するものがない場合は空の配列
   */
  get: {
    reqHeaders: AuthToken;
    query: Partial<ReservationQuery>;
    resBody: Reservation[];
  };
}
2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

現状あまりいい方法がない

→ どうしよう

2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

REST API 型定義とリファレンスは本質的に同じ

どちらも API のリクエストやレスポンスの型を定義している

ただし、リファレンスには認証情報や補足情報、エラーに関する情報も含まれる

→ API 型定義からリファレンスを生成するのが最強では??

2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

こんなツールを作りたい

2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

📝 TS で定義することで型の表現力と書きやすさを両立

Utility Types も使えて嬉しい

📘 ソースコードで記述された定義を文書化

TypeDoc がかなり近いが、API ドキュメントとしては不適

💣 エラーもなるべく型付けして扱いたい

4xx 系列ならたぶん API 仕様内なので、型を付けてあげたい

2023-12-15 | 合同 LT 会
REST API の型定義とドキュメンテーション | su8ru

ご清聴ありがとうございました!

興味ある!とかこんな方法は?とかぜひ教えてください!

2023-12-15 | 合同 LT 会

# API クライアントの選択どうしてますか?

# API クライアントの選択どうしてますか?

# API クライアントの選択どうしてますか?

# API クライアントの選択どうしてますか?