Security Scores API と Security Profiles API

このページの内容は ApigeeApigee ハイブリッドに該当します。

Apigee Edge のドキュメントはこちらをご覧ください。

概要

このページでは、API を使用してリスク評価のセキュリティ スコアとセキュリティ プロファイル(単に「プロファイル」とも呼ばれます)を管理する方法について説明します。このページでは、API リクエストの例を示します。

制限事項など、リスク評価機能の概要と UI の使用手順については、リスク評価の概要と UI をご覧ください。

リスク評価 v2 API の例

v2 API サンプルのパラメータ

このセクションの例では、次のパラメータを使用できます。

  • ORG は、あなたの組織です。
  • ENV は、スコアを計算する環境です。
  • PROFILE_ID は、プロファイルの名前です。PROFILE_ID は、google-default または作成したカスタム プロファイルの名前です。
  • PROFILE_DESC(省略可)は、プロファイルの説明です。プロファイルの人間が読める説明で、他のプロファイルと区別するのに十分な情報を提供する必要があります。
  • PROXY_NAME: プロキシの名前。
  • $TOKEN は、OAuth アクセス トークンの環境変数です。

バッチ セキュリティ評価の結果を取得する

Security Admin ロールまたは Security Viewer ロールを持つユーザーには、アドホックなリスク評価計算を実行する権限が付与されています。評価するセキュリティ プロファイル、スコープ(Apigee 環境)、リソースを指定する必要があります。リソースは、スコープ内のすべてのリソースで計算する include_all_resources: true にすることも、少数のリソースで計算することもできます。この機能の詳細については、Apigee Management API リファレンス ドキュメントの securityAssessmentResults.batchCompute をご覧ください。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityAssessmentResults:batchCompute" \
  -X POST \
  -H "Authorization: Bearer $TOKEN"
  -H 'Content-type: application/json' \
  -d '{
    "profile": "google-default",
    "scope": "ENV",
    "include_all_resources": {}
  }'

リクエストに対するレスポンスは次のようになります。

  {
    "security_assessment_results": [
      {
        "resource": {
          "name" : "my-proxy-1",
          "revision": "1"
        },
        "create_time": "2023-11-22T03:04:05Z",
        "score": 99,
        "severity": "low",
        "failed_assessment_by_weight": {
          "MINOR": 1
        },
        "assessment_recommendations": {
          "CORS-Check": {
            "weight": "MINOR",
            "recommendations": [
              {
                "description": "add CORS policy to your proxy",
                "learn_more_link": "https://example.com"
              }
            ]
          }
        }
      },
      {
        "resource": {
          "name" : "my-proxy-2",
          "revision": "3"
        },
        "create_time": "2023-11-22T03:04:05Z",
        "score": 100,
        "severity": "low",
        "resource_revision": "1",
        "failed_assessment_by_weight": {
          "MINOR": 0
        },
        "assessment_recommendations": {}
      }
    ]
  }

セキュリティ プロファイルを管理する

このセクションでは、API を使用してセキュリティ プロファイルを管理する例を示します。ただし、この例は網羅的なものではありません。詳細については、securityProfilesV2 API リファレンス ドキュメントをご覧ください。

既存のカスタム セキュリティ プロファイルを取得する

このコマンドは、プロジェクトのすべてのセキュリティ プロファイルの情報を取得します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfilesV2" \
      -H "Authorization: Bearer $TOKEN"

このコマンドは、特定のセキュリティ プロファイルのメタデータを取得します。google-default プロファイルとカスタム プロファイルに関する情報を取得するために使用できます。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfilesV2/PROFILE_ID" \
      -H "Authorization: Bearer $TOKEN"

新しいカスタム セキュリティ プロファイルを作成する

新しいカスタム セキュリティ プロファイルを作成するには、次のようなコマンドを使用します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfilesV2?security_profile_v2_id=PROFILE_ID" \
       -X POST \
       -H "Authorization: Bearer $TOKEN" \
       -H 'Content-type: application/json' \
       -d '{
          "description": "PROFILE_DESC",
          "profile_assessment_configs": {
            "auth-policies-check": {"weight": "MINOR"},
            "threat-policies-check": {"weight": "MODERATE"}
          }
       }'
}

既存のカスタム セキュリティ プロファイルを更新する

既存のプロファイルを更新するには、次のようなコマンドを使用します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfilesV2/PROFILE_ID?update_mask=UPDATE_MASK" \
       -X PATCH \
       -H "Authorization: Bearer $TOKEN" \
       -H 'Content-type: application/json' \
       -d '{"description": "PROFILE_DESC"}'

