正式なドキュメントは英語版であり、この日本語訳はAI支援翻訳により作成された参考用のものです。日本語訳の一部の内容は人間によるレビューがまだ行われていないため、翻訳のタイミングにより英語版との間に差異が生じることがあります。最新かつ正確な情報については、英語版をご参照ください。

Pagesドメイン

  • プラン: Free、Premium、Ultimate
  • 提供形態: GitLab.com、GitLab Self-Managed

GitLab PagesでカスタムドメインとTLS証明書を接続するためのエンドポイント。

これらのエンドポイントを使用するには、GitLab Pages機能を有効にする必要があります。機能の管理使用に関する詳細をご覧ください。

すべてのPagesドメインをリスト表示

前提要件:

  • インスタンスへの管理者アクセス権が必要です。

すべてのPagesドメインのリストを取得します。

GET /pages/domains

成功した場合、200と次のレスポンス属性を返します:

属性説明
domain文字列GitLab Pagesサイトのカスタムドメイン名。
url文字列プロトコルを含む、Pagesサイトの完全なURL。
project_id整数このPagesドメインに関連付けられているGitLabプロジェクトのID。
verifiedブール値ドメインが確認されたかどうかを示します。
verification_code文字列ドメインの所有権を確認するために使用される一意のレコード。
enabled_until日付ドメインが有効になっている日付。これは、ドメインが再検証されると定期的に更新されます。
auto_ssl_enabledブール値自動生成 SSL証明書(Let’s Encryptを使用)が、このドメインに対して有効になっているかどうかを示します。
certificate_expirationオブジェクトSSL証明書の有効期限に関する情報。
certificate_expiration.expiredブール値SSL証明書の有効期限が切れているかどうかを示します。
certificate_expiration.expiration日付SSL証明書の有効期限の日時。

リクエスト例:

curl --header "PRIVATE-TOKEN: <your_access_token>" "https://gitlab.example.com/api/v4/pages/domains"

レスポンス例:

[
  {
    "domain": "ssl.domain.example",
    "url": "https://ssl.domain.example",
    "project_id": 1337,
    "verified": true,
    "verification_code": "1234567890abcdef",
    "enabled_until": "2020-04-12T14:32:00.000Z",
    "auto_ssl_enabled": false,
    "certificate": {
      "expired": false,
      "expiration": "2020-04-12T14:32:00.000Z"
    }
  }
]

Pagesドメインをリスト表示

プロジェクトのPagesドメインのリストを取得します。ユーザーはPagesドメインを表示するための権限を持っている必要があります。

GET /projects/:id/pages/domains

サポートされている属性は以下のとおりです:

属性必須説明
id整数または文字列はいプロジェクトのIDまたはURLエンコードされたパス

成功した場合、200と次のレスポンス属性を返します:

属性説明
domain文字列GitLab Pagesサイトのカスタムドメイン名。
url文字列プロトコルを含む、Pagesサイトの完全なURL。
verifiedブール値ドメインが確認されたかどうかを示します。
verification_code文字列ドメインの所有権を確認するために使用される一意のレコード。
enabled_until日付ドメインが有効になっている日付。これは、ドメインが再検証されると定期的に更新されます。
auto_ssl_enabledブール値自動生成 SSL証明書(Let’s Encryptを使用)が、このドメインに対して有効になっているかどうかを示します。
certificateオブジェクトSSL証明書に関する情報。
certificate.subject文字列SSL証明書のサブジェクト(通常はドメインに関する情報を含む)。
certificate.expired日付SSL証明書の有効期限が切れている(true)か、まだ有効(false)かを示します。
certificate.certificate文字列PEM形式の完全なSSL証明書。
certificate.certificate_text日付発行者、有効期間、サブジェクト、その他の証明書情報など、SSL証明書を人間が読める形式で表現したテキスト。

リクエスト例:

curl --request GET \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/pages/domains"

レスポンス例:

