cdk-amazon-chime-resources
Version:

197 lines • 27.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.DeletePhoneNumber = exports.CreatePhoneNumber = void 0;
const client_chime_sdk_voice_1 = require("@aws-sdk/client-chime-sdk-voice");
const client_ssm_1 = require("@aws-sdk/client-ssm");
const chimeSDKVoiceClient = new client_chime_sdk_voice_1.ChimeSDKVoiceClient({
region: 'us-east-1',
});
const ssmClient = new client_ssm_1.SSMClient({ region: process.env.AWS_REGION });
let searchAvailableNumbersParam;
let searchAvailablePhoneNumberResponse;
let createPhoneNumberOrderResponse;
let getParameterCommandOutput;
let getPhoneNumberResponse;
const sleep = (ms) => new Promise((r) => setTimeout(r, ms));
const CreatePhoneNumber = async (uid, props) => {
searchAvailableNumbersParam = {
...(props.phoneAreaCode && { AreaCode: props.phoneAreaCode }),
...(props.phoneNumberType && { PhoneNumberType: props.phoneNumberType }),
...(props.phoneState && { State: props.phoneState }),
...(props.phoneCity && { City: props.phoneCity }),
...(props.phoneCountry && { Country: props.phoneCountry }),
...(props.phoneNumberTollFreePrefix && {
TollFreePrefix: props.phoneNumberTollFreePrefix,
}),
};
console.info(`Search Available Numbers: ${JSON.stringify(searchAvailableNumbersParam)}`);
let orderSuccessful = false;
let searchAttempts = 1;
while (searchAttempts < 16) {
try {
console.log(`Searching for available numbers. Search # ${searchAttempts}`);
searchAvailablePhoneNumberResponse = await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.SearchAvailablePhoneNumbersCommand(searchAvailableNumbersParam));
console.log(`Search Available Numbers Response: ${JSON.stringify(searchAvailablePhoneNumberResponse)}`);
}
catch (error) {
if (error instanceof Error) {
console.error(error);
throw error;
}
}
if (searchAvailablePhoneNumberResponse &&
searchAvailablePhoneNumberResponse.E164PhoneNumbers &&
searchAvailablePhoneNumberResponse.E164PhoneNumbers.length === 0) {
throw new Error('No numbers were found with this search parameters. Please try a different search.');
}
try {
console.log('Creating New Phone Number Order');
createPhoneNumberOrderResponse = await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.CreatePhoneNumberOrderCommand({
ProductType: props.phoneProductType,
E164PhoneNumbers: [
searchAvailablePhoneNumberResponse.E164PhoneNumbers[0],
],
}));
console.log(`CreatePhoneNumberOrder Response: ${JSON.stringify(createPhoneNumberOrderResponse)}`);
}
catch (error) {
if (error instanceof client_chime_sdk_voice_1.ChimeSDKVoiceServiceException) {
if (error.name === 'BadRequestException') {
console.log('Bad Request Exception. Retrying');
console.error(error);
searchAttempts++;
await sleep(10000);
continue;
}
else {
console.error(error);
throw error;
}
}
}
let orderAttempts = 0;
let orderResults = '';
while (orderAttempts < 20) {
orderResults = await checkPhoneNumber(createPhoneNumberOrderResponse.PhoneNumberOrder.PhoneNumberOrderId);
if (orderResults === 'Processing') {
orderAttempts++;
await sleep(10000);
console.log('Still processing phone number order. Looping');
continue;
}
else if (orderResults === 'Failed') {
console.log('Phone number order failed');
break;
}
else if (orderResults === 'Successful') {
orderSuccessful = true;
console.log('Phone number order successful');
break;
}
else {
console.log('Unknown phone number order status');
break;
}
}
if (orderSuccessful) {
break;
}
}
if (!orderSuccessful) {
throw new Error('The phone number order failed to process. Please try again.');
}
try {
await ssmClient.send(new client_ssm_1.PutParameterCommand({
Name: '/chime/phoneNumber' + uid,
Value: searchAvailablePhoneNumberResponse.E164PhoneNumbers[0],
Description: 'Phone Number',
Overwrite: true,
Type: 'String',
}));
}
catch (error) {
if (error instanceof Error) {
console.error(error);
throw error;
}
}
return {
phoneNumber: searchAvailablePhoneNumberResponse.E164PhoneNumbers[0],
};
};
exports.CreatePhoneNumber = CreatePhoneNumber;
const DeletePhoneNumber = async (uid) => {
try {
getParameterCommandOutput = await ssmClient.send(new client_ssm_1.GetParameterCommand({ Name: '/chime/phoneNumber' + uid }));
}
catch (error) {
if (error instanceof Error) {
console.error(error);
throw error;
}
}
try {
getPhoneNumberResponse = await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.GetPhoneNumberCommand({
PhoneNumberId: getParameterCommandOutput.Parameter.Value,
}));
}
catch (error) {
if (error instanceof Error) {
console.error(error);
throw error;
}
}
try {
if (getPhoneNumberResponse.PhoneNumber.Status === 'Assigned') {
if (getPhoneNumberResponse.PhoneNumber.ProductType === 'VoiceConnector') {
await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.DisassociatePhoneNumbersFromVoiceConnectorCommand({
E164PhoneNumbers: [
getPhoneNumberResponse.PhoneNumber.E164PhoneNumber,
],
VoiceConnectorId: getPhoneNumberResponse.PhoneNumber.Associations[0].Value,
}));
}
else if (getPhoneNumberResponse.PhoneNumber.ProductType ===
'SipMediaApplicationDialIn') {
await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.UpdateSipRuleCommand({
Name: getPhoneNumberResponse.PhoneNumber.E164PhoneNumber,
SipRuleId: getPhoneNumberResponse.PhoneNumber.Associations[0].Value,
Disabled: true,
}));
}
else {
throw new Error('Could not disassociate number');
}
}
}
catch (error) {
if (error instanceof Error) {
console.error(error);
throw error;
}
}
await sleep(10000);
try {
await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.DeletePhoneNumberCommand({
PhoneNumberId: getParameterCommandOutput.Parameter.Value,
}));
await ssmClient.send(new client_ssm_1.DeleteParameterCommand({ Name: '/chime/phoneNumber' + uid }));
}
catch (error) { }
};
exports.DeletePhoneNumber = DeletePhoneNumber;
async function checkPhoneNumber(phoneOrderId) {
try {
const getPhoneNumberOrderResponse = await chimeSDKVoiceClient.send(new client_chime_sdk_voice_1.GetPhoneNumberOrderCommand({ PhoneNumberOrderId: phoneOrderId }));
console.info(`Get Phone Number Order: ${JSON.stringify(getPhoneNumberOrderResponse)}`);
return getPhoneNumberOrderResponse.PhoneNumberOrder?.Status;
}
catch (error) {
if (error instanceof Error) {
console.error(error);
throw error;
}
return;
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"phoneNumber.js","sourceRoot":"","sources":["../../../src/resources/pstn/phoneNumber.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport {\n  ChimeSDKVoiceClient,\n  CreatePhoneNumberOrderCommand,\n  CreatePhoneNumberOrderCommandOutput,\n  DeletePhoneNumberCommand,\n  DisassociatePhoneNumbersFromVoiceConnectorCommand,\n  GetPhoneNumberCommand,\n  GetPhoneNumberCommandOutput,\n  GetPhoneNumberOrderCommand,\n  SearchAvailablePhoneNumbersCommand,\n  SearchAvailablePhoneNumbersCommandInput,\n  SearchAvailablePhoneNumbersCommandOutput,\n  UpdateSipRuleCommand,\n  ChimeSDKVoiceServiceException,\n} from '@aws-sdk/client-chime-sdk-voice';\n\nimport {\n  SSMClient,\n  DeleteParameterCommand,\n  GetParameterCommand,\n  GetParameterCommandOutput,\n  PutParameterCommand,\n} from '@aws-sdk/client-ssm';\nimport { PhoneNumberType, PhoneProductType } from '../../pstn/phoneNumber';\n\nconst chimeSDKVoiceClient = new ChimeSDKVoiceClient({\n  region: 'us-east-1',\n});\n\nconst ssmClient = new SSMClient({ region: process.env.AWS_REGION });\n\nlet searchAvailableNumbersParam: SearchAvailablePhoneNumbersCommandInput;\nlet searchAvailablePhoneNumberResponse: SearchAvailablePhoneNumbersCommandOutput;\nlet createPhoneNumberOrderResponse: CreatePhoneNumberOrderCommandOutput;\nlet getParameterCommandOutput: GetParameterCommandOutput;\nlet getPhoneNumberResponse: GetPhoneNumberCommandOutput;\n\nconst sleep = (ms: number) => new Promise((r) => setTimeout(r, ms));\n\nexport interface CreatePhoneNumberProps {\n  phoneState?: string;\n  phoneAreaCode?: string;\n  phoneCity?: string;\n  phoneCountry?: string;\n  phoneNumberTollFreePrefix?: string;\n  phoneProductType?: PhoneProductType;\n  phoneNumberType?: PhoneNumberType;\n}\n\nexport const CreatePhoneNumber = async (\n  uid: string,\n  props: CreatePhoneNumberProps,\n) => {\n  searchAvailableNumbersParam = {\n    ...(props.phoneAreaCode && { AreaCode: props.phoneAreaCode }),\n    ...(props.phoneNumberType && { PhoneNumberType: props.phoneNumberType }),\n    ...(props.phoneState && { State: props.phoneState }),\n    ...(props.phoneCity && { City: props.phoneCity }),\n    ...(props.phoneCountry && { Country: props.phoneCountry }),\n    ...(props.phoneNumberTollFreePrefix && {\n      TollFreePrefix: props.phoneNumberTollFreePrefix,\n    }),\n  };\n  console.info(\n    `Search Available Numbers: ${JSON.stringify(searchAvailableNumbersParam)}`,\n  );\n\n  let orderSuccessful: boolean = false;\n  let searchAttempts = 1;\n\n  while (searchAttempts < 16) {\n    try {\n      console.log(\n        `Searching for available numbers.  Search # ${searchAttempts}`,\n      );\n      searchAvailablePhoneNumberResponse = await chimeSDKVoiceClient.send(\n        new SearchAvailablePhoneNumbersCommand(searchAvailableNumbersParam),\n      );\n      console.log(\n        `Search Available Numbers Response: ${JSON.stringify(\n          searchAvailablePhoneNumberResponse,\n        )}`,\n      );\n    } catch (error) {\n      if (error instanceof Error) {\n        console.error(error);\n        throw error;\n      }\n    }\n\n    if (\n      searchAvailablePhoneNumberResponse &&\n      searchAvailablePhoneNumberResponse.E164PhoneNumbers &&\n      searchAvailablePhoneNumberResponse.E164PhoneNumbers.length === 0\n    ) {\n      throw new Error(\n        'No numbers were found with this search parameters.  Please try a different search.',\n      );\n    }\n    try {\n      console.log('Creating New Phone Number Order');\n      createPhoneNumberOrderResponse = await chimeSDKVoiceClient.send(\n        new CreatePhoneNumberOrderCommand({\n          ProductType: props.phoneProductType,\n          E164PhoneNumbers: [\n            searchAvailablePhoneNumberResponse.E164PhoneNumbers![0],\n          ],\n        }),\n      );\n      console.log(\n        `CreatePhoneNumberOrder Response: ${JSON.stringify(\n          createPhoneNumberOrderResponse,\n        )}`,\n      );\n    } catch (error) {\n      if (error instanceof ChimeSDKVoiceServiceException) {\n        if (error.name === 'BadRequestException') {\n          console.log('Bad Request Exception.  Retrying');\n          console.error(error);\n          searchAttempts++;\n          await sleep(10000);\n          continue;\n        } else {\n          console.error(error);\n          throw error;\n        }\n      }\n    }\n    let orderAttempts = 0;\n    let orderResults: string | undefined = '';\n    while (orderAttempts < 20) {\n      orderResults = await checkPhoneNumber(\n        createPhoneNumberOrderResponse.PhoneNumberOrder!.PhoneNumberOrderId!,\n      );\n\n      if (orderResults === 'Processing') {\n        orderAttempts++;\n        await sleep(10000);\n        console.log('Still processing phone number order.  Looping');\n        continue;\n      } else if (orderResults === 'Failed') {\n        console.log('Phone number order failed');\n        break;\n      } else if (orderResults === 'Successful') {\n        orderSuccessful = true;\n        console.log('Phone number order successful');\n        break;\n      } else {\n        console.log('Unknown phone number order status');\n        break;\n      }\n    }\n    if (orderSuccessful) {\n      break;\n    }\n  }\n\n  if (!orderSuccessful) {\n    throw new Error(\n      'The phone number order failed to process.  Please try again.',\n    );\n  }\n\n  try {\n    await ssmClient.send(\n      new PutParameterCommand({\n        Name: '/chime/phoneNumber' + uid,\n        Value: searchAvailablePhoneNumberResponse.E164PhoneNumbers![0],\n        Description: 'Phone Number',\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    phoneNumber: searchAvailablePhoneNumberResponse.E164PhoneNumbers![0],\n  };\n};\n\nexport const DeletePhoneNumber = async (uid: string) => {\n  try {\n    getParameterCommandOutput = await ssmClient.send(\n      new GetParameterCommand({ Name: '/chime/phoneNumber' + uid }),\n    );\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n\n  try {\n    getPhoneNumberResponse = await chimeSDKVoiceClient.send(\n      new GetPhoneNumberCommand({\n        PhoneNumberId: getParameterCommandOutput.Parameter!.Value,\n      }),\n    );\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n\n  try {\n    if (getPhoneNumberResponse.PhoneNumber!.Status === 'Assigned') {\n      if (\n        getPhoneNumberResponse.PhoneNumber!.ProductType! === 'VoiceConnector'\n      ) {\n        await chimeSDKVoiceClient.send(\n          new DisassociatePhoneNumbersFromVoiceConnectorCommand({\n            E164PhoneNumbers: [\n              getPhoneNumberResponse.PhoneNumber!.E164PhoneNumber!,\n            ],\n            VoiceConnectorId:\n              getPhoneNumberResponse.PhoneNumber!.Associations![0].Value!,\n          }),\n        );\n      } else if (\n        getPhoneNumberResponse.PhoneNumber!.ProductType! ===\n        'SipMediaApplicationDialIn'\n      ) {\n        await chimeSDKVoiceClient.send(\n          new UpdateSipRuleCommand({\n            Name: getPhoneNumberResponse.PhoneNumber!.E164PhoneNumber!,\n            SipRuleId:\n              getPhoneNumberResponse.PhoneNumber!.Associations![0].Value!,\n            Disabled: true,\n          }),\n        );\n      } else {\n        throw new Error('Could not disassociate number');\n      }\n    }\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n  }\n  await sleep(10000);\n\n  try {\n    await chimeSDKVoiceClient.send(\n      new DeletePhoneNumberCommand({\n        PhoneNumberId: getParameterCommandOutput.Parameter!.Value,\n      }),\n    );\n    await ssmClient.send(\n      new DeleteParameterCommand({ Name: '/chime/phoneNumber' + uid }),\n    );\n  } catch (error) {}\n};\n\nasync function checkPhoneNumber(phoneOrderId: string) {\n  try {\n    const getPhoneNumberOrderResponse = await chimeSDKVoiceClient.send(\n      new GetPhoneNumberOrderCommand({ PhoneNumberOrderId: phoneOrderId }),\n    );\n    console.info(\n      `Get Phone Number Order: ${JSON.stringify(getPhoneNumberOrderResponse)}`,\n    );\n    return getPhoneNumberOrderResponse.PhoneNumberOrder?.Status;\n  } catch (error) {\n    if (error instanceof Error) {\n      console.error(error);\n      throw error;\n    }\n    return;\n  }\n}\n"]}