UPDATE_MASK は、存在する場合は descriptionprofile_assessment_configsdescription,profile_assessment_configs*(すべて)のいずれかです。* 更新マスクを指定した場合は、すべてのフィールドが更新されます。リクエストに値が含まれていない場合、値が削除される可能性があります。

update_mask を省略すると、更新リクエストで指定されたフィールドのみが更新されます。

カスタム セキュリティ プロファイルを削除する

カスタム セキュリティ プロファイルを削除する:

curl "https://apigee.googleapis.com/v1/organizations/$ORG/securityProfilesV2/PROFILE_ID" \
       -X DELETE \
       -H "Authorization: Bearer $TOKEN"

リスク評価 v1

このセクションでは、リスク評価 v1 API の情報と例を示します。

API 使用時のセキュリティ スコアの制限

Security Scores API と Profiles API からセキュリティ スコアを使用する場合については、次の制限事項があります。

  • サポートされている JSON の入力フィールド:
  • 複数の入力フィルタはサポートされていません。
  • レスポンスの影響フィールドはサポートされていません影響フィールドは、この推奨事項が総スコアに与える潜在的な影響です。これは、この推奨事項がスコアを改善することが重要であることを示しています。

API からの使用に固有ではない一般的なセキュリティ スコアの制限事項については、セキュリティ スコア v1 に関する制限事項をご覧ください。

API 呼び出しの例のパラメータ