[
  {
    "domain": "www.domain.example",
    "url": "http://www.domain.example",
    "verified": true,
    "verification_code": "1234567890abcdef",
    "enabled_until": "2020-04-12T14:32:00.000Z",
    "auto_ssl_enabled": false,
  },
  {
    "domain": "ssl.domain.example",
    "url": "https://ssl.domain.example",
    "verified": true,
    "verification_code": "1234567890abcdef",
    "enabled_until": "2020-04-12T14:32:00.000Z",
    "auto_ssl_enabled": false,
    "certificate": {
      "subject": "/O=Example, Inc./OU=Example Origin CA/CN=Example Origin Certificate",
      "expired": false,
      "certificate": "-----BEGIN CERTIFICATE-----\n … \n-----END CERTIFICATE-----",
      "certificate_text": "Certificate:\n … \n"
    }
  }
]

単一のPagesドメイン

単一のプロジェクトPagesドメインを取得します。ユーザーはPagesドメインを表示するための権限を持っている必要があります。

GET /projects/:id/pages/domains/:domain

サポートされている属性は以下のとおりです:

属性必須説明
id整数または文字列はいプロジェクトのIDまたはURLエンコードされたパス
domain文字列はいユーザーが指定したカスタムドメイン

成功した場合、200と次のレスポンス属性を返します:

属性説明
domain文字列GitLab Pagesサイトのカスタムドメイン名。
url文字列プロトコルを含む、Pagesサイトの完全なURL。
verifiedブール値ドメインが確認されたかどうかを示します。
verification_code文字列ドメインの所有権を確認するために使用される一意のレコード。
enabled_until日付ドメインが有効になっている日付。これは、ドメインが再検証されると定期的に更新されます。
auto_ssl_enabledブール値自動生成 SSL証明書(Let’s Encryptを使用)が、このドメインに対して有効になっているかどうかを示します。
certificateオブジェクトSSL証明書に関する情報。
certificate.subject文字列SSL証明書のサブジェクト(通常はドメインに関する情報を含む)。
certificate.expired日付SSL証明書の有効期限が切れている(true)か、まだ有効(false)かを示します。
certificate.certificate文字列PEM形式の完全なSSL証明書。
certificate.certificate_text日付発行者、有効期間、サブジェクト、その他の証明書情報など、SSL証明書を人間が読める形式で表現したテキスト。

リクエスト例:

curl --request GET \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/pages/domains/ssl.domain.example"

レスポンス例:

{
  "domain": "ssl.domain.example",
  "url": "https://ssl.domain.example",
  "verified": true,
  "verification_code": "1234567890abcdef",
  "enabled_until": "2020-04-12T14:32:00.000Z",
  "auto_ssl_enabled": false,
  "certificate": {
    "subject": "/O=Example, Inc./OU=Example Origin CA/CN=Example Origin Certificate",
    "expired": false,
    "certificate": "-----BEGIN CERTIFICATE-----\n … \n-----END CERTIFICATE-----",
    "certificate_text": "Certificate:\n … \n"
  }
}

新しいPagesドメインを作成

新しいPagesドメインを作成します。ユーザーは新しいPagesドメインを作成するための権限を持っている必要があります。

POST /projects/:id/pages/domains

サポートされている属性は以下のとおりです:

属性必須説明
id整数または文字列はいプロジェクトのIDまたはURLエンコードされたパス
domain文字列はいユーザーが指定したカスタムドメイン
auto_ssl_enabledブール値いいえLet’s Encryptによって発行されたSSL証明書の自動生成をカスタムドメインに対して有効にします。
certificateファイル/文字列いいえ最も限定的な順序で中間証明書が続くPEM形式の証明書。
keyファイル/文字列いいえPEM形式の証明書キー。

成功した場合、201と次のレスポンス属性を返します:

