OpenAI
Cette page a été traduite automatiquement. Afficher l’article original en anglais.

Instructions d’intégration OpenAI / AWS EKM

Instructions étape par étape pour configurer AWS et activer EKM

Mise à jour : 13 days ago

Aperçu

Enterprise Key Management (EKM) permet à OpenAI de chiffrer les données à l’aide d’une clé maîtresse que vous contrôlez. Ce document explique comment configurer votre compte AWS pour accorder à OpenAI des autorisations limitées sur votre KMS.

AWS EKM integration flow between OpenAI EKM Service, your STS, your KMS, and your master KEK

Étapes

1. Créez une nouvelle clé KMS

  1. Allez à KMS -> Customer managed keys, puis cliquez sur Create Key

  2. Sélectionnez un algorithme de chiffrement symétrique

  3. Une fois votre clé créée, notez son ARN. Les formats pris en charge comprennent arn:aws:kms:<region>:<account_number>:key/<uuid>, ...:key/mrk-*, ou ...:alias/<alias_name>

    AWS KMS customer managed key details page with key ID and ARN for test-kms

2. Créez une politique personnalisée pour un accès limité à la clé KMS

  1. Allez à IAM -> Policies, puis cliquez sur Create Policy

  2. À l’étape Specify permissions, sélectionnez JSON et saisissez ce qui suit pour donner à la politique les actions d’accès KMS. Assurez-vous de remplacer YOUR_KMS_ARN par l’ARN de la clé que vous avez créée.

    AWS IAM Create policy page with Specify permissions open and the JSON policy editor selected
    {
        "Version": "2012-10-17",
        "Statement": [
            {
                "Sid": "AllowEncryptDecrypt",
                "Effect": "Allow",
                "Action": [

                    "kms:Decrypt",
                    "kms:Encrypt"

                ],
                "Resource": <YOUR_KMS_ARN>
            }
        ]
    }

3. Créez un rôle IAM que OpenAI pourra assumer et attribuez-lui la politique avec accès limité à votre KMS

OpenAI appellera AssumeRole à partir d’un compte AWS appartenant à OpenAI. Cette étape reconnaît que le principal AWS d’OpenAI peut assumer le rôle limité pour accéder à votre KMS.

  1. Allez à IAM -> Roles, puis cliquez sur Create Role

  2. À l’étape Select trusted entity, sélectionnez Custom trust policy

    AWS IAM Select trusted entity screen with Custom trust policy selected
  3. Saisissez ce qui suit dans la custom trust policy pour autoriser l’accès au principal AWS d’OpenAI.

    1. Le principal est le principal AWS d’OpenAI - arn:aws:iam::790389265272:role/EnterpriseKeyManagement

    2. Indiquez quel Externald OpenAI doit transmettre pendant le processus AssumeRole.

      1. Pour ChatGPT ou l’API, vous pouvez utiliser l’ID d’organisation (org-xxx) associé à votre espace de travail - https://platform.api.openai.org/settings/organization/general

      2. Pour l’API, vous pouvez indiquer un ID de projet API précis pour une granularité accrue

        {
            "Version": "2012-10-17",
            "Statement": [
                {
                    "Effect": "Allow",
                    "Principal": {
                        "AWS": "arn:aws:iam::790389265272:role/EnterpriseKeyManagement"
                    },
                    "Action": "sts:AssumeRole",
                    "Condition": {
                        "StringEquals": {
                            "sts:ExternalId": [
                                 <YOUR_OPENAI_ORGANIZATION_ID>,
                             ]
                        }
                    }
                }
            ]
        }
  4. À l’étape Add permissions, recherchez le nom de la politique IAM que vous avez créée à l’étape précédente. Cliquez sur la case à cocher à côté du nom de la politique, puis cliquez sur Next.

    AWS IAM Add permissions page filtered to customer managed KMS policies with test-allow-kms-access selected
  5. Dans la section Name, review, and create, choisissez n’importe quel nom de rôle.

4. Appliquez toute restriction additionnelle conforme à vos propres pratiques de sécurité

Ci-dessus se trouve l’information minimale requise dont OpenAI a besoin pour configurer EKM. Vous êtes libre d’appliquer des politiques de clé ou des restrictions supplémentaires conformes à vos propres pratiques de sécurité internes, tant qu’OpenAI peut appeler les opérations de chiffrement et de déchiffrement sur votre KMS. Lorsque vous appelez avec OpenAI l’endpoint d’enregistrement de clé décrit ci-dessous, nous validerons votre configuration.

Après avoir terminé les étapes ci-dessus

ChatGPT Enterprise

Veuillez communiquer avec votre contact OpenAI et lui transmettre ce qui suit :

  • "role_arn": "arn:aws:iam::<YOUR_AWS_ACCOUNT_NUMBER>:role/<YOUR_ROLE>",

    • L’ARN du rôle que OpenAI assumera dans votre nuage

  • "kms_arn": "arn:aws:kms:<REGION>:<YOUR_AWS_ACCOUNT_NUMBER>:key/<UUID>"

    • L’ARN du Key Management System pour la clé maîtresse que vous gérez

Nous activerons EKM pour votre organisation/espace de travail ChatGPT.

API

Enregistrez votre clé externe auprès d’OpenAI

Suivez les instructions de cette référence d’API Clés externes dans l’API de gestion

  1. Tout d’abord, enregistrez votre clé externe au niveau de l’organisation OpenAI, ce qui générera un ID de clé externe.

  2. À cette étape, nous validerons que votre entrée est valide et que nous pouvons nous authentifier auprès de votre KMS.

  3. Cela n’ajoutera pas encore EKM à votre projet OpenAI.

    curl -X POST \
    -H "Content-type: application/json" \
    -H "Authorization: Bearer $TOKEN" \

    "https://api.openai.com/v1/organization/external_keys" \
    -d '{
      "type": "aws",
      "name": "Config AWS EKM",
      "role_arn": "arn:aws:iam::<YOUR_AWS_ACCOUNT_NUMBER>:role/<YOUR_ROLE>",
      "kms_arn": "arn:aws:kms:<REGION>:<YOUR_AWS_ACCOUNT_NUMBER>:key/<UUID>",
      "external_id": <votre ID d’organisation ou ID de projet>
    }'
  4. Ensuite, créez un projet OpenAI associé à la clé externe. Après cela, EKM est activé sur votre projet.

  5. Le corps de réponse de cet appel d’API vous donnera l’ID du projet (proj_xxx)

    curl -X POST \
    -H "Content-type: application/json" \
    -H "Authorization: Bearer $TOKEN" \
    "https://api.openai.com/v1/organization/projects" \
    -d '{
       "name": "Un projet",

       "external_key_id": "extkey_xxxx"
    }'

Cet article vous a-t-il été utile?