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
Type Spec と Go(gin) で作るTypeSafeな web api/Craete...
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
Ryusei Ohkura
November 08, 2025
450
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Type Spec と Go(gin) で作るTypeSafeな web api/Craete type safe web api with typespec and go
ゆる勉強会 in 新宿御苑 #2
で発表させていただいた資料です!
https://engineers-anime.connpass.com/event/374534/
Ryusei Ohkura
November 08, 2025
More Decks by Ryusei Ohkura
See All by Ryusei Ohkura
コードギアスから学ぶ戦略と戦術/engineer-anime-2026-04-11
3l4l5
0
85
登壇を続けていたら地域コミュニティを作るようになった話/outputconf2026
3l4l5
1
1.3k
本当にpythonは堅牢さに欠けるのか
3l4l5
0
240
習慣化するための技術 / Techniques for Habit Formation
3l4l5
3
510
SQLAlchemy の select(User).where(User.id =="123") を理解してみる/sqlalchemy deep dive
3l4l5
3
1.1k
NEW GAMEが良いということを伝えたいLT / New Game is iizo.
3l4l5
0
96
「アニメから学ぶ」から学ぶ具体と抽象/ I wanna learn abstraction from "learning from anime"
3l4l5
4
1.1k
アニメからリーダーシップを学びたい / i wanna learn leader ship from animation
3l4l5
1
130
ドミネーターの実装で学ぶSOLID原則/learn solid law with dominator
3l4l5
2
170
Featured
See All Featured
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
62
44k
Optimising Largest Contentful Paint
csswizardry
37
3.7k
SEO Brein meetup: CTRL+C is not how to scale international SEO
lindahogenes
1
2.7k
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
150
<Decoding/> the Language of Devs - We Love SEO 2024
nikkihalliwell
1
240
Building Experiences: Design Systems, User Experience, and Full Site Editing
marktimemedia
0
520
Art, The Web, and Tiny UX
lynnandtonic
304
22k
We Have a Design System, Now What?
morganepeng
55
8.2k
Gemini Prompt Engineering: Practical Techniques for Tangible AI Outcomes
mfonobong
2
430
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
55
3.4k
Design of three-dimensional binary manipulators for pick-and-place task avoiding obstacles (IECON2024)
konakalab
0
440
Un-Boring Meetings
codingconduct
0
310
Transcript
Type Spec と Go(gin) で作るTypeSafeな web api ヲクラ @3l4I5
自己紹介 3l4i5 3l4l5 - クロスマート株式会社 - 請求書チーム - テックリード -
バックエンドエンジニア - すき - 🎷響けユーフォニアム - 🤖SSSS.GRIDMAN - 🎸ぼっち・ざ・ろっく - 🐧宇宙よりも遠い場所 往蔵隆成(ヲクラ)
Web APIを作る時に考えること • リクエストのバリデーションを楽に書きたい • swagger.yaml書きたくないけど、swagger.yamlはほしい(わがまま) • バックエンドのcontroller層でも型safeに開発したい • (Go書けるようになりたいのでGoで書きたい)
リクエストのバリデーション楽に書きたい やだ!!!!!
Web APIを作る時に考えること • リクエストのバリデーションを楽に書きたい • swagger.yaml書きたくないけど、swagger.yamlはほしい(わがまま) • バックエンドのcontroller層でも型safeに開発したい • (Go書けるようになりたいのでGoで書きたい)
FastAPI(Python) Nest.js(TypeScript/JavaScript) Micronaut(Kotlin) で、コードで型定義 → OpenAPI 仕様書生成可能
コードで型+バリデーション定義 OpenAPI 仕様書
バックエンド バリデーション+型のコード生成 OpenAPI 仕様書 何か
バックエンド バリデーション+型のコード生成 OpenAPI 仕様書 TypeSpec
バックエンド バリデーション+型のコード生成 OpenAPI Specification TypeSpec Swagger書かなくて良い! + バリデーション書かなくて良い! + Gin対応!
TypeSpecとは? • TypeScriptのような書き方で APIのinterfaceを定義できる • TypeSpecで定義された記述を OpenAPI 仕様書に変換できる
TypeSpecとは? “/stores”に対して • query paramでリクエストした場合は Storeのリストを返す • path paramでリクエストした場合は Store単体を返す
TypeSpecとは? “/stores”に対して • query paramでリクエストした場合は Storeのリストを返す • path paramでリクエストした場合は Store単体を返す
入れ子のオブジェクトも 簡単に表現
TypeSpecの記述 Oapi.ymlの記述 変換!
TypeSpecの記述 Oapi.ymlの記述 変換! 圧倒的に楽!🎉
バックエンド バリデーション+型のコード生成 OpenAPI 仕様書 TypeSpec 今の話
OpenAPI 仕様書 TypeSpec 今度こっち バックエンド バリデーション+型のコード生成
• OpenAPI 仕様書からGoのコードを生成 できる • ginをはじめとした、様々な GoのWeb APIのcontroller層のコード を生成 OpenAPI
Specificationからのコード生成
詳しくは割愛(ドキュメントを参照ください) • OpenAPI仕様書で定義した型を元に バリデーションコード レスポンスの型 を生成 • レスポンスには勝手にstatus codeをつけてくれる •
errを返せば勝手に500 errorとして解釈してくれる → 至れり尽くせり! oapi-codegen
バックエンド バリデーション+型のコード生成 OpenAPI 仕様書 TypeSpec TypeSpec Cli oapi-codegen
バックエンド バリデーション+型のコード生成 OpenAPI 仕様書 TypeSpec TypeSpec Cli oapi-codegen フロントエンド クライアント・型生成 orval
/ openapi-typescript
バックエンド バリデーション+型のコード生成 OpenAPI 仕様書 TypeSpec TypeSpec Cli oapi-codegen フロントエンド クライアント・型生成 orval
/ openapi-typescript 一気通貫の Type safe な web 開発!💪
宣伝! LT会やるよ〜 来てね〜