以降のセクションでは、次のパラメータを使用できる API 呼び出しの例を示します。

  • ORG は、あなたの組織です。
  • ENV は、スコアを計算する環境です。
  • ENVGROUP は、環境を含む環境グループです。
  • PROFILE_ID は、プロファイルの名前です。PROFILE_ID は、default または作成したカスタム プロファイルの名前です。

    PROFILE_ID は 1 ~ 63 文字にする必要があります。小文字、0 ~ 9 の数字、ハイフンを使用できます。最初の文字は小文字にする必要があります。最後の文字は小文字か数字にする必要があります。

  • PROXY_NAME: プロキシの名前。
  • RESOURCES は次のいずれかです。
    • スコープ内のすべてのリソースに対して {"all_resources":true}
    • {"includes": { "resources": [{"name": "<proxy-name>"}]}: 指定した 1 つ以上のプロキシをモニタリングします。たとえば、my-proxy-1 というプロキシをモニタリングするには {"includes": { "resources": [{"name": "my-proxy-1"}]} を使用します。
    • {"excludes": { "resources": [{"name": "<proxy-name>"}]}: 1 つ以上の指定されたプロキシを除くすべてのリソースをモニタリングします。たとえば、{"excludes": { "resources": [{"name": "my-proxy-1"}]} は、my-proxy-1 というプロキシを除くすべてのリソースをモニタリングします。
  • $TOKEN は、OAuth アクセス トークンの環境変数です。
  • timeRange は、スコアの期間です。

リスク評価 v1 API の例

API でサポートされているフィルタ

次の表に、API でサポートされているフィルタと、そのコンポーネント パスを示します。

フィルタ コンポーネント パス
環境スコア /org@ORG/envgroup@ENVGROUP/env@ENV
基盤となるすべてのコンポーネントのソーススコア /org@ORG/envgroup@ENVGROUP/env@ENV/source
不正行為スコア /org@ORG/envgroup@ENVGROUP/env@ENV/source/abuse
すべてのプロキシのスコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies
特定のプロキシのスコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@PROXY_NAME
特定のプロキシのポリシースコア
  • /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@PROXY_NAME/policies
  • /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@PROXY_NAME/policies/individual
特定のプロキシのメディエーション ポリシースコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@PROXY_NAME/policies/individual/mediation
特定のプロキシのセキュリティ ポリシースコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@PROXY_NAME/policies/individual/security
特定のプロキシの認証ポリシースコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@PROXY_NAME/policies/individual/security/auth
特定のプロキシの CORS ポリシースコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@PROXY_NAME/policies/individual/security/cors
特定のプロキシの脅威ポリシースコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@PROXY_NAME/policies/individual/security/threat
環境内のすべてのプロキシのポリシースコア
  • /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@$proxy/policies
  • /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@$proxy/policies/individual
環境内のすべてのプロキシのメディエーション ポリシースコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@$proxy/policies/individual/mediation
環境内のすべてのプロキシのセキュリティ ポリシースコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@$proxy/policies/individual/security
環境内のすべてのプロキシの認証ポリシースコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@$proxy/policies/individual/security/auth
環境内のすべてのプロキシの CORS ポリシースコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@$proxy/policies/individual/security/cors
環境内のすべてのプロキシの脅威ポリシースコア /org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@$proxy/policies/individual/security/threat

デフォルトのセキュリティ プロファイルを使用する

次の例では、デフォルトのセキュリティ プロファイルを使用する方法を示します。例で使用されているパラメータについては、サンプルの API 呼び出しのパラメータをご覧ください。

デフォルトのセキュリティ プロファイルを環境に接続する

セキュリティ スコアを表示するには、セキュリティを評価する環境にプロファイルを接続する必要があります。デフォルトのセキュリティ プロファイルを環境に接続するには、次のコマンドを使用します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/default/environments" \
       -X POST \
       -d '{"name": "ENV"}' \
       -H 'Content-type: application/json' \
       -H "Authorization: Bearer $TOKEN"
デフォルトのセキュリティ プロファイルの定義を取得する

デフォルトのセキュリティ プロファイルの定義を取得するには、次のコマンドを入力します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/default" \
       -H 'Content-type: application/json' \
       -H "Authorization: Bearer $TOKEN"

デフォルトのセキュリティ プロファイルを環境から切断する

環境からデフォルトのプロファイルを接続解除する必要がある場合は、次のようにしてそれを実行できます。

  curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/default/environments/ENV" \
         -X DELETE
         -H 'Content-type: application/json' \
         -H "Authorization: Bearer $TOKEN"

カスタム セキュリティ プロファイルを使用する

次のいずれかの方法で、API 呼び出しでカスタム セキュリティ プロファイルを作成できます。

  • 呼び出しの本文でプロファイルを明示的に定義します。
  • プロファイル定義を含む JSON ファイルを呼び出しに添付します。

次のセクションでは、両方の方法の例を紹介します。例で使用されているパラメータについては、サンプルの API 呼び出しのパラメータをご覧ください。

サンプル API 呼び出しの次のフィールドで、カスタム プロファイルを指定します。

  • description: カスタム プロファイルの説明。
  • profileConfig: カスタム プロファイルに含めるカテゴリのリスト。これは、次のセキュリティ カテゴリの任意のサブセットになります。
    • abuse
    • authorization
    • cors
    • mtls
    • mediation
    • threat
API 呼び出しの本文でプロファイルを定義する

API 呼び出しの本文でカスタム プロファイルを定義するには、次のようなコマンドを入力します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles?security_profile_id=PROFILE_ID" \
       -X POST \
       -H "Authorization: Bearer $TOKEN" \
       -H "Content-Type: application/json" \
       -d '{
         "description":"test custom profile",
         "profileConfig" : {
           "categories":[
             {"cors":{}},
             {"threat":{}}
           ]
         }
       }'

これにより、カテゴリ cors と脅威を含むカスタム プロファイルが作成され、次のようなレスポンスが返されます。

{
  "name": "PROFILE_ID",
  "revisionId": "1",
  "revisionCreateTime": "2023-07-17T18:47:08Z",
  "revisionUpdateTime": "2023-07-17T18:47:08Z",
  "scoringConfigs": [
    {
      "title": "json",
      "scorePath": "/org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@$proxy/policies/individual/security/threat/json",
      "description": "Check if JSONThreatProtection policy is configured."
    },
    {
      "title": "xml",
      "scorePath": "/org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@$proxy/policies/individual/security/threat/xml",
      "description": "Check if XMLThreatProtection policy is configured."
    },
    {
      "title": "cors",
      "scorePath": "/org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@$proxy/policies/individual/security/cors",
      "description": "Check if CORS policy is configured."
    }
  ],
  "maxScore": 1200,
  "minScore": 200,
  "profileConfig": {
    "categories": [
      {
        "cors": {}
      },
      {
        "threat": {}
      }
    ]
  },
  "description": "test custom profile"
  }
API 呼び出しに JSON ファイルを関連付けてプロファイルを定義する

プロファイルを定義する JSON ファイルを API 呼び出しに添付して、カスタム セキュリティ プロファイルを定義することもできます。例として、次の JSON ファイルをまず作成します。

{
  "description": "test custom profile",
  "profileConfig" : {
    "categories":[
      {"cors":{}},
      {"threat" :{}},
    ]
  }
}

カテゴリ cors と脅威を含むプロファイルを定義します。その後、次のように、これらのカテゴリに基づいてプロファイルを作成できます。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles?security_profile_id=PROFILE_ID" \
       -X POST \
       -H "Authorization: Bearer $TOKEN" \
       -H "Content-Type: application/json" \
       -d @create_profile.json

ここで、create_profile.json は前述の JSON ファイルの名前です。

カスタム セキュリティ プロファイルの定義を取得する

カスタム セキュリティ プロファイルの定義を取得するには、次のようなコマンドを入力します。

  curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/PROFILE_ID" \
         -X GET \
         -H "Authorization: Bearer $TOKEN" \
         -H "Content-Type: application/json"
環境からカスタム セキュリティ プロファイルを切断する

環境からカスタム セキュリティ プロファイルを切断するには、次のようなコマンドを入力します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/PROFILE_ID/environments/ENV" \
       -X DELETE \
       -H "Authorization: Bearer $TOKEN" \
       -H "Content-Type: application/json"
カスタム セキュリティ プロファイルを削除する

カスタム セキュリティ プロファイルを削除するには、次のようなコマンドを入力します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/PROFILE_ID" \
       -X DELETE \
       -H "Authorization: Bearer $TOKEN" \
       -H "Content-Type: application/json"

環境のスコアを取得する

以降のセクションでは、環境のスコアを取得する例を示します。例で使用されているパラメータについては、サンプルの API 呼び出しのパラメータをご覧ください。

環境のすべてのスコアを取得する

環境のすべてのスコアを取得するには、次のようなコマンドを入力します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/PROFILE_ID/environments/ENV:computeEnvironmentScores" \
       -X POST \
       -d '{"timeRange":
              {
                "startTime": "YYYY-MM-DDT00:00:00Z",
                "endTime": "YYYY-MM-DDT00:00:00Z"
              }
           }' \
       -H 'Content-type: application/json' \
       -H "Authorization: Bearer $TOKEN"

リクエストとレスポンスの説明については、computeEnvironmentScores のリファレンス ページをご覧ください。

環境のソーススコアを取得する

環境のソーススコアを取得するには、次のようなコマンドを入力します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/PROFILE_ID/environments/ENV:computeEnvironmentScores" \
       -X POST \
       -d '{"timeRange":
              {
                "startTime": "YYYY-MM-DDT00:00:00Z",
                "endTime": "YYYY-MM-DDT00:00:00Z"
              },
            "filters": [{"scorePath": "/org@ORG/envgroup@ENVGROUP/env@ENV/source"}]
           }' \
       -H 'Content-type: application/json' \
       -H "Authorization: Bearer $TOKEN"
環境に対する移行元の不正行為スコアを取得する

環境の移行元における不正行為スコアを取得するには、次のようなコマンドを入力します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/PROFILE_ID/environments/ENV:computeEnvironmentScores" \
       -X POST \
       -d '{"timeRange":
              {
                "startTime": "YYYY-MM-DDT00:00:00Z",
                "endTime": "YYYY-MM-DDT00:00:00Z"
              },
            "filters": [{"scorePath": "/org@ORG/envgroup@ENVGROUP/env@ENV/source/abuse"}]
           }' \
       -H 'Content-type: application/json' \
       -H "Authorization: Bearer $TOKEN"
