コンテンツにスキップ

GitHubからのSSH用の公開鍵を取得

さくらのクラウドのコントロールパネルには、GitHub上のユーザー名を指定してSSH用の公開鍵を取得しサーバ作成時に利用する機能があります。
この機能をTerraformで実現するためにhttpプロバイダーが利用可能です。

# GitHub上の公開鍵を参照するためのデータソース
data "http" "key" {
  url = "https://github.com/<GitHubのユーザ名>.keys" # 任意のユーザー名に置き換える
}

GitHubから公開鍵を取得してサーバ作成に利用するコード例は以下の通りです。

terraform {
  required_providers {
    http = {
      source  = "hashicorp/http"
      version = "~> 3"
    }
    sakuracloud = {
      source  = "sacloud/sakuracloud"
      version = "~> 2"
    }
  }
}

data "sakuracloud_archive" "ubuntu" {
  os_type = "ubuntu2204"
}

resource "sakuracloud_disk" "example" {
  name              = "example"
  source_archive_id = data.sakuracloud_archive.ubuntu.id
}

resource "sakuracloud_server" "example" {
  name  = "example"
  disks = [sakuracloud_disk.example.id]

  network_interface {
    upstream = "shared"
  }

  disk_edit_parameter {
    disable_pw_auth = true
    ssh_keys        = split("\n", trimspace(data.http.key.response_body)) // Note: 複数の公開鍵が登録されている場合は改行で結合されている
  }
}

data "http" "key" {
  url = "https://github.com/<GitHubのユーザ名>.keys" # 任意のユーザー名に置き換える
}