AWS Contact Center
Request service using Amazon Connect and AWS IoT
Introduction
Smartphones have become the standard method of communication for consumers, with an estimated 6.8 billion users worldwide in 2023. The World Health Organization reported an estimated 1.3 billion people living with a disability. A portion of this population may not be able to use smartphones easily in their daily lives. This results in the need for businesses to ensure digital accessibility for customers with disabilities.
The use of Amazon Connect with an accessible, connected AWS IoT Button can help businesses achieve digital accessibility. Based on the user’s clicking pattern, their request will be routed to the right place. For example, one click sends a text to a family member. Two clicks create a task for a pharmacy to refill a medication. A long press calls a pharmacist for medication questions.
This blog post shows how to integrate Amazon Connect with AWS IoT Core using AWS Lambda to route user requests to contact center agents or individual phone numbers based on user’s click patterns.
Solution overview

Following steps explain how the preceding solution works:
- User clicks the AWS IoT Button.
- AWS IoT button forwards the click events to the AWS IoT Core service.
- AWS IoT Core rules invoke a Lambda and pass the click events to the Lambda.
- Lambda queries Amazon DynamoDB using the AWS IoT button serial number as partition key for the following attributes: user’s phone number, family member phone number, text message to be sent to family member, pharmacy phone number, and the message to be displayed in the task.
- Lambda processes the events: 
         - One Click – Lambda invokes Amazon Pinpoint to send a text message to a family member’s mobile phone.
- Two Clicks – Lambda calls the Amazon Connect StartTaskContact API to invoke an Amazon Connect flow. The flow initiates an Amazon Connect Task for a pharmacy technician to process a prescription.
- Long Press – Lambda calls the Amazon Connect StartOutboundVoiceContact API to call the user’s phone and runs an Amazon Connect Flow to connect the user with a pharmacist.
 
Prerequisites
Select an AWS Region that supports all the required services in this post. We have validated this solution in AWS us-east-1. Refer to AWS Regional Services for more details on AWS Services availability per AWS Region.
Here are the prerequisites for this solution:
- An AWS Account with access to: 
         - An existing Amazon Connect instance with a Claimed phone number and a configured agent linked to the Basic routing profile. Basic routing profile must have Voice and Task Channels enabled.
- AWS IoT Core to handle click events from an AWS IoT button.
- Create AWS Lambda functions.
- Create an Amazon DynamoDB.
- Configure an Amazon Pinpoint SMS channel for sending text messages.
- AWS Identity and Access Management (IAM) to create roles.
- Amazon CloudWatch to create log groups and to troubleshoot.
- AWS CloudFormation to deploy the Lambda, DynamoDB, and required IAM roles and policies.
 