環境にあるすべてのプロキシのスコアを取得する

環境内のすべてのプロキシのスコアを取得するには、次のようなコマンドを入力します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/PROFILE_ID/environments/ENV:computeEnvironmentScores" \
       -X POST \
       -d '{"timeRange":
              {
                "startTime": "YYYY-MM-DDT00:00:00Z",
                "endTime": "YYYY-MM-DDT00:00:00Z"
              },
            "filters": [{"scorePath": "/org@ORG/envgroup@ENVGROUP/env@ENV/proxies"}]
           }' \
       -H 'Content-type: application/json' \
       -H "Authorization: Bearer $TOKEN"
環境にある特定のプロキシのスコアを取得する

環境内の特定のプロキシのスコアを取得するには、次のようなコマンドを入力します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/PROFILE_ID/environments/ENV:computeEnvironmentScores" \
       -X POST \
       -d '{"timeRange":
              {
                "startTime": "YYYY-MM-DDT00:00:00Z",
                "endTime": "YYYY-MM-DDT00:00:00Z"
              },
            "filters": [{"scorePath": "/org@ORG/envgroup@ENVGROUP/env@ENV/proxies/proxy@PROXY"}]
           }' \
       -H 'Content-type: application/json' \
       -H "Authorization: Bearer $TOKEN"

ここで、PROXY は、スコアを取得するプロキシです。

環境にある特定のターゲットのスコアを取得する

環境内の特定のターゲットのスコアを取得するには、次のようなコマンドを入力します。

curl "https://apigee.googleapis.com/v1/organizations/ORG/securityProfiles/PROFILE_ID/environments/ENV:computeEnvironmentScores" \
       -X POST \
       -d '{"timeRange":
              {
                "startTime": "YYYY-MM-DDT00:00:00Z",
                "endTime": "YYYY-MM-DDT00:00:00Z"
              },
            "filters": [{"scorePath": "/org@ORG/envgroup@ENVGROUP/env@ENV/target@TARGET"}]
           }' \
       -H 'Content-type: application/json' \
       -H "Authorization: Bearer $TOKEN"