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
Is Serverless Safe? ~Hacking AWS Lambda~
Search
Yutaka Hiroyama
December 05, 2023
Technology
410
1
Share
Is Serverless Safe? ~Hacking AWS Lambda~
I spoke this content at Cyber-sec+ vol.2 Dec.5 2023.
Yutaka Hiroyama
December 05, 2023
More Decks by Yutaka Hiroyama
See All by Yutaka Hiroyama
[Jagu'e'r]Next26×Jagu'e'r アフターイベント "The Real Deal": セキュリティ
pict3
0
39
Security in the AI Agent era
pict3
0
120
The State of AI Agent Security:2025年の総括と2026年の宿題
pict3
0
170
Is Serverless Safe? ~Hacking AWS Lambda~
pict3
0
200
PagerDutyを活用したインシデント管理の自動化とメリット
pict3
0
630
WafCharm運用のベストプラクティスを考えてみた
pict3
0
1.4k
AWSからのメール読んでいますか?
pict3
0
2.1k
PCI DSS運用でラクをする/make_it_easy_for_pci-dss_operation_on_cloud
pict3
0
290
AWSでのPCI DSS運用でラクをする/make_it_easy_for_pci-dss_operation_on_aws
pict3
1
2.5k
Other Decks in Technology
See All in Technology
Sociotechnical Architecture Reviews: Understanding Teams, not just Artefacts
ewolff
1
160
Agent Skillsで実現する記憶領域の運用とその後
yamadashy
2
1.6k
Building Production-Ready Agents Microsoft Agent Framework
_mertmetin
0
160
「QA=テスト」「シフトレフト=スクラムイベントの参加者の一員」の呪縛を解く。アジャイルな開発を止めないために、10Xで挑んだ「右側のしわ寄せ」解消記 #scrumniigata
nihonbuson
PRO
4
970
Agent の「自由」と「安全」〜未来に向けて今できること〜
katayan
0
350
SLI/SLO、「完全に理解した」から「チョットデキル」へ
maruloop
1
160
「背中を見て育て」からの卒業 〜専門技術としてのテスト設計を軸に、品質保証のバトンを繋ぐ〜 #genda_tech_talk
nihonbuson
PRO
1
890
Shiny New Tools Won't Fix Your Problem
trishagee
1
120
100マイクロサービスのTerraform/Kubernetes管理地獄から抜け出すためのAI活用術
markie1009
0
110
生成AIはソフトウェア開発の革命か、ソフトウェア工学の宿題再提出なのか -ソフトウェア品質特性の追加提案-
kyonmm
PRO
2
870
QAエンジニアはどうやって プロダクト議論の場に入れるのか?
moritamasami
2
410
エージェント時代の UIとAPI、CLI戦略
coincheck_recruit
0
160
Featured
See All Featured
Discover your Explorer Soul
emna__ayadi
2
1.1k
Why Your Marketing Sucks and What You Can Do About It - Sophie Logan
marketingsoph
0
140
Into the Great Unknown - MozCon
thekraken
41
2.5k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
Faster Mobile Websites
deanohume
310
31k
Technical Leadership for Architectural Decision Making
baasie
3
360
Utilizing Notion as your number one productivity tool
mfonobong
4
300
Jess Joyce - The Pitfalls of Following Frameworks
techseoconnect
PRO
1
140
The Illustrated Children's Guide to Kubernetes
chrisshort
51
52k
Tips & Tricks on How to Get Your First Job In Tech
honzajavorek
1
500
Exploring anti-patterns in Rails
aemeredith
3
350
How to Get Subject Matter Experts Bought In and Actively Contributing to SEO & PR Initiatives.
livdayseo
0
110
Transcript
サーバーレスは 安全なのか? Hacking AWS Lambda
自己紹介 •氏名:廣山 豊 •所属:アイレット株式会社 クラウドインテグレーション事業部副事業部長 兼 内部統制推進室室長 •役割:情報管理責任者 兼 PCI DSS管理責任者
兼 AWS Well Architected Lead 兼 品質管理責任者 •AWS Top Engineers - 2019 ~ <初回から継続中> •AWS, 情報処理安全確保支援士、 その他多数の認定資格を保有
はじめに
このLambdaファンクションで、他の人のデータを盗める? import json import yaml def Handler(event, context):
data = yaml.load(event[“body”]["Data"]) store_data(data) return { "statusCode" : 200, "body" : “OK!!” } import json import yaml def Handler(event, context): data = yaml.load(event[“body”]["Data"]) # store_data(data) return { "statusCode" : 200, "body" : “OK!!” }
注意事項 https://unit42.paloaltonetworks.com/gaining-persistency-vulnerable-lambdas/ 攻撃手段については、上記で公開されている範囲内でお話しします。 悪用への活用や、無断での第三者環境での試用は絶対にしないでください!
ハッキング
AWS Lambda の仕組み 以下の3点が、今回のお話の肝となります。 • コールドスタート時に、コンテナが生成される • bootstrap (ランタイム)はユーザーが記載するコード(ハンドラ)と同じコンテナ環境に存在する •
ランタイム はハンドラの呼び出しとレスポンスの返却をループ処理で繰り返す 引用) https://aws.amazon.com/jp/blogs/compute/the-serverless-lamp-stack-part-3-replacing-the-web-server/ https://medium.com/build-succeeded/deconstructing-aws-lambda-functions-d1597dd054cd
今回解説するハッキングの概要 ハンドラから bootstrap を差し替えることで実現。 OS コマンドインジェクションの脆弱性をつく。 データを盗み出すよう改竄した bootstrap を送り込み、YAML読み込み時にプロセスを
差し替えることで永続化させる。 この bootstrap は、ハンドラ呼び出し直前に、TCPにてデータを指定のIPアドレス宛に 送信する。
ハッキング構成 差し替える
bootstrap の改ざん手順 ざっくりとした手順は以下。 1. 正規の bootstrap をベースに加工した bootstrap を用意する 2.
加工した bootstrap を、既存の bootstrap と差し替えるスクリプトを用意する 3. 攻撃対象の Lambda に対し、1, 2 のスクリプトを展開させるような YAML データを 付属の上、呼び出す 正規の bootstrap の振る舞いも続けるため、利用者および Lambda の保守担当者は 気づきにくい。 成功すれば、そのコンテナ環境に次回以降くるリクエストに付随するデータを搾取可能。
加工した bootstrap のサンプルの抜粋 ハンドラ呼び出しの直前に POST で悪意ある 攻撃者宛にデータを送信
プロセスを差し替えるスクリプトのサンプル
Lambdaに送りつける YAML データ生成のサンプル 先の2つのサンプルを差し込んで、上記の偽装 YAML を生成し、Lambda ファンクション を invoke する。
盗み出したデータのキャプチャ Base64でデコードすることで データを取得可能
ホワイトハッカー視点での分析
攻撃に対して PyYAML の脆弱性 (CVE-2017-18342) をついた、OS コマンドインジェクション。 5.1 未満のバージョンに存在。 CVSS で
9.8 のヤバいやつ。 引用) https://nvd.nist.gov/vuln/detail/CVE-2017-18342
問題となる箇所 PyYaml ver 5.1 で作った Layer
問題箇所のコード import json import yaml def Handler(event, context):
data = yaml.load(event[“body”]["Data"]) # store_data(data) return { "statusCode" : 200, "body" : “OK!!” }
防御 Shift Left(スキャン、ネットワーク制限、暗号化) Shield Right(WAF、エージェント、VPC FlowLog、GuardDuty) 引用) https://sysdig.com/blog/cnapp-runtime-insights-shift-left-shield-right/
防御 Shift Left も重要! 予めできることはやっておきましょう!
Amazon CodeGuru の検出例 しっかり検出!
AWS WAF防御例 「os.execv」 という文字列を検知 左記のルールを設定した WAFをAPI Gatewayにアタッチ した上で攻撃を行なったログ
AWS Lambda における責任共有モデル IaaSとサーバーレス 引用) https://docs.aws.amazon.com/whitepapers/latest/security-overview-aws-lambda/the-shared-responsibility-model.html
AWS Lambda における責任共有モデル IaaSとサーバーレス
Wrap-up
AWS Lambdaは危険なのか? No! OS コマンドインジェクションは、IaaS やオンプレでも有効。むしろ攻撃を成功させやす い。 コールドスタートによって自動的にコンテナを再生成(攻撃を無効化)できる AWS Lamba
の方が安全。
まとめ • (IaaS やオンプレよりは攻撃難易度は上がるものの) たとえ FaaS であっても脆弱性対策は必要 • セキュリティ面を考慮するには、仕組みを知ったほうがいい •
脆弱性をなくすことと(Shift Left)、攻撃を検知・防御すること(Shield Right)両面で 行う