属性説明
domain文字列GitLab Pagesサイトのカスタムドメイン名。
url文字列プロトコルを含む、Pagesサイトの完全なURL。
verifiedブール値ドメインが確認されたかどうかを示します。
verification_code文字列ドメインの所有権を確認するために使用される一意のレコード。
enabled_until日付ドメインが有効になっている日付。これは、ドメインが再検証されると定期的に更新されます。
auto_ssl_enabledブール値自動生成 SSL証明書(Let’s Encryptを使用)が、このドメインに対して有効になっているかどうかを示します。
certificateオブジェクトSSL証明書に関する情報。
certificate.subject文字列SSL証明書のサブジェクト(通常はドメインに関する情報を含む)。
certificate.expired日付SSL証明書の有効期限が切れている(true)か、まだ有効(false)かを示します。
certificate.certificate文字列PEM形式の完全なSSL証明書。
certificate.certificate_text日付発行者、有効期間、サブジェクト、その他の証明書情報など、SSL証明書を人間が読める形式で表現したテキスト。

リクエストの例:

.pemファイルから証明書を使用して、新しいPagesドメインを作成します:

curl --request POST \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/pages/domains" \
  --form "domain=ssl.domain.example" \
  --form "certificate=@/path/to/cert.pem" \
  --form "key=@/path/to/key.pem"

証明書を含む変数を使用して、新しいPagesドメインを作成します:

curl --request POST \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/pages/domains" \
  --form "domain=ssl.domain.example" \
  --form "certificate=$CERT_PEM" \
  --form "key=$KEY_PEM"

自動証明書を使用して、新しいPagesドメインを作成します:

curl --request POST --header "PRIVATE-TOKEN: <your_access_token>" --form "domain=ssl.domain.example" \
     --form "auto_ssl_enabled=true" "https://gitlab.example.com/api/v4/projects/5/pages/domains"

レスポンス例:

{
  "domain": "ssl.domain.example",
  "url": "https://ssl.domain.example",
  "auto_ssl_enabled": true,
  "certificate": {
    "subject": "/O=Example, Inc./OU=Example Origin CA/CN=Example Origin Certificate",
    "expired": false,
    "certificate": "-----BEGIN CERTIFICATE-----\n … \n-----END CERTIFICATE-----",
    "certificate_text": "Certificate:\n … \n"
  }
}

Pagesドメインを更新

既存のプロジェクトPagesドメインを更新します。ユーザーは既存のPagesドメインを変更するための権限を持っている必要があります。

PUT /projects/:id/pages/domains/:domain

サポートされている属性は以下のとおりです:

属性必須説明
id整数または文字列はいプロジェクトのIDまたはURLエンコードされたパス
domain文字列はいユーザーが指定したカスタムドメイン
auto_ssl_enabledブール値いいえLet’s Encryptによって発行されたSSL証明書の自動生成をカスタムドメインに対して有効にします。
certificateファイル/文字列いいえ最も限定的な順序で中間証明書が続くPEM形式の証明書。
keyファイル/文字列いいえPEM形式の証明書キー。

成功した場合、200と次のレスポンス属性を返します:

属性説明
domain文字列GitLab Pagesサイトのカスタムドメイン名。
url文字列プロトコルを含む、Pagesサイトの完全なURL。
verifiedブール値ドメインが確認されたかどうかを示します。
verification_code文字列ドメインの所有権を確認するために使用される一意のレコード。
enabled_until日付ドメインが有効になっている日付。これは、ドメインが再検証されると定期的に更新されます。
auto_ssl_enabledブール値自動生成 SSL証明書(Let’s Encryptを使用)が、このドメインに対して有効になっているかどうかを示します。
certificateオブジェクトSSL証明書に関する情報。
certificate.subject文字列SSL証明書のサブジェクト(通常はドメインに関する情報を含む)。
certificate.expired日付SSL証明書の有効期限が切れている(true)か、まだ有効(false)かを示します。
certificate.certificate文字列PEM形式の完全なSSL証明書。
certificate.certificate_text日付発行者、有効期間、サブジェクト、その他の証明書情報など、SSL証明書を人間が読める形式で表現したテキスト。

証明書を追加

.pemファイルから証明書をPagesドメインに追加します:

