Copyrights(c) Henry, Inc. All rights reserved. アジェンダ • WHY なぜOpenAPIによるスキーマ駆動開発を使うべきと判断し たのか • Contract-first vs. Code-first • OpenAPI vs. GraphQL vs. gRPC • WHAT サーバーサイドKotlinでスキーマ駆動開発を実現するため の守破離
Copyrights(c) Henry, Inc. All rights reserved. Contract-first vs. Code-first 予約システム 名簿システム 検査報告システム Henry Integration API 外部サービスベンダー様と協業する際のワークフローを 考慮 ● 要求の認識合わせ ● APIの仕様のフィックス ● 各自が実装 ● 結合テスト ● リリース
Copyrights(c) Henry, Inc. All rights reserved. gRPC GraphQL OpenAPI 自動生成 First Party GraphQL Code Generator OpenAPI Generator Swagger Codegen 利用ノウハウ 社内にはあるが、世の中で はまだそれ程多くない
Copyrights(c) Henry, Inc. All rights reserved. 自作テンプレートの活用 協力会社へ提供するAPIとはいえ、外部向けのAPIサーバーなので、 入力に対するバリデーションが必要。 ソースコード(modules/openapi-generator/src/main/resources/kotlin-server/libraries/ktor)内で確認 したら確かにuseBeanValidationの記述がなかった(非サポートだった)
Copyrights(c) Henry, Inc. All rights reserved. 複数の定義ファイルへの対応 対応するAPIが増えることによって、全てのAPI定義を一つのファイル にまとめることは書きづらさ、メンテナンスしにくさに直結してしまう。 spec.yml Kotlinコード spec.x.yml spec.y.yml spec.z.yml spec._base.yml