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
Cap'n Webについて
Search
Yusuke Wada
December 09, 2025
Programming
350
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Cap'n Webについて
2025-12-09
Yusuke Wada
Yusuke Wada
December 09, 2025
More Decks by Yusuke Wada
See All by Yusuke Wada
Honoでのサプライチェーン侵害対策 〜 3つのライブラリに学ぶ
yusukebe
7
1.5k
Webフレームワークの ベンチマークについて
yusukebe
0
180
AI時代のUIはどこへ行く?その2!
yusukebe
22
7.6k
Dynamic Workersについて
yusukebe
2
700
飯MCP
yusukebe
0
630
へんな働き方
yusukebe
6
3k
OSS開発者の憂鬱
yusukebe
17
31k
r2-image-worker
yusukebe
1
270
Introduce Hono CLI
yusukebe
7
4.1k
Other Decks in Programming
See All in Programming
AIキャラアプリkaiwaの低遅延音声通話基盤をどう作ったか - AWS Gravitonで支える低遅延・低コストAI Agent基盤
mogamit
0
120
生成AI時代にこそ効くGo | Why Go Works in the Age of Generative AI
mom0tomo
8
3.3k
任せる範囲はこう広がった / How the Scope of AI Delegation Has Expanded
nrslib
0
170
なぜ型を書くのか? TSKaigi2026で改めて考える #tskaigi_smarthr
kajitack
0
170
LLM本来の能力を解き放つサンドボックス技術とAI民主化への適用
yukukotani
3
4.6k
Semantic Version 単位で戦略を柔軟に変えて、パッケージアップデートを自動化する
daitasu
1
320
Vite+ Unified Toolchain for the Web
naokihaba
0
360
正しくソフトウェアを作る、前提を疑うための認知の視点 / doubt-premise
minodriven
21
7.1k
Snowflake Summitでの新機能 CoCo / CoWork / snowflake-summit-2026-overall-what-new-coco
tatsuhiro
1
190
Make SRE Operations Easier with Azure SRE Agent
kkamegawa
0
8.7k
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.7k
AI駆動開発を妨げる技術的負債の解消アプローチ / ai-refactoring-approach
minodriven
15
7.7k
Featured
See All Featured
How to build an LLM SEO readiness audit: a practical framework
nmsamuel
1
790
What’s in a name? Adding method to the madness
productmarketing
PRO
24
4.1k
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.5k
Scaling GitHub
holman
464
140k
Chasing Engaging Ingredients in Design
codingconduct
0
230
Building a A Zero-Code AI SEO Workflow
portentint
PRO
0
610
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
162
16k
Making the Leap to Tech Lead
cromwellryan
135
9.9k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
32
2.9k
Future Trends and Review - Lecture 12 - Web Technologies (1019888BNR)
signer
PRO
0
3.6k
We Analyzed 250 Million AI Search Results: Here's What I Found
joshbly
1
1.4k
Become a Pro
speakerdeck
PRO
31
6k
Transcript
Cap'n Webについて
Me Yusuke Wada Web Application Developer Developer Advocate at Cloudflare
A founder of Bokete The Creator of Hono
Cap’n Web
Cap'n Webとは? • JavaScriptネイティブな RPC • capnwebというnpmパッケージがある • 作者がKenton Varda
◦ Cloudflare Workersの作者 • https://github.com/cloudflare/capnweb https://blog.cloudflare.com/capnweb-javascript-rpc-library/
Cap'n Webの特徴 • サーバーとブラウザで動作 • JavaScriptのメソッド呼び出し、オブジェクト操作ができる • HTTP、WebSocket、postMessage() で動作 •
メジャーなブラウザ、 Cloudflare Workers、Node.js、Denoで動作 ◦ Hono Adapterを使うと Bunでも • 依存なし、 10KB(minify+gzip) • TypeScriptによる型サポート
インストール
RPCであること • RESTやGraphQLを置き換えるかも • サーバサイド・クライアントを JavaScript/TypeScriptに統一したい時
RPCのイメージ - APIの定義 src/api.ts RpcTargetをextendsしたクラスをつくって関数を定義
RPCのイメージ - クライアントの呼び出し src/client.ts api.hello()で関数呼び出し
src/client.ts src/api.ts
TypeScriptの型サポート APIから型を取ってきてジェネリクスに渡す
サーバーサイドの実装 src/server.ts MyApiServerのインストールをnewWorkersRpcResponse()に渡す
動かし方 サーバーサイド Cloudflare Workers / Wranglerで起動 クライアントサイド コマンドライン / tsxで起動
2種類の呼び出し • バッチとWebSocket • API、サーバーの実装は変えなくてよい
バッチの基本 src/client-batch.ts newHttpBatchRpcSessionを使う
まとめてリクエストする src/client-batch.ts Promise.all()した時に初めてリクエストが飛ぶ
クライアント出力
サーバーログ 1度だけ!
おさらい
パイプライン - API src/api.ts getMyName()を追加
パイプライン - クライアント src/client-batch.ts await batch.hello()した時に初めてリクエストが飛ぶ Promise
クライアント出力
サーバーログ 1度だけ!
パイプライン • APIを変えずに Promiseをメソッドに渡せる • batch.hello()の時にawaitして初めてリクエストが飛ぶ • Cap’n WebのPromiseは「通常の Promise」ではない!
◦ メソッドチェーンをよしなにしてくれる
Cap’n Webのバッチの面白いところ • JavaScriptのネイティブな関数呼び出し • パイプラインを作って 1度のラウンドトリップで実行
map() - API src/api.ts
map() - クライアント src/client-batch.ts リスト操作をmap()で行う
クライアント出力
サーバーログ 1度だけ!
map() を活用する • 友達のリストを処理する ◦ 1度だけのラウンドトリップ • RESTやGraphQLに大きなアドバンテージ • APIを変えずに
1つのリクエストにすることができる
WebSocket - クライアント src/client-websocket.ts 使い方はさほど変わらない
クライアント出力 1秒経って
サーバーログ WebSocketコネクション
WebSocket • コネクションをはりっぱなし • チャットなどリアルタイム共有系で便利
Durable Objectsと一緒に使う • ステート管理をしたい • Cloudflare Workersの場合Durable Objectsが使える • JSRPCで使うRpcTargetがCap’n
WebのAPIに使える • Cap’n WebのWeb Socketクライアントからステート付きのオブジェクトに アクセスできる
None
既存のRPCとの比較 • JavaScript/TypeScriptのRPCライブラリは他にもある • tRPC • Hono RPC
JSネイティブに書ける 独自の書き方 バリデーションしている
冗長 Honoのアプリをそのままクライアントで利用できる TypeScriptの型 + fetchラッパー
実例 • Workers SDK • TanStack AIのExample ◦ https://github.com/TanStack/ai/tree/main/examples/ts-group-chat
Hono Adapter - インストール
Hono Adapter - コード例 src/server.ts Cloudflare Workers用 他にも同じインターフェースで Node.js/Deno/Bunに対応
まとめ • Cap’n Webの紹介 • JavaScriptネイティブのパイプライン • 1ラウンドトリップで呼び出し • Hono
Adapterもある