SSL証明書API
certificates
APIは、Elasticsearchクラスター内の通信を暗号化するために使用されるX.509証明書に関する情報を取得することを可能にします。
リクエスト
GET /_ssl/certificates
前提条件
- セキュリティ機能が有効になっている場合、このAPIを使用するには
monitor
クラスター権限が必要です。詳細については、セキュリティ権限を参照してください。
説明
証明書がトランスポート層セキュリティ(TLS)とどのように構成されているかについての詳細は、TLSを使用したノード間通信の暗号化を参照してください。
APIは、次のすべてのTLSコンテキストからの証明書を含むリストを返します:
- トランスポートおよびHTTPインターフェースの設定
- 認証領域内で使用されるTLS設定
- リモートモニタリングエクスポータのTLS設定
リストには、xpack.security.transport.ssl.truststore
およびxpack.security.transport.ssl.certificate_authorities
設定で構成された信頼の設定に使用される証明書が含まれています。また、xpack.security.http.ssl.keystore
およびxpack.security.http.ssl.certificate
設定のように、サーバーのアイデンティティを構成するために使用される証明書も含まれています。
リストには、Elasticsearch内で使用されている場合でも、Java Runtime Environment(JRE)のデフォルトSSLコンテキストから取得された証明書は含まれません。
PKCS#11トークンがJREのトラストストアとして構成されている場合、APIは、これらがElasticsearchのTLS構成で使用されているかどうかに関係なく、PKCS#11トークンに含まれるすべての証明書を返します。
Elasticsearchがキーストアまたはトラストストアを使用するように構成されている場合、APIの出力には、そのストア内のすべての証明書が含まれますが、一部の証明書はクラスター内でアクティブに使用されていない可能性があります。
レスポンスボディ
レスポンスはオブジェクトの配列であり、各オブジェクトは単一の証明書を表します。各オブジェクトのフィールドは次のとおりです:
path
- (文字列)
elasticsearch.yml
ファイルに構成された証明書へのパス。 format
- (文字列) ファイルの形式。次のいずれか:
jks
、PKCS12
、PEM
。 alias
- (文字列) パスがコンテナファイル(jksキーストアまたはPKCS#12ファイル)を指す場合、証明書のエイリアス。それ以外の場合はnull。
subject_dn
- (文字列) 証明書のサブジェクトの識別名。
serial_number
- (文字列) 証明書のシリアル番号の16進数表現。
has_private_key
- (Boolean) Elasticsearchがこの証明書の秘密鍵にアクセスできるかどうかを示します。
expiry
- (文字列) 証明書の有効期限(not-after)の日付のISO形式。
issuer
- (文字列) 証明書の発行者の識別名。
例
以下の例は、Elasticsearchの単一ノード上の証明書に関する情報を提供します:
Python
resp = client.ssl.certificates()
print(resp)
Js
const response = await client.ssl.certificates();
console.log(response);
コンソール
GET /_ssl/certificates
APIは次の結果を返します:
Js
[
{
"path": "certs/elastic-certificates.p12",
"format": "PKCS12",
"alias": "instance",
"subject_dn": "CN=Elastic Certificate Tool Autogenerated CA",
"serial_number": "a20f0ee901e8f69dc633ff633e5cd5437cdb4137",
"has_private_key": false,
"expiry": "2021-01-15T20:42:49.000Z"
},
{
"path": "certs/elastic-certificates.p12",
"format": "PKCS12",
"alias": "ca",
"subject_dn": "CN=Elastic Certificate Tool Autogenerated CA",
"serial_number": "a20f0ee901e8f69dc633ff633e5cd5437cdb4137",
"has_private_key": false,
"expiry": "2021-01-15T20:42:49.000Z"
},
{
"path": "certs/elastic-certificates.p12",
"format": "PKCS12",
"alias": "instance",
"subject_dn": "CN=instance",
"serial_number": "fc1905e1494dc5230218d079c47a617088f84ce0",
"has_private_key": true,
"expiry": "2021-01-15T20:44:32.000Z"
}
]