UNPKG

cdk-amazon-chime-resources

Version:

![Experimental](https://img.shields.io/badge/experimental-important.svg?style=for-the-badge)

318 lines 43.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.DeleteVoiceConnector = exports.UpdateVoiceConnector = exports.CreateVoiceConnector = void 0; const client_chime_sdk_voice_1 = require("@aws-sdk/client-chime-sdk-voice"); const client_cloudwatch_logs_1 = require("@aws-sdk/client-cloudwatch-logs"); const client_ssm_1 = require("@aws-sdk/client-ssm"); var VoiceConnectorRegion; (function (VoiceConnectorRegion) { VoiceConnectorRegion["US_EAST_1"] = "us-east-1"; VoiceConnectorRegion["US_WEST_2"] = "us-west-2"; VoiceConnectorRegion["CA_CENTRAL_1"] = "ca-central-1"; VoiceConnectorRegion["AP_NORTHEAST_1"] = "ap-northeast-1"; VoiceConnectorRegion["AP_NORTHEAST_2"] = "ap-northeast-2"; VoiceConnectorRegion["AP_SOUTHEAST_1"] = "ap-southeast-1"; VoiceConnectorRegion["AP_SOUTHEAST_2"] = "ap-southeast-2"; VoiceConnectorRegion["EU_WEST_1"] = "eu-west-1"; VoiceConnectorRegion["EU_WEST_2"] = "eu-west-2"; VoiceConnectorRegion["EU_CENTRAL_1"] = "eu-central-1"; })(VoiceConnectorRegion || (VoiceConnectorRegion = {})); const chimeSDKVoiceClient = new client_chime_sdk_voice_1.ChimeSDKVoiceClient({ region: process.env.AWS_REGION, }); const ssmClient = new client_ssm_1.SSMClient({ region: process.env.AWS_REGION }); const logClient = new client_cloudwatch_logs_1.CloudWatchLogsClient({ region: process.env.AWS_REGION }); let createVoiceConnectorResponse; let createVoiceConnectorParams; let updateVoiceConnectorParams; let getParameterCommandOutput; let voiceConnectorId; let phoneNumbersToDisassociate; let routes; let terminationConfiguration; let streamingConfiguration; let loggingConfiguration; let deleteVoiceConnectorResponse; const CreateVoiceConnector = async (uid, props) => { console.log(`Creating Voice Connector: ${uid}`); console.log(`Create Voice Connector Props: ${JSON.stringify(props)}`); createVoiceConnectorParams = { Name: props.name, RequireEncryption: props.encryption, AwsRegion: props.region, }; console.log(`createVoiceConnectorParams: ${JSON.stringify(createVoiceConnectorParams)}`); try { createVoiceConnectorResponse = await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.CreateVoiceConnectorCommand(createVoiceConnectorParams)); console.log(`createVoiceConnectorResponse: ${JSON.stringify(createVoiceConnectorResponse)}`); if (createVoiceConnectorResponse.VoiceConnector && createVoiceConnectorResponse.VoiceConnector.VoiceConnectorId) { voiceConnectorId = createVoiceConnectorResponse.VoiceConnector?.VoiceConnectorId; } else { throw new Error('Voice Connector failed to create'); } } catch (error) { if (error instanceof Error) { console.error(error); throw error; } } console.log(`Voice Connector Created: ${voiceConnectorId}`); if (props.origination) { await putOrigination(voiceConnectorId, props.origination); } if (props.termination) { await putTermination(voiceConnectorId, props.termination); } if (props.streaming) { await putStreaming(voiceConnectorId, props.streaming); } if (props.logging) { await putLogging(voiceConnectorId, props.logging); } try { await ssmClient.send(new client_ssm_1.PutParameterCommand({ Name: '/chime/voiceConnector' + uid, Value: voiceConnectorId, Description: 'Voice Connector ID', Overwrite: true, Type: 'String', })); } catch (error) { if (error instanceof Error) { console.error(error); throw error; } } return { voiceConnectorId: voiceConnectorId, }; }; exports.CreateVoiceConnector = CreateVoiceConnector; const UpdateVoiceConnector = async (uid, props) => { console.log(`Updating Voice Connector: ${uid}`); console.log(`Updating Voice Connector Props: ${JSON.stringify(props)}`); updateVoiceConnectorParams = { Name: props.name, RequireEncryption: props.encryption, AwsRegion: props.region, }; console.log(`updateVoiceConnectorParams: ${JSON.stringify(updateVoiceConnectorParams)}`); try { getParameterCommandOutput = await ssmClient.send(new client_ssm_1.GetParameterCommand({ Name: '/chime/voiceConnector' + uid })); if (getParameterCommandOutput.Parameter && getParameterCommandOutput.Parameter.Value) { voiceConnectorId = getParameterCommandOutput.Parameter.Value; } } catch (error) { if (error instanceof Error) { console.error(error); throw error; } } if (props.origination) { await putOrigination(voiceConnectorId, props.origination); } if (props.termination) { await putTermination(voiceConnectorId, props.termination); } if (props.streaming) { await putStreaming(voiceConnectorId, props.streaming); } if (props.logging) { await putLogging(voiceConnectorId, props.logging); } return { voiceConnectorId: voiceConnectorId, }; }; exports.UpdateVoiceConnector = UpdateVoiceConnector; const DeleteVoiceConnector = async (uid) => { try { getParameterCommandOutput = await ssmClient.send(new client_ssm_1.GetParameterCommand({ Name: '/chime/voiceConnector' + uid })); if (getParameterCommandOutput.Parameter && getParameterCommandOutput.Parameter.Value) { voiceConnectorId = getParameterCommandOutput.Parameter.Value; } } catch (error) { if (error instanceof Error) { console.error(error); throw error; } } console.log(`voiceConnectorId to delete: ${voiceConnectorId}`); try { const phoneNumbersAssociated = await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.ListPhoneNumbersCommand({ FilterName: 'VoiceConnectorId', FilterValue: voiceConnectorId, })); console.log(`phoneNumbers to disassociate: ${JSON.stringify(phoneNumbersAssociated)}`); if (phoneNumbersAssociated.PhoneNumbers && phoneNumbersAssociated.PhoneNumbers.length > 0) { phoneNumbersAssociated.PhoneNumbers.forEach(async (phoneNumber) => { phoneNumbersToDisassociate.push(phoneNumber.PhoneNumberId); }); console.log(`Disassociate Phone Numbers: ${phoneNumbersToDisassociate}`); await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.DisassociatePhoneNumbersFromVoiceConnectorCommand({ VoiceConnectorId: voiceConnectorId, E164PhoneNumbers: phoneNumbersToDisassociate, })); } } catch (error) { if (error instanceof Error) { console.error(error); throw error; } } console.log(`Deleting Voice Connector: ${voiceConnectorId}`); try { deleteVoiceConnectorResponse = await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.DeleteVoiceConnectorCommand({ VoiceConnectorId: voiceConnectorId, })); console.log(`Delete Voice Connector Response: ${deleteVoiceConnectorResponse}`); await ssmClient.send(new client_ssm_1.DeleteParameterCommand({ Name: '/chime/voiceConnector' + uid })); } catch (error) { if (error instanceof Error) { console.error(error); throw error; } } }; exports.DeleteVoiceConnector = DeleteVoiceConnector; const putOrigination = async (originationVoiceConnectorId, originations) => { console.log(`originations: ${JSON.stringify(originations)}`); console.info(`voiceConnectorId: ${originationVoiceConnectorId}`); routes = []; originations.forEach(async (origination) => { routes.push({ Protocol: origination.protocol, Host: origination.host, Port: parseInt(origination.port), Priority: parseInt(origination.priority), Weight: parseInt(origination.weight), }); }); console.log(`routes: ${JSON.stringify(routes)}`); try { await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.PutVoiceConnectorOriginationCommand({ VoiceConnectorId: originationVoiceConnectorId, Origination: { Routes: routes, Disabled: false, }, })); } catch (error) { if (error instanceof Error) { console.error(error); throw error; } } }; const putTermination = async (terminationVoiceConnectorId, termination) => { console.log(`termination: ${JSON.stringify(termination)}`); console.info(`voiceConnectorId: ${terminationVoiceConnectorId}`); terminationConfiguration = { CallingRegions: termination.callingRegions, CidrAllowedList: termination.terminationCidrs, CpsLimit: parseInt(termination.cpsLimit), }; console.log(`terminationConfiguration: ${JSON.stringify(terminationConfiguration)}`); try { await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.PutVoiceConnectorTerminationCommand({ VoiceConnectorId: terminationVoiceConnectorId, Termination: terminationConfiguration, })); } catch (error) { if (error instanceof Error) { console.error(error); throw error; } } }; const putStreaming = async (streamingVoiceConnectorId, streaming) => { console.log(`streaming: ${JSON.stringify(streaming)}`); console.info(`voiceConnectorId: ${streamingVoiceConnectorId}`); streamingConfiguration = { StreamingNotificationTargets: streaming.notificationTarget, Disabled: false, DataRetentionInHours: parseInt(streaming.dataRetention), ...(streaming.mediaInsightsConfiguration && { MediaInsightsConfiguration: { Disabled: streaming.mediaInsightsConfiguration.disabled, ConfigurationArn: streaming.mediaInsightsConfiguration.configurationArn, }, }), }; console.log(`streamingConfiguration: ${JSON.stringify(streamingConfiguration)}`); try { await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.PutVoiceConnectorStreamingConfigurationCommand({ VoiceConnectorId: streamingVoiceConnectorId, StreamingConfiguration: streamingConfiguration, })); } catch (error) { if (error instanceof Error) { console.error(error); throw error; } } }; const putLogging = async (loggingVoiceConnectorId, logging) => { console.log(`logging: ${JSON.stringify(logging)}`); console.info(`voiceConnectorId: ${loggingVoiceConnectorId}`); try { console.log('Updating Resource Policy'); const policyDocument = JSON.stringify({ Version: '2012-10-17', Statement: [ { Sid: 'AWSLogDeliveryWrite', Effect: 'Allow', Principal: { Service: 'delivery.logs.amazonaws.com' }, Action: ['logs:CreateLogStream', 'logs:PutLogEvents'], Resource: ['*'], }, ], }); await logClient.send(new client_cloudwatch_logs_1.PutResourcePolicyCommand({ policyName: 'msk', policyDocument: policyDocument, })); } catch (error) { if (error instanceof Error) { console.error(error); throw error; } } loggingConfiguration = { ...(logging.enableSIPLogs && { EnableSIPLogs: logging.enableSIPLogs }), ...(logging.enableMediaMetricLogs && { EnableMediaMetricLogs: logging.enableMediaMetricLogs, }), }; console.log(`loggingConfiguration: ${JSON.stringify(loggingConfiguration)}`); try { await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.PutVoiceConnectorLoggingConfigurationCommand({ VoiceConnectorId: loggingVoiceConnectorId, LoggingConfiguration: loggingConfiguration, })); } catch (error) { if (error instanceof Error) { console.error(error); throw error; } } }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"voiceConnector.js","sourceRoot":"","sources":["../../../src/resources/pstn/voiceConnector.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChimeSDKVoiceClient,\n  CreateVoiceConnectorCommand,\n  PutVoiceConnectorLoggingConfigurationCommand,\n  PutVoiceConnectorStreamingConfigurationCommand,\n  PutVoiceConnectorTerminationCommand,\n  PutVoiceConnectorOriginationCommand,\n  DeleteVoiceConnectorCommand,\n  DeleteVoiceConnectorCommandOutput,\n  DisassociatePhoneNumbersFromVoiceConnectorCommand,\n  CreateVoiceConnectorCommandInput,\n  CreateVoiceConnectorCommandOutput,\n  Termination,\n  OriginationRoute,\n  StreamingConfiguration,\n  LoggingConfiguration,\n  ListPhoneNumbersCommand,\n  StreamingNotificationTarget,\n} from '@aws-sdk/client-chime-sdk-voice';\nimport {\n  CloudWatchLogsClient,\n  PutResourcePolicyCommand,\n} from '@aws-sdk/client-cloudwatch-logs';\nimport {\n  SSMClient,\n  DeleteParameterCommand,\n  GetParameterCommand,\n  GetParameterCommandOutput,\n  PutParameterCommand,\n} from '@aws-sdk/client-ssm';\nimport {\n  MediaInsightsConfiguration,\n  Protocol,\n} from '../../pstn/voiceConnector';\n\n\nenum VoiceConnectorRegion {\n  US_EAST_1 = 'us-east-1',\n  US_WEST_2 = 'us-west-2',\n  CA_CENTRAL_1 = 'ca-central-1',\n  AP_NORTHEAST_1 = 'ap-northeast-1',\n  AP_NORTHEAST_2 = 'ap-northeast-2',\n  AP_SOUTHEAST_1 = 'ap-southeast-1',\n  AP_SOUTHEAST_2 = 'ap-southeast-2',\n  EU_WEST_1 = 'eu-west-1',\n  EU_WEST_2 = 'eu-west-2',\n  EU_CENTRAL_1 = 'eu-central-1',\n}\nconst chimeSDKVoiceClient = new ChimeSDKVoiceClient({\n  region: process.env.AWS_REGION,\n});\n\nconst ssmClient = new SSMClient({ region: process.env.AWS_REGION });\nconst logClient = new CloudWatchLogsClient({ region: process.env.AWS_REGION });\n\nlet createVoiceConnectorResponse: CreateVoiceConnectorCommandOutput;\nlet createVoiceConnectorParams: CreateVoiceConnectorCommandInput;\nlet updateVoiceConnectorParams: CreateVoiceConnectorCommandInput;\nlet getParameterCommandOutput: GetParameterCommandOutput;\nlet voiceConnectorId: string;\nlet phoneNumbersToDisassociate: string[];\nlet routes: OriginationRoute[];\nlet terminationConfiguration: Termination;\nlet streamingConfiguration: StreamingConfiguration;\nlet loggingConfiguration: LoggingConfiguration;\nlet deleteVoiceConnectorResponse: DeleteVoiceConnectorCommandOutput;\n\ninterface Routes {\n  protocol: Protocol;\n  host: string;\n  port: string;\n  priority: string;\n  weight: string;\n}\n\ninterface TerminationProps {\n  callingRegions: string[];\n  terminationCidrs: string[];\n  cpsLimit: string;\n}\n\ninterface StreamingProps {\n  enabled: boolean;\n  dataRetention: string;\n  notificationTarget: StreamingNotificationTarget[];\n  mediaInsightsConfiguration: MediaInsightsConfiguration;\n}\n\ninterface LoggingProps {\n  enableSIPLogs: boolean;\n  enableMediaMetricLogs: boolean;\n}\n\nexport interface CreateVoiceConnectorProps {\n  name?: string;\n  region?: VoiceConnectorRegion;\n  encryption?: boolean;\n  termination?: TerminationProps;\n  origination?: Routes[];\n  logging?: LoggingProps;\n  streaming?: StreamingProps;\n}\n\nexport const CreateVoiceConnector = async (\n  uid: string,\n  props: CreateVoiceConnectorProps,\n) => {\n  console.log(`Creating Voice Connector: ${uid}`);\n  console.log(`Create Voice Connector Props: ${JSON.stringify(props)}`);\n  createVoiceConnectorParams = {\n    Name: props.name,\n    RequireEncryption: props.encryption,\n    AwsRegion: props.region,\n  };\n  console.log(\n    `createVoiceConnectorParams: ${JSON.stringify(createVoiceConnectorParams)}`,\n  );\n\n  try {\n    createVoiceConnectorResponse = await chimeSDKVoiceClient.send(\n      new CreateVoiceConnectorCommand(createVoiceConnectorParams),\n    );\n    console.log(\n      `createVoiceConnectorResponse: ${JSON.stringify(\n        createVoiceConnectorResponse,\n      )}`,\n    );\n    if (\n      createVoiceConnectorResponse.VoiceConnector &&\n      createVoiceConnectorResponse.VoiceConnector.VoiceConnectorId\n    ) {\n      voiceConnectorId =\n        createVoiceConnectorResponse.VoiceConnector?.VoiceConnectorId;\n    } else {\n      throw new Error('Voice Connector failed to create');\n    }\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n  console.log(`Voice Connector Created: ${voiceConnectorId}`);\n\n  if (props.origination) {\n    await putOrigination(voiceConnectorId, props.origination);\n  }\n\n  if (props.termination) {\n    await putTermination(voiceConnectorId, props.termination);\n  }\n\n  if (props.streaming) {\n    await putStreaming(voiceConnectorId, props.streaming);\n  }\n\n  if (props.logging) {\n    await putLogging(voiceConnectorId, props.logging);\n  }\n\n  try {\n    await ssmClient.send(\n      new PutParameterCommand({\n        Name: '/chime/voiceConnector' + uid,\n        Value: voiceConnectorId,\n        Description: 'Voice Connector ID',\n        Overwrite: true,\n        Type: 'String',\n      }),\n    );\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n\n  return {\n    voiceConnectorId: voiceConnectorId,\n  };\n};\n\nexport interface UpdateVoiceConnectorProps {\n  name?: string;\n  region?: VoiceConnectorRegion;\n  encryption?: boolean;\n  termination?: TerminationProps;\n  origination?: Routes[];\n  logging?: LoggingProps;\n  streaming?: StreamingProps;\n}\n\nexport const UpdateVoiceConnector = async (\n  uid: string,\n  props: UpdateVoiceConnectorProps,\n) => {\n  console.log(`Updating Voice Connector: ${uid}`);\n  console.log(`Updating Voice Connector Props: ${JSON.stringify(props)}`);\n  updateVoiceConnectorParams = {\n    Name: props.name,\n    RequireEncryption: props.encryption,\n    AwsRegion: props.region,\n  };\n  console.log(\n    `updateVoiceConnectorParams: ${JSON.stringify(updateVoiceConnectorParams)}`,\n  );\n\n  try {\n    getParameterCommandOutput = await ssmClient.send(\n      new GetParameterCommand({ Name: '/chime/voiceConnector' + uid }),\n    );\n    if (\n      getParameterCommandOutput.Parameter &&\n      getParameterCommandOutput.Parameter.Value\n    ) {\n      voiceConnectorId = getParameterCommandOutput.Parameter.Value;\n    }\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n\n  if (props.origination) {\n    await putOrigination(voiceConnectorId, props.origination);\n  }\n\n  if (props.termination) {\n    await putTermination(voiceConnectorId, props.termination);\n  }\n\n  if (props.streaming) {\n    await putStreaming(voiceConnectorId, props.streaming);\n  }\n\n  if (props.logging) {\n    await putLogging(voiceConnectorId, props.logging);\n  }\n  return {\n    voiceConnectorId: voiceConnectorId,\n  };\n};\n\nexport const DeleteVoiceConnector = async (uid: string) => {\n  try {\n    getParameterCommandOutput = await ssmClient.send(\n      new GetParameterCommand({ Name: '/chime/voiceConnector' + uid }),\n    );\n    if (\n      getParameterCommandOutput.Parameter &&\n      getParameterCommandOutput.Parameter.Value\n    ) {\n      voiceConnectorId = getParameterCommandOutput.Parameter.Value;\n    }\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n  console.log(`voiceConnectorId to delete: ${voiceConnectorId}`);\n  try {\n    const phoneNumbersAssociated = await chimeSDKVoiceClient.send(\n      new ListPhoneNumbersCommand({\n        FilterName: 'VoiceConnectorId',\n        FilterValue: voiceConnectorId,\n      }),\n    );\n    console.log(\n      `phoneNumbers to disassociate:  ${JSON.stringify(\n        phoneNumbersAssociated,\n      )}`,\n    );\n    if (\n      phoneNumbersAssociated.PhoneNumbers &&\n      phoneNumbersAssociated.PhoneNumbers.length > 0\n    ) {\n      phoneNumbersAssociated.PhoneNumbers.forEach(async (phoneNumber) => {\n        phoneNumbersToDisassociate.push(phoneNumber.PhoneNumberId!);\n      });\n      console.log(`Disassociate Phone Numbers: ${phoneNumbersToDisassociate}`);\n      await chimeSDKVoiceClient.send(\n        new DisassociatePhoneNumbersFromVoiceConnectorCommand({\n          VoiceConnectorId: voiceConnectorId,\n          E164PhoneNumbers: phoneNumbersToDisassociate,\n        }),\n      );\n    }\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n  console.log(`Deleting Voice Connector: ${voiceConnectorId}`);\n  try {\n    deleteVoiceConnectorResponse = await chimeSDKVoiceClient.send(\n      new DeleteVoiceConnectorCommand({\n        VoiceConnectorId: voiceConnectorId,\n      }),\n    );\n    console.log(\n      `Delete Voice Connector Response: ${deleteVoiceConnectorResponse}`,\n    );\n    await ssmClient.send(\n      new DeleteParameterCommand({ Name: '/chime/voiceConnector' + uid }),\n    );\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n};\n\nconst putOrigination = async (\n  originationVoiceConnectorId: string,\n  originations: {\n    protocol: Protocol;\n    host: string;\n    port: string;\n    priority: string;\n    weight: string;\n  }[],\n) => {\n  console.log(`originations:  ${JSON.stringify(originations)}`);\n  console.info(`voiceConnectorId: ${originationVoiceConnectorId}`);\n  routes = [];\n  originations.forEach(async (origination) => {\n    routes.push({\n      Protocol: origination.protocol,\n      Host: origination.host,\n      Port: parseInt(origination.port),\n      Priority: parseInt(origination.priority),\n      Weight: parseInt(origination.weight),\n    });\n  });\n  console.log(`routes:  ${JSON.stringify(routes)}`);\n  try {\n    await chimeSDKVoiceClient.send(\n      new PutVoiceConnectorOriginationCommand({\n        VoiceConnectorId: originationVoiceConnectorId,\n        Origination: {\n          Routes: routes,\n          Disabled: false,\n        },\n      }),\n    );\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n};\n\nconst putTermination = async (\n  terminationVoiceConnectorId: string,\n  termination: {\n    callingRegions: string[];\n    terminationCidrs: string[];\n    cpsLimit: string;\n  },\n) => {\n  console.log(`termination:  ${JSON.stringify(termination)}`);\n  console.info(`voiceConnectorId: ${terminationVoiceConnectorId}`);\n  terminationConfiguration = {\n    CallingRegions: termination.callingRegions,\n    CidrAllowedList: termination.terminationCidrs,\n    CpsLimit: parseInt(termination.cpsLimit),\n  };\n  console.log(\n    `terminationConfiguration:  ${JSON.stringify(terminationConfiguration)}`,\n  );\n  try {\n    await chimeSDKVoiceClient.send(\n      new PutVoiceConnectorTerminationCommand({\n        VoiceConnectorId: terminationVoiceConnectorId,\n        Termination: terminationConfiguration,\n      }),\n    );\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n};\n\nconst putStreaming = async (\n  streamingVoiceConnectorId: string,\n  streaming: StreamingProps,\n) => {\n  console.log(`streaming:  ${JSON.stringify(streaming)}`);\n  console.info(`voiceConnectorId: ${streamingVoiceConnectorId}`);\n\n  streamingConfiguration = {\n    StreamingNotificationTargets: streaming.notificationTarget,\n    Disabled: false,\n    DataRetentionInHours: parseInt(streaming.dataRetention),\n    ...(streaming.mediaInsightsConfiguration && {\n      MediaInsightsConfiguration: {\n        Disabled: streaming.mediaInsightsConfiguration.disabled,\n        ConfigurationArn: streaming.mediaInsightsConfiguration.configurationArn,\n      },\n    }),\n  };\n  console.log(\n    `streamingConfiguration:  ${JSON.stringify(streamingConfiguration)}`,\n  );\n\n  try {\n    await chimeSDKVoiceClient.send(\n      new PutVoiceConnectorStreamingConfigurationCommand({\n        VoiceConnectorId: streamingVoiceConnectorId,\n        StreamingConfiguration: streamingConfiguration,\n      }),\n    );\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n};\n\nconst putLogging = async (\n  loggingVoiceConnectorId: string,\n  logging: LoggingProps,\n) => {\n  console.log(`logging:  ${JSON.stringify(logging)}`);\n  console.info(`voiceConnectorId: ${loggingVoiceConnectorId}`);\n\n  try {\n    console.log('Updating Resource Policy');\n    const policyDocument = JSON.stringify({\n      Version: '2012-10-17',\n      Statement: [\n        {\n          Sid: 'AWSLogDeliveryWrite',\n          Effect: 'Allow',\n          Principal: { Service: 'delivery.logs.amazonaws.com' },\n          Action: ['logs:CreateLogStream', 'logs:PutLogEvents'],\n          Resource: ['*'],\n        },\n      ],\n    });\n    await logClient.send(\n      new PutResourcePolicyCommand({\n        policyName: 'msk',\n        policyDocument: policyDocument,\n      }),\n    );\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n\n  loggingConfiguration = {\n    ...(logging.enableSIPLogs && { EnableSIPLogs: logging.enableSIPLogs }),\n    ...(logging.enableMediaMetricLogs && {\n      EnableMediaMetricLogs: logging.enableMediaMetricLogs,\n    }),\n  };\n  console.log(`loggingConfiguration:  ${JSON.stringify(loggingConfiguration)}`);\n  try {\n    await chimeSDKVoiceClient.send(\n      new PutVoiceConnectorLoggingConfigurationCommand({\n        VoiceConnectorId: loggingVoiceConnectorId,\n        LoggingConfiguration: loggingConfiguration,\n      }),\n    );\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n};\n"]}