Walkthrough
In the Amazon Connect console, you will create an inbound flow to route tasks and calls to agents based on the Channel value, either VOICE or TASK. In the Amazon Pinpoint console, you will register a toll-free number and set up an SMS channel. You will also use CloudFormation to build and deploy AWS resources such as Lambda, Amazon DynamoDB, and required IAM roles and policies. Finally, in the AWS IoT Core console, you will configure rules to call your Lambda endpoint. You will use the AWS IoT Core MQTT test client to test your solution.
Deployment steps
The following instructions assume a working knowledge of Amazon Connect, AWS IoT Core, Amazon Pinpoint, AWS CloudFormation, and Amazon DynamoDB. Refer to the following links for more details on these topics:
- Amazon Connect Administration Guide
- AWS IoT Core Developer Guide
- Amazon Pinpoint documentation
- AWS CloudFormation User Guide
- Amazon DynamoDB Developer Guide
Import the Amazon Connect flow into your Amazon Connect instance and attach it to your claimed number:
- Download the Medication Refill And Question flow by selecting this link.
- Sign into your Amazon Connect instance.
- Navigate to the Routing tab.
- Select Contact flows.
- Choose Create contact flow.
- Select the dropdown menu (arrow) next to Save and select Import flow (beta).
- Choose Select and choose the file Medication Refill And Question downloaded from step 1.
- Choose Save.
- Choose Publish.
- Attach the claimed phone number to the Medication Refill And Question flow.
Make note of the Medication Refill And Question flow ID and BasicQueue ID to be used in later steps:
- In the flow designer for Medication Refill And Question flow, expand Show additional flow information.
- Under the Amazon Resource Name (ARN) section, copy everything after contact-flow/ to a text editor. 
- Navigate to the Routing tab.
- Select Queues.
- Choose BasicQueue and expand the Show additional queue information.
- Under the ARN section, copy everything after queue/ to a text editor. 
Configure Amazon Pinpoint for text messaging:
- Request a toll-free number.
- Register your toll-free number. It can take up to 15 days for registration to be processed.
- Set up the SMS channel. For the purpose of this blog, you can select Promotional for the Default message type and keep all other preselected entries as default.
- Select Save Changes.
- Note down the Project ID of the Amazon Pinpoint project to use in the next step. 
Deploy the AWS resources, Lambda, DynamoDB, and IAM roles:
- Launch this CloudFormation.
- Provide a descriptive Stack name.
- Enter the following parameters. 
- Choose Next.
- Keep all default entries for the stack and select Next to move through each screen.
- Accept the notice regarding new IAM resources being created and AWS CloudFormation requiring capability CAPABILITY_AUTO_EXPAND.
- Select Create.
Add user data into DynamoDB:
- From the DynamoDB console, select Tables.
- Select the table deployed in the previous step and choose Explore Items.
- Enter the following JSON with View DynamoDB JSON toggled off. { "serialNumber": "<< Replace with your AWS IoT Button serial number here>>", "familyContact": "<<Replace with family contact phone number in E.164 format>>", "familyContactMessage": "I need your help, please come to the house today.", "userName": "John Doe", "userPhoneNum": "<<Replace with user/subscriber contact phone number in E.164 format>>” } 
- Select Create item.
Configure AWS IoT Core Rules:
- In the AWS IoT Core console, from the left-hand side panel, select Message routing.
- Select Rules.
- Select Create rule.
- Input a descriptive name for your rule in the Rule name field.
- Select Next.
- Make sure to select 2016-03-23 in the SQL version field.
- Input the following Select statement into the SQL statement section.SELECT serialNumber as serialNumber, clickType as clickType FROM‘device/+/data’ 
- Select Next.
- Select Lambda in the Rule actions Action 1 field.
- Choose the Lambda that you have deployed previously via CloudFormation.
- Select Next. 
- Review your Rule configuration in the Review and create section.
- Select Create.
Test the solution
The solution as deployed is for a fictional home user that needs to contact their family member and pharmacy via button clicks. However, this solution can be applied to any other use case where a user needs to request service by clicking a button. For testing purposes, we are using the same agent to simulate the pharmacy technician and pharmacist. Optionally, you can create two agent ids, and use those to test as the pharmacy technician and pharmacist. Finally, instead of an AWS IoT button, we will use the AWS IoT Core MQTT test client to generate click messages.
Validate your test results by going to the associated Amazon CloudWatch Logs Log Group for the Lambda deployed in the previous steps.
- In the MQTT test client section, select Subscribe to a topic.
- Input device/1/data as the Topic filter.
- Choose Subscribe. This enables you to see all events sent to this topic in the Subscriptions section. 
- In the MQTT test client section, select Publish to a topic.
- Input device/1/data as the Topic name.
- Input {“serialNumber”: ”<button_serial_number>“, ”clickType”: ”SINGLE”}as the Message payload.
- Choose Publish. This simulates a one click action.
- Replace the <button_serial_number> value with the serialNumber value input in the DynamoDB table from previous steps. 
- You will also see this event in the Subscriptions section for device/1/data. 
- Verify that a text message is received on the family member’s mobile device with the text “I need your help, please come to the house today”. 
- As the pharmacy technician, Log in the Amazon Connect Control Panel (CCP) and change your agent status to Available.
- In the MQTT test client section, input {“serialNumber”: ”<button_serial_number>“, ”clickType”: ”DOUBLE”}as the Message payload.
- Choose Publish. This simulates a double-click action. 
- Verify that a task is queued to the pharmacy technician.
- After picking up the task, notice the task displayed as “Please refill medication for John Doe for delivery tomorrow”. 
- Select End task and change your agent status to Available.
- In the MQTT test client section, input {“serialNumber”: ”<button_serial_number>“, ”clickType”: ”LONG”}as the Message payload.
- Choose Publish. This simulates a long press action. 
- Verify that you receive a call on the patient phone and that a call is ringing in the pharmacist’s CCP. As the pharmacist, select Accept call.

Cleaning up
To avoid incurring future charges:
- Delete the rules created in AWS IoT Rules via the AWS IoT Core console Rules section.
- From the CloudFormation console, select the deployed CloudFormation stack and choose Delete to delete the deployed services and IAM roles.
- Delete the Amazon Connect flows imported for this blog by using Archiving and deleting flows.
- Release the phone number from your Amazon Pinpoint SMS account.
- If you had to claim a new Amazon Connect phone number, release this phone number.
Conclusion
In this post, we have implemented a solution to help businesses achieve their digital accessibility objective by enabling service and help requests via click button patterns.
If your use case requires connecting users to different agent groups based on their click patterns, add additional routing logic to the Amazon Connect flows. If you have specific IoT devices for your use case, review Connecting devices to AWS IoT to connect these devices to AWS IoT Core. Ensure that the Rules, Lambda, and DynamoDB from the blog are updated to support your device message format. If your use case requires additional security, explore Security in AWS IoT.
To learn more about Amazon Connect, go to About Amazon Connect. To learn more about AWS IoT Core, go to How AWS IoT works.
Ready to transform your customer service experience with Amazon Connect and AWS IoT? Contact us.