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
個人開発アプリにスキーマ 駆動開発を取り入れた話
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
虎の穴ラボ株式会社
November 30, 2023
Programming
0
260
個人開発アプリにスキーマ 駆動開発を取り入れた話
2023年11月30日に行われた「秋の終わりまでにチャレンジしたことLT会」にて発表した内容となります。
虎の穴ラボ株式会社
November 30, 2023
Tweet
Share
More Decks by 虎の穴ラボ株式会社
See All by 虎の穴ラボ株式会社
Tailwind CSSとAtomic Designで実現する効率的な Web 開発の事例
toranoana
1
570
Denoについて、同人誌記事を出しました+update
toranoana
0
200
【虎の穴ラボ Tech Talk #2】プロンプトエンジニアリング
toranoana
0
130
20241121_[TechTalk#2]虎の穴ラボでのLLMについて取り組み紹介
toranoana
0
120
社内チャットへRAG導入した話(Tech Talk #2)
toranoana
0
200
Deno Deploy で Web Cache API を 使えるようになったので試した知見
toranoana
1
630
【虎の穴ラボ Tech Talk】虎の穴ラボTech Talk説明資料
toranoana
0
440
虎の穴ラボ Tech Talk_CDKでFargate環境構築
toranoana
1
490
虎の穴ラボスキルアップ支援制度の利用例
toranoana
0
9.4k
Other Decks in Programming
See All in Programming
責任感のあるCloudWatchアラームを設計しよう
akihisaikeda
3
180
CSC307 Lecture 10
javiergs
PRO
1
660
Amazon Bedrockを活用したRAGの品質管理パイプライン構築
tosuri13
5
800
Python’s True Superpower
hynek
0
110
IFSによる形状設計/デモシーンの魅力 @ 慶應大学SFC
gam0022
1
310
2026年 エンジニアリング自己学習法
yumechi
0
140
16年目のピクシブ百科事典を支える最新の技術基盤 / The Modern Tech Stack Powering Pixiv Encyclopedia in its 16th Year
ahuglajbclajep
5
1k
Unicodeどうしてる? PHPから見たUnicode対応と他言語での対応についてのお伺い
youkidearitai
PRO
1
2.6k
「ブロックテーマでは再現できない」は本当か?
inc2734
0
1k
今こそ知るべき耐量子計算機暗号(PQC)入門 / PQC: What You Need to Know Now
mackey0225
3
390
生成AIを使ったコードレビューで定性的に品質カバー
chiilog
1
280
CSC307 Lecture 05
javiergs
PRO
0
500
Featured
See All Featured
Un-Boring Meetings
codingconduct
0
200
Building Experiences: Design Systems, User Experience, and Full Site Editing
marktimemedia
0
410
Art, The Web, and Tiny UX
lynnandtonic
304
21k
Odyssey Design
rkendrick25
PRO
1
500
Unlocking the hidden potential of vector embeddings in international SEO
frankvandijk
0
170
The Impact of AI in SEO - AI Overviews June 2024 Edition
aleyda
5
740
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
160
How People are Using Generative and Agentic AI to Supercharge Their Products, Projects, Services and Value Streams Today
helenjbeal
1
130
Git: the NoSQL Database
bkeepers
PRO
432
66k
A designer walks into a library…
pauljervisheath
210
24k
RailsConf 2023
tenderlove
30
1.3k
Building a A Zero-Code AI SEO Workflow
portentint
PRO
0
320
Transcript
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. 個人開発アプリにスキーマ 駆動開発を取り入れた話
虎の穴ラボ株式会社 浜田拓実 (sheltie) 2022 秋の終わりまでにチャレンジしたことLT会 11/30
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. 自己紹介 浜田
拓実(ハマダ タクミ) • 2022/06 入社 • 虎の穴ラボ 通販コスト削減チーム エンジニア Goを使い始めた理由 • シンプルな構文でコードがガリガリ書ける(気がする) • エイリアスや省略した書き方が少ない(気がする) 今季の推しアニメ • SHY • 16bitセンセーション
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. ・スキーマ駆動開発とは ・スキーマ駆動開発を取り入れた理由
・実際にやってみる ・OpenAPIでAPI仕様書を作成 ・ツールを利用してGo言語のファイルを出力 ・プログラムの修正 ・まとめ アジェンダ
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. スキーマ駆動開発とは 2022
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. スキーマ駆動開発とは スキーマ駆動開発(Schema-Driven
Development)は、ソフトウェア開発のアプ ローチの一つです。通常、データの構造や形式が事前に定義されたスキーマ に基づいています。これにより、開発者はデータの構造や型を明示的に定義 し、それに基づいてコードを構築します。 By ChatGPT 先にAPIのパラメータやDBのテーブル構造を決めておき、その設 計に沿ってプログラムを作成する開発手法のこと
Copyright (C) 2021 Toranoana Inc. All Rights Reserved. スキーマ駆動開発を 取り入れた理由
6 2022
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. スキーマ駆動開発を取り入れた理由 ・設計と実装を一元管理したい
個人開発のため、思いついたらそのまま実装(設計書は書かない) ➡自分でどんなAPIを作ったのか思い出せない ➡APIのパラメータを忘れた ➡APIのメソッドも忘れた(POSTだっけ? PUTだっけ?) 設計書は必要だ!
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. スキーマ駆動開発を取り入れた理由 ・設計書の管理はどうするか?
スプレッドシート ➡設計と実装がずれる自信がある! GoDocに書く ➡出力されるフォーマットがAPI向きではない
Copyright (C) 2021 Toranoana Inc. All Rights Reserved. 実際にやってみる 9
2022
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. OpenAPIでAPI仕様書を作成 ・エディタを整備
VSCodeに以下2つの拡張機能を導入
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. OpenAPIでAPI仕様書を作成 ・エディタを整備
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. ツールを利用してGo言語のファイルを出力 ・作成したOpenAPI仕様書からGoのプログラムを出力
今回は「oapi-codegen」を利用します ➡変換後のファイルが1つなので、管理が楽そう ➡main関数はすでに作成済みなので、 ジェネレーターから出力されなくて良い
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. ツールを利用してGo言語のファイルを出力 ・oapi-codegenの利用方法
導入 go install github.com/deepmap/oapi-codegen/v2/cmd/oapi-codegen@latest 変換 oapi-codegen -package petstore petstore-expanded.yaml > petstore.gen.go
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. ツールを利用してGo言語のファイルを出力 ・oapi-codegenの利用方法(自分の場合)
oapi-codegen -package generated -generate types,server,spec ./openapi.yaml > ./openapi.go 以下のコードのみ出力 ・APIパラメータの構造体 ・サーバーサイドのAPI定義の利用(Echoのルーター定義など)
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. ツールを利用してGo言語のファイルを出力
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. プログラムの修正 ・生成されたコードに合わせて既存のプログラムを修正
➡独自に定義していた構造体を削除 この修正に合わせて、構造体利用箇所も修正 ➡生成されたハンドラーの実装(次で紹介) ➡Echoのルーティングを削除 生成されたコードのルーティングを利用するように修正(次で紹介)
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. プログラムの修正 ハンドラーの実装
ハンドラーの登録
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. 動作確認
Copyright (C) 2021 Toranoana Inc. All Rights Reserved. まとめ 19
2022
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. まとめ ・スキーマ駆動開発を取り入れて
➡APIの設計と実装が一元管理できるようになった! ➡APIの設計書が出来た! ・注意事項 APIを修正するときはyamlファイル修正、 その後ジェネレータでソース出力する 出力されたファイルを修正しないように注意!!!
Copyright (C) 2020 Toranoana Inc. All Rights Reserved. ご静聴ありがとうございました 2022