UNPKG

@aws-cdk/aws-bedrock-agentcore-alpha

Version:

The CDK Construct Library for Amazon Bedrock

141 lines 16.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.ApiKeyCredentialProviderConfiguration = exports.ApiKeyCredentialLocation = exports.ApiKeyCredentialLocationType = void 0; const jsiiDeprecationWarnings = require("../../../.warnings.jsii.js"); const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti"); const aws_iam_1 = require("aws-cdk-lib/aws-iam"); const credential_provider_1 = require("./credential-provider"); const perms_1 = require("../perms"); /** * API Key credential location type * @internal */ var ApiKeyCredentialLocationType; (function (ApiKeyCredentialLocationType) { ApiKeyCredentialLocationType["HEADER"] = "HEADER"; ApiKeyCredentialLocationType["QUERY_PARAMETER"] = "QUERY_PARAMETER"; })(ApiKeyCredentialLocationType || (exports.ApiKeyCredentialLocationType = ApiKeyCredentialLocationType = {})); /** * API Key location within the request */ class ApiKeyCredentialLocation { static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-bedrock-agentcore-alpha.ApiKeyCredentialLocation", version: "2.227.0-alpha.0" }; /** * Create a header-based API key credential location * @param config - Optional configuration for the credential location * @returns ApiKeyCredentialLocation configured for header placement */ static header(config) { try { jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_ApiKeyAdditionalConfiguration(config); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.header); } throw error; } return new ApiKeyCredentialLocation(ApiKeyCredentialLocationType.HEADER, config?.credentialParameterName ?? 'Authorization', config?.credentialPrefix ?? 'Bearer '); } /** * Create a query parameter-based API key credential location * @param config - Optional configuration for the credential location * @returns ApiKeyCredentialLocation configured for query parameter placement */ static queryParameter(config) { try { jsiiDeprecationWarnings._aws_cdk_aws_bedrock_agentcore_alpha_ApiKeyAdditionalConfiguration(config); } catch (error) { if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") { Error.captureStackTrace(error, this.queryParameter); } throw error; } return new ApiKeyCredentialLocation(ApiKeyCredentialLocationType.QUERY_PARAMETER, config?.credentialParameterName ?? 'api_key', config?.credentialPrefix); } /** * The name of the credential parameter */ credentialParameterName; /** * The prefix for the credential value */ credentialPrefix; /** * The type of credential location (HEADER or QUERY_PARAMETER) */ credentialLocationType; constructor(credentialLocationType, credentialParameterName, credentialPrefix) { this.credentialLocationType = credentialLocationType; this.credentialParameterName = credentialParameterName; this.credentialPrefix = credentialPrefix; } } exports.ApiKeyCredentialLocation = ApiKeyCredentialLocation; /** * API Key credential provider configuration implementation * Can be used with OpenAPI targets * @internal */ class ApiKeyCredentialProviderConfiguration { credentialProviderType = credential_provider_1.CredentialProviderType.API_KEY; /** * The ARN of the API key provider */ providerArn; /** * The ARN of the Secrets Manager secret */ secretArn; /** * The location configuration for the API key credential */ credentialLocation; constructor(configuration) { this.providerArn = configuration.providerArn; this.secretArn = configuration.secretArn; this.credentialLocation = configuration.credentialLocation ?? ApiKeyCredentialLocation.header(); } /** * Grant the needed permissions to the role for API key authentication */ grantNeededPermissionsToRole(role) { const statements = [ new aws_iam_1.PolicyStatement({ actions: [ ...perms_1.GatewayPerms.GATEWAY_API_KEY_PERMS, ...perms_1.GatewayPerms.GATEWAY_WORKLOAD_IDENTITY_PERMS, ], resources: [this.providerArn], }), new aws_iam_1.PolicyStatement({ actions: perms_1.GatewayPerms.SECRETS_PERMS, resources: [this.secretArn], }), ]; return aws_iam_1.Grant.addToPrincipal({ grantee: role, actions: statements.flatMap(s => s.actions), resourceArns: statements.flatMap(s => s.resources), }); } /** * @internal */ _render() { return { credentialProviderType: this.credentialProviderType, credentialProvider: { apiKeyCredentialProvider: { providerArn: this.providerArn, credentialLocation: this.credentialLocation.credentialLocationType, credentialParameterName: this.credentialLocation.credentialParameterName, credentialPrefix: this.credentialLocation.credentialPrefix, }, }, }; } } exports.ApiKeyCredentialProviderConfiguration = ApiKeyCredentialProviderConfiguration; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-key.js","sourceRoot":"","sources":["api-key.ts"],"names":[],"mappings":"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","sourcesContent":["import { Grant, IRole, PolicyStatement } from 'aws-cdk-lib/aws-iam';\nimport { CredentialProviderType, ICredentialProviderConfig } from './credential-provider';\nimport { GatewayPerms } from '../perms';\n\n/******************************************************************************\n *                                 API KEY\n *****************************************************************************/\n/**\n * API Key additional configuration\n */\nexport interface ApiKeyAdditionalConfiguration {\n\n  /**\n   * The name of the credential parameter for the API key.\n   * This parameter name is used when sending the API key to the target endpoint.\n   *\n   * Length Constraints: Minimum length of 1. Maximum length of 64.\n   * @default - 'Authorization' for HEADER, 'api_key' for QUERY_PARAMETER\n   */\n  readonly credentialParameterName?: string;\n\n  /**\n   * The prefix for the API key credential.\n   * This prefix is added to the API key when sending it to the target endpoint.\n   *\n   * Length Constraints: Minimum length of 1. Maximum length of 64.\n   * @default - 'Bearer ' for HEADER, no prefix for QUERY_PARAMETER\n   */\n  readonly credentialPrefix?: string;\n}\n\n/**\n * API Key credential location type\n * @internal\n */\nexport enum ApiKeyCredentialLocationType {\n  HEADER = 'HEADER',\n  QUERY_PARAMETER = 'QUERY_PARAMETER',\n}\n\n/**\n * API Key location within the request\n */\nexport class ApiKeyCredentialLocation {\n  /**\n   * Create a header-based API key credential location\n   * @param config - Optional configuration for the credential location\n   * @returns ApiKeyCredentialLocation configured for header placement\n   */\n  public static header(config?: ApiKeyAdditionalConfiguration) {\n    return new ApiKeyCredentialLocation(\n      ApiKeyCredentialLocationType.HEADER,\n      config?.credentialParameterName ?? 'Authorization',\n      config?.credentialPrefix ?? 'Bearer ',\n    );\n  }\n\n  /**\n   * Create a query parameter-based API key credential location\n   * @param config - Optional configuration for the credential location\n   * @returns ApiKeyCredentialLocation configured for query parameter placement\n   */\n  public static queryParameter(config?: ApiKeyAdditionalConfiguration) {\n    return new ApiKeyCredentialLocation(\n      ApiKeyCredentialLocationType.QUERY_PARAMETER,\n      config?.credentialParameterName ?? 'api_key',\n      config?.credentialPrefix,\n    );\n  }\n\n  /**\n   * The name of the credential parameter\n   */\n  public readonly credentialParameterName: string;\n  /**\n   * The prefix for the credential value\n   */\n  public readonly credentialPrefix?: string;\n  /**\n   * The type of credential location (HEADER or QUERY_PARAMETER)\n   */\n  public readonly credentialLocationType: string;\n\n  private constructor(\n    credentialLocationType: string,\n    credentialParameterName: string,\n    credentialPrefix?: string,\n  ) {\n    this.credentialLocationType = credentialLocationType;\n    this.credentialParameterName = credentialParameterName;\n    this.credentialPrefix = credentialPrefix;\n  }\n}\n\n/**\n * API Key configuration\n */\nexport interface ApiKeyCredentialProviderProps {\n  /**\n   * The API key credential provider ARN.\n   * This is returned when creating the API key credential provider via Console or API.\n   * Format: arn:aws:bedrock-agentcore:region:account:token-vault/id/apikeycredentialprovider/name\n   */\n  readonly providerArn: string;\n\n  /**\n   * The ARN of the Secrets Manager secret containing the API key.\n   * This is returned when creating the API key credential provider via Console or API.\n   * Format: arn:aws:secretsmanager:region:account:secret:name\n   */\n  readonly secretArn: string;\n\n  /**\n   * The location of the API key credential.\n   * This field specifies where in the request the API key should be placed.\n   *\n   * @default - HEADER\n   */\n  readonly credentialLocation?: ApiKeyCredentialLocation;\n}\n\n/**\n * API Key credential provider configuration implementation\n * Can be used with OpenAPI targets\n * @internal\n */\nexport class ApiKeyCredentialProviderConfiguration implements ICredentialProviderConfig {\n  public readonly credentialProviderType = CredentialProviderType.API_KEY;\n  /**\n   * The ARN of the API key provider\n   */\n  public readonly providerArn: string;\n  /**\n   * The ARN of the Secrets Manager secret\n   */\n  public readonly secretArn: string;\n  /**\n   * The location configuration for the API key credential\n   */\n  public readonly credentialLocation: ApiKeyCredentialLocation;\n\n  constructor(configuration: ApiKeyCredentialProviderProps) {\n    this.providerArn = configuration.providerArn;\n    this.secretArn = configuration.secretArn;\n    this.credentialLocation = configuration.credentialLocation ?? ApiKeyCredentialLocation.header();\n  }\n\n  /**\n   * Grant the needed permissions to the role for API key authentication\n   */\n  grantNeededPermissionsToRole(role: IRole): Grant | undefined {\n    const statements = [\n      new PolicyStatement({\n        actions: [\n          ...GatewayPerms.GATEWAY_API_KEY_PERMS,\n          ...GatewayPerms.GATEWAY_WORKLOAD_IDENTITY_PERMS,\n        ],\n        resources: [this.providerArn],\n      }),\n      new PolicyStatement({\n        actions: GatewayPerms.SECRETS_PERMS,\n        resources: [this.secretArn],\n      }),\n    ];\n\n    return Grant.addToPrincipal({\n      grantee: role,\n      actions: statements.flatMap(s => s.actions),\n      resourceArns: statements.flatMap(s => s.resources),\n    });\n  }\n\n  /**\n   * @internal\n   */\n  _render(): any {\n    return {\n      credentialProviderType: this.credentialProviderType,\n      credentialProvider: {\n        apiKeyCredentialProvider: {\n          providerArn: this.providerArn,\n          credentialLocation: this.credentialLocation.credentialLocationType,\n          credentialParameterName: this.credentialLocation.credentialParameterName,\n          credentialPrefix: this.credentialLocation.credentialPrefix,\n        },\n      },\n    };\n  }\n}\n"]}