SlideShare a Scribd company logo
日々の開発フローにプラスする
GitHub Actions
~ セキュリティ対策を取り込む
Go fast and robust with GitHub 第一弾
岩永かづみ / Kazumi IWANAGA
• Microsoft MVP for Azure
• ZEN Architects 所属
• GitHub公認トレーナー
• 得意な領域
• Infrastructure as Code
• GitHub Actions による自動化
• 技術コミュニティ
• Code Polaris / Hack Everything.
• @dz_
• @dzeyelid
• @dzeyelid
業務における開発フロー
開発フロー
• GitHubフローをベースに、プルリクエストを用いてレビューを受けて
マージ
実装 プルリクエスト作成 レビュー マージ
開発フロー
実装 プルリクエスト作成 レビュー マージ
人によるレビュー
開発フローに CI/CD を加える
開発フロー
実装 プルリクエスト作成 レビュー マージ
人によるレビュー
開発フローに機械的なチェックをプラス
実装 プルリクエスト作成 レビュー マージ
人によるレビュー
機械によるレビュー
開発フローに機械的なチェックをプラス
実装 プルリクエスト作成 レビュー マージ
人によるレビュー
機械によるレビュー
CI/CD
開発フローに機械的なチェックをプラス
実装 プルリクエスト作成 レビュー マージ
人によるレビュー
機械によるレビュー
CI/CD
GitHub Actions
GitHub Actions で
CI/CD を構成する
GitHub Actions
• 自動化のためのワークフローを作成できる
• プルリクエスト作成・編集時をはじめ、様々な契機で発動できる
• 自作、またはオープンソースで公開される"アクション"を利用できる
• Marketplace の他、各々のリポジトリを参照可能
• GitHub-hosted または Self-hosted ランナーを利用できる
• GitHub-hosted ランナー
• Ubuntu, Windows, MacOS
• 最近は、より大きいコア数を搭載したランナーも登場
GitHub Actions
GitHub Actions のいいところ
• GitHub の各機能との連携がシームレス
• とくにプルリクエストと密に連携でき、既存の開発フローに取り込める
• 無料利用枠が多い
• 後述のセキュリティ対策と相性が良い
• GitHub Actions Importerで他のプラットフォームから移行も対応
• 参考: Automating migration with GitHub Actions Importer -
GitHub Docs
開発フローにセキュリティ対策を
加える
開発フロー
実装 プルリクエスト作成 レビュー マージ
人によるレビュー
機械によるレビュー
CI/CD
GitHub Actions
開発フローにセキュリティ対策をプラス
実装 プルリクエスト作成 レビュー マージ
人によるレビュー
機械によるレビュー
CI/CD
GitHub Actions
セキュリティ対策
GitHub でできるセキュリティ対策
依存パッケージに潜む脆弱性の検出・対策
シークレットの混入を検出
コードの静的解析
GitHub でできるセキュリティ対策
"Dependabot" と Dependency review
Secret scanning
Code scanning
"Dependabot"
• リポジトリ(デフォルトブランチ)に含まれるパッケージの依存関係を
解析し、脆弱性の検出や修正の提案を行ってくれる機能群
• 脆弱性の情報は GitHub Advisory Database を参照する(更新
も追随)
機能 説明
Dependabot alerts 依存関係にあるパッケージに脆弱性が検出された場合にア
ラートを通知する
Dependabot security updates Dependabot alerts で検出された脆弱性に対して、コード
の修正をプルリクエストとして提案してくれる
Dependabot version updates 依存関係にあるパッケージのバージョンにアップデートがあ
る場合に、更新をプルリクエストとして提案してくれる
Dependabot alerts
Dependabot alerts 詳細ページ
Dependabot によるプルリクエストの様子
Dependabot security updates
Dependabot version updates
Dependabot security updates
Dependabot version updates
Dependency review
• 依存関係内の脆弱性を検出する機能が、GitHub Actions のアク
ション actions/dependency-review-action として提供されてい
る
• Dependency Review · Actions · GitHub Marketplace
機能 説明
Dependabot alerts
(前述)
Dependabot alerts は、リポジトリのデフォルトブランチに対する依存関
係が対象なので、マージしないと検出できない
Dependency review GitHub Actions で利用できるので、プルリクエストなどの時点でも依存
関係のチェックを行える
Dependency review
Secret scanning
• GitHubリポジトリ上の全てのブランチと履歴に対しスキャンを行い、
シークレットの混入を検出してくれる機能
シークレットの種類 説明
パートナープロバイダのパターン パートナープロバイダが発行しているトークンやキーなどのシーク
レットパターン(現在、66プロバイダ)
参考: Supported secrets for partner patterns - GitHub Docs
カスタムパターン 独自のパターンを定義できる(GitHub Advanced Security
が必要(後述))
参考: Defining custom patterns for secret scanning - GitHub
Enterprise Cloud Docs
Code scanning
• GitHubリポジトリ上のコードに対する脆弱性を検出・管理できる機能
• GitHub が提供する CodeQL を用いて解析
• GitHub Actions を利用して容易に導入できる
• 各種言語に応じた汎用的なクエリが用意されている、カスタマイズも可能
• 参考: About code scanning with CodeQL - GitHub Docs
• サードパーティ製の静的解析ツールであっても、SARIF形式のレポー
トで出力できれば、統合して利用できる
Code scanning のレポート一覧
Code scanning のレポート
参考: About code scanning alerts - GitHub Docs
Code scanning のレポート(tfsec)
GitHub セキュリティ関連機能の対応
機能 Public リポ Private リポ(GHASなし) Private リポ(GHASあり)
Dependabot alerts 〇 〇 〇
Dependabot security updates 〇 〇 〇
Dependabot version updates 〇 〇 〇
Dependency review 〇 × 〇
Secret scanning
〇 ×
〇
+ カスタマイズ
Code scanning 〇 × 〇
GitHub セキュリティ関連機能の対応
機能 Public リポ Private リポ(GHASなし) Private リポ(GHASあり)
Dependabot alerts 〇 〇 〇
Dependabot security updates 〇 〇 〇
Dependabot version updates 〇 〇 〇
Dependency review 〇 × 〇
Secret scanning
〇 ×
〇
+ カスタマイズ
Code scanning 〇 × 〇
GitHub Advanced Security のライセンスを導入すれば、
Private リポジトリでも利用可能
GitHub Advanced Security
• GitHub Enterprise Cloud または Server に対して付与できるセ
キュリティライセンス
• Privateリポジトリに対しても、下記を利用できる
• Dependency review
• Secret scanning (パートナーパターンに加え、カスタマイズにも対応)
• Code scanning
開発フローにプラスしていく
開発フローにプラスしていく
便利も、安心も