curl --request PUT \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/pages/domains/ssl.domain.example" \
  --form "certificate=@/path/to/cert.pem" \
  --form "key=@/path/to/key.pem"

証明書を含む変数を使用して、Pagesドメインの証明書を追加します:

curl --request PUT \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/pages/domains/ssl.domain.example" \
  --form "certificate=$CERT_PEM" \
  --form "key=$KEY_PEM"

レスポンス例:

{
  "domain": "ssl.domain.example",
  "url": "https://ssl.domain.example",
  "auto_ssl_enabled": false,
  "certificate": {
    "subject": "/O=Example, Inc./OU=Example Origin CA/CN=Example Origin Certificate",
    "expired": false,
    "certificate": "-----BEGIN CERTIFICATE-----\n … \n-----END CERTIFICATE-----",
    "certificate_text": "Certificate:\n … \n"
  }
}

PagesカスタムドメインのLet’s Encryptインテグレーションを有効にする

curl --request PUT \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/pages/domains/ssl.domain.example" \
  --form "auto_ssl_enabled=true"

レスポンス例:

{
  "domain": "ssl.domain.example",
  "url": "https://ssl.domain.example",
  "auto_ssl_enabled": true
}

証明書を削除

Pagesドメインに添付されているSSL証明書を削除するには、次を実行します:

curl --request PUT \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/pages/domains/ssl.domain.example" \
  --form "certificate=" \
  --form "key="

レスポンス例:

{
  "domain": "ssl.domain.example",
  "url": "https://ssl.domain.example",
  "auto_ssl_enabled": false
}

Pagesドメインを確認

既存のプロジェクトPagesドメインを確認します。ユーザーはPagesドメインを更新するための権限を持っている必要があります。

PUT /projects/:id/pages/domains/:domain/verify

サポートされている属性は以下のとおりです:

属性必須説明
id整数または文字列はいプロジェクトのIDまたはURLエンコードされたパス
domain文字列はい確認するカスタムドメイン

成功した場合、200と次のレスポンス属性を返します:

属性説明
domain文字列GitLab Pagesサイトのカスタムドメイン名。
url文字列プロトコルを含む、Pagesサイトの完全なURL。
verifiedブール値ドメインが確認されたかどうかを示します。
verification_code文字列ドメインの所有権を確認するために使用される一意のレコード。
enabled_until日付ドメインが有効になっている日付。これは、ドメインが再検証されると定期的に更新されます。
auto_ssl_enabledブール値自動生成 SSL証明書(Let’s Encryptを使用)が、このドメインに対して有効になっているかどうかを示します。
certificateオブジェクトSSL証明書に関する情報。
certificate.subject文字列SSL証明書のサブジェクト(通常はドメインに関する情報を含む)。
certificate.expired日付SSL証明書の有効期限が切れている(true)か、まだ有効(false)かを示します。
certificate.certificate文字列PEM形式の完全なSSL証明書。
certificate.certificate_text日付発行者、有効期間、サブジェクト、その他の証明書情報など、SSL証明書を人間が読める形式で表現したテキスト。

リクエスト例:

curl --request PUT \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/pages/domains/ssl.domain.example/verify"

レスポンス例:

{
  "domain": "ssl.domain.example",
  "url": "https://ssl.domain.example",
  "auto_ssl_enabled": false,
  "verified": true,
  "verification_code": "1234567890abcdef",
  "enabled_until": "2020-04-12T14:32:00.000Z"
}

Pagesドメインを削除

既存のプロジェクトPagesドメインを削除します。

DELETE /projects/:id/pages/domains/:domain

サポートされている属性は以下のとおりです:

属性必須説明
id整数または文字列はいプロジェクトのIDまたはURLエンコードされたパス
domain文字列はいユーザーが指定したカスタムドメイン

成功した場合、空の本体を持つ204 No Content HTTPレスポンスが予期されます。

リクエスト例:

curl --request DELETE \
  --header "PRIVATE-TOKEN: <your_access_token>" \
  --url "https://gitlab.example.com/api/v4/projects/5/pages/domains/ssl.domain.example"