Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
JSON Schema で Web API のスキマを埋めよう
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Kousuke Ebihara
May 15, 2014
4.7k
9
Share
JSON Schema で Web API のスキマを埋めよう
Kousuke Ebihara
May 15, 2014
More Decks by Kousuke Ebihara
See All by Kousuke Ebihara
YAPC::Asia Tokyo 行ってきた (橙で地獄谷も食べた)
co3k
0
1.4k
戦姫絶唱エンジニア (#pixivoyage)
co3k
0
200
VOYAGE GROUP 2014/06 セキュリティ勉強会 (エンジニア向け / 公開版)
co3k
1
830
Featured
See All Featured
Visualization
eitanlees
150
17k
State of Search Keynote: SEO is Dead Long Live SEO
ryanjones
0
170
エンジニアに許された特別な時間の終わり
watany
106
240k
Faster Mobile Websites
deanohume
310
31k
DBのスキルで生き残る技術 - AI時代におけるテーブル設計の勘所
soudai
PRO
64
53k
sira's awesome portfolio website redesign presentation
elsirapls
0
210
What’s in a name? Adding method to the madness
productmarketing
PRO
24
4k
職位にかかわらず全員がリーダーシップを発揮するチーム作り / Building a team where everyone can demonstrate leadership regardless of position
madoxten
62
53k
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
760
ラッコキーワード サービス紹介資料
rakko
1
2.9M
Java REST API Framework Comparison - PWX 2021
mraible
34
9.3k
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
27k
Transcript
JSON Schema で Web API のスキマを埋めよう 海老原昂輔 (@co3k)
クライアント実装 サーバ実装 仕様 Web API にありがちなこと API ドキュメント リクエスト レスポンス
ぶっちゃけAPI の追加時く らいしか更新していない なぜかドキュメントにない属性が 含まれている 手が滑ってドキュメントと若干違う形式の 属性を含めちゃったけどなんとなく通った
クライアント実装 サーバ実装 仕様 いまは API Blueprint で頑張ってる (http://apiblueprint.org/) API ドキュメント
リクエスト レスポンス Markdown の スーパーセット (ツラい) API Blueprint (YAML 表現) generate mock validate あんまり嬉しく ない なんか別に JSON Schema 書かない といけない
クライアント実装 サーバ実装 仕様 今日話したいこと JSON Schema API ドキュメント リクエスト レスポンス
generate validate validate API 仕様の DSL ドキュメントが仕様に追従 していることを保証 入力処理の実装が仕様に 追従していることを保証 出力処理の実装が仕様に 追従していることを保証
クライアント実装 サーバ実装 仕様 (まだ) 無理だった JSON Schema API ドキュメント リクエスト
レスポンス generate API 仕様の DSL ドキュメントが仕様に追従 していることを保証
JSON Schema • リソースや attribute、 JSON を用いた API について表現 することができるフォーマット
(http://json-schema.org/ documentation.html) • JSON Schema Core • JSON Schema Validation • JSON Hyper-Schema
JSON Schema $ curl https://api.heroku.com/ schema -H "Accept: application/vnd.heroku+json; version=3"
Validation (予定) • JSON Schema 仕様に基づく validate 用ライブラリは言 語問わず腐るほどあるはずなのでそれを使えばよい •
入力も JSON Schema でバリデーションするようにすれば (ある程度の) 入力値検証は自分で書かなくても済む • 出力は JSON Schema のバリデーションに通るかどうかだ け確認すれば (ある程度の) テストは自分で書かなくても 済む
Documentation • prmd で生成するのがオススメ • Heroku の API ドキュメント用に作られた •
JSON Hyper-Schema から GitHub Markdown を出力し てくれる • erb 形式のテンプレートで出力をカスタマイズ可能 • 海老原も contribute している
Documentation https://github.com/interagent/prmd
実例 https://devcenter.heroku.com/ articles/platform-api-reference
Heroku Interagent https://github.com/interagent/
interagent/committee • Rack middleware to validate responses according to JSON
schema JSON スキーマに基づくレスポンスのバリデーションをする Rack ミドルウェア
interagent/schematic • Generate Go client code for HTTP APIs described
by JSON Hyper-Schemas. JSON Hyper-Schema によって記述された HTTP API の Go クライアントを生成する
interagent/http-api-design • HTTP API design guide extracted from work on
the Heroku Platform API Heroku Platform API の成果物から派生した HTTP API の 設計ガイド • 昨日の 25 時になぜか和訳をはじめた https:// github.com/co3k/http-api-design/tree/translate- japanese
interagent/heroics ! ! • Ruby HTTP client for APIs represented
with JSON schema JSON スキーマによって表現された API のための Ruby HTTP クライアント
クライアント実装 サーバ実装 仕様 まとめ JSON Schema API ドキュメント リクエスト レスポンス
generate validate validate API 仕様の DSL ドキュメントが仕様に追従 していることを保証 入力処理の実装が仕様に 追従していることを保証 出力処理の実装が仕様に 追従していることを保証
Question?