More Related Content

PDF
GitHub と Azure でアプリケーションとインフラストラクチャの守りを固めるDevSecOps
PDF
地味だけど劇的に便利になるGitHubリポジトリ設定あれこれ
PDF
GitHub Codespaces と Azure でつくる、エンタープライズレベルの開発環境
PDF
[Developers Festa Sapporo 2020] Microsoft/GitHubが提供するDeveloper Cloud (Develop...
PDF
GitHub Actions と Azure PaaS でプルリクエストごとに環境を ~ Azure Static Web Apps と Containe...
PDF
GitHub最新情報キャッチアップ 2023年6月
PDF
Developers Summit 2023 9-D-1「もう悩まされない開発環境、プロジェクトで統一した環境をいつでもどこでも」
PDF
【BS13】チーム開発がこんなにも快適に!コーディングもデバッグも GitHub 上で。 GitHub Codespaces で叶えられるシームレスな開発
GitHub と Azure でアプリケーションとインフラストラクチャの守りを固めるDevSecOps
地味だけど劇的に便利になるGitHubリポジトリ設定あれこれ
GitHub Codespaces と Azure でつくる、エンタープライズレベルの開発環境
[Developers Festa Sapporo 2020] Microsoft/GitHubが提供するDeveloper Cloud (Develop...
GitHub Actions と Azure PaaS でプルリクエストごとに環境を ~ Azure Static Web Apps と Containe...
GitHub最新情報キャッチアップ 2023年6月
Developers Summit 2023 9-D-1「もう悩まされない開発環境、プロジェクトで統一した環境をいつでもどこでも」
【BS13】チーム開発がこんなにも快適に!コーディングもデバッグも GitHub 上で。 GitHub Codespaces で叶えられるシームレスな開発

Similar to 日々の開発フローにプラスする GitHub Actions ~ セキュリティ対策を取り込む (20)

PDF
VCS - Version Control System at Security and Programming camp 2011
PDF
GitHub Copilotとともに次の開発体験へ
PDF
Azure Functions 開発デプロイ環境を GitHub Codespaces で爆速に整える
PDF
@s_ssk13さん向けGitHub入門
PDF
20201008 GitHub at Microsoft
PDF
Azure Cosmos DB Emulator on Docker を GitHub Codespaces で動かす!
PDF
【BS8】GitHub Advanced Security で実践できる DevSecOps 対策
PPTX
Windows Azure Mobile Servicesによるアプリ構築
PDF
Elastic on Azure Integration & Building React UI Based Search App Using Azure...
KEY
Yapc2012資料
PDF
GitHub Actions で CI/CD
PDF
VS Code新機能紹介 2020-2021
PDF
Git & ブランチモデルで学ぶ バージョン管理入門
PDF
【de:code 2020】 Azure Kubernetes Service と Azure DevOps による GitOps の実践
PDF
App Service の DevOps と Visual Studio Team Services 最新アップデート
PDF
【de:code 2020】 GitHub と Azure Security Center による、アプリケーションのための Azure セキュリティ
PDF
GitHub Appsと回帰テストフロー
PDF
第0回仕様策定サブWG会合報告 - 仕様作成プロセスについて
PDF
【de:code 2020】 セキュアなソフトウェアを実現する、GitHub のコード解析のご紹介
PDF
DevOps on Azure Kubernetes
VCS - Version Control System at Security and Programming camp 2011
GitHub Copilotとともに次の開発体験へ
Azure Functions 開発デプロイ環境を GitHub Codespaces で爆速に整える
@s_ssk13さん向けGitHub入門
20201008 GitHub at Microsoft
Azure Cosmos DB Emulator on Docker を GitHub Codespaces で動かす!
【BS8】GitHub Advanced Security で実践できる DevSecOps 対策
Windows Azure Mobile Servicesによるアプリ構築
Elastic on Azure Integration & Building React UI Based Search App Using Azure...
Yapc2012資料
GitHub Actions で CI/CD
VS Code新機能紹介 2020-2021
Git & ブランチモデルで学ぶ バージョン管理入門
【de:code 2020】 Azure Kubernetes Service と Azure DevOps による GitOps の実践
App Service の DevOps と Visual Studio Team Services 最新アップデート
【de:code 2020】 GitHub と Azure Security Center による、アプリケーションのための Azure セキュリティ
GitHub Appsと回帰テストフロー
第0回仕様策定サブWG会合報告 - 仕様作成プロセスについて
【de:code 2020】 セキュアなソフトウェアを実現する、GitHub のコード解析のご紹介
DevOps on Azure Kubernetes
Ad

More from Kazumi OHIRA (20)

PDF
GitHub dockyardコミュニティ 竣工イベント!オープニング資料
PDF
高さ比べじゃない、キャリアは歩んできた道
PDF
突如登場したAzure Developer CLIでなにができるのか?検証してみる
PDF
GitHub Codespaces が拡げる開発環境、いつでもどこでも Visual Studio Code で!
PDF
女性エンジニアコミュニティから見える価値観のリアル
PDF
「あの人の自分戦略を聞きたい!2022」~ 大平かづみの場合
PDF
本領を発揮するために、まずバリアを開放できる場を
PDF
【NLU祭り 場外編】コミュニケーションをより身近に、よりかしこく。LUIS と Azure AI サービスの使いどころ
PDF
「 Azure 」にデータを溜めて活用する のご紹介 - 「はじめてのNode-RED ver.1.3.0対応版」書籍出版記念イベント LT
PDF
Code Polaris 紹介(Woman type イベント「女性エンジニアのキャリアのお悩み相談室 with Code Polaris」)
PDF
Azure Rock Star Community Day #2 - Cogbot Community スタッフが選ぶ Microsoft Learn コ...
PDF
LINE LIFF with Azure ハンズオン資料 - Azure サービス解説
PDF
Code Polaris meetup #2
PDF
Code Polaris meetup #1
PDF
TypeScript x Bot Framework
PDF
de:code 夏まつり クイズクライアント作ったよ!
PDF
観たいセッションがかぶった!なんて心配ご無用。今年は、興味の赴くままにあれもこれも♪
PDF
Cogbot コミュニティのご紹介 #MSBuild #COM173
PDF
TOMORROW IS IN YOUR HANDS - テクノロジ・ブーストをまとい、生き抜くために - Microsoft Ignite The Tou...
PDF
Azure サーバレスアーキテクチャを支える Infrastructure as Code - Microsoft Ignite The Tour 202...
GitHub dockyardコミュニティ 竣工イベント!オープニング資料
高さ比べじゃない、キャリアは歩んできた道
突如登場したAzure Developer CLIでなにができるのか?検証してみる
GitHub Codespaces が拡げる開発環境、いつでもどこでも Visual Studio Code で!
女性エンジニアコミュニティから見える価値観のリアル
「あの人の自分戦略を聞きたい!2022」~ 大平かづみの場合
本領を発揮するために、まずバリアを開放できる場を
【NLU祭り 場外編】コミュニケーションをより身近に、よりかしこく。LUIS と Azure AI サービスの使いどころ
「 Azure 」にデータを溜めて活用する のご紹介 - 「はじめてのNode-RED ver.1.3.0対応版」書籍出版記念イベント LT
Code Polaris 紹介(Woman type イベント「女性エンジニアのキャリアのお悩み相談室 with Code Polaris」)
Azure Rock Star Community Day #2 - Cogbot Community スタッフが選ぶ Microsoft Learn コ...
LINE LIFF with Azure ハンズオン資料 - Azure サービス解説
Code Polaris meetup #2
Code Polaris meetup #1
TypeScript x Bot Framework
de:code 夏まつり クイズクライアント作ったよ!
観たいセッションがかぶった!なんて心配ご無用。今年は、興味の赴くままにあれもこれも♪
Cogbot コミュニティのご紹介 #MSBuild #COM173
TOMORROW IS IN YOUR HANDS - テクノロジ・ブーストをまとい、生き抜くために - Microsoft Ignite The Tou...
Azure サーバレスアーキテクチャを支える Infrastructure as Code - Microsoft Ignite The Tour 202...
Ad

日々の開発フローにプラスする GitHub Actions ~ セキュリティ対策を取り込む