Add Generative AI to a JavaScript Web App
Learn how to integrate genAI with minimal code changes using JS, Cognito credentials to invoke the Amazon Bedrock API in a React single page app.
How Does This Application Work?
An instance of a Large Language Model
First: Chat With Amazon Bedrock
Second: Knowledge Bases for Amazon Bedrock
Let's Deploy React Generative AI Application With Amazon Bedrock and AWS Javascript SDK
Step 1 - Enable AWS Amplify Hosting:
Step 2 - Access to the App URL:
Let's Try React Generative AI Application With Amazon Bedrock Javascript SDK
šØšØšØšØšØ This blog is outdated, check the new version Add Generative AI to a JavaScript Web App 2.0 šØšØšØšØšØšØ
data:image/s3,"s3://crabby-images/aedb8/aedb86802ae1fcb38686f0a08babd14a9ae31e38" alt="Authentication Authentication"
- Chat with Amazon Bedrock
- Knowledge Bases for Amazon Bedrock
Ā
data:image/s3,"s3://crabby-images/9bd56/9bd5637e6be52ba300f1a6ee875f05522bf3ca5e" alt="Demos Menu Demos menu"
data:image/s3,"s3://crabby-images/8d60a/8d60af9bcb095377a9f04bb09e0b99899440827c" alt="Chat Q&A Chat Q&A"
data:image/s3,"s3://crabby-images/ce1d3/ce1d3dd0d0b530f7b070d3b72b785eae117b8313" alt="Chat Q&A Chat Q&A"
data:image/s3,"s3://crabby-images/0c143/0c1435fa7447dcc3ab056d5a8b3002510ab8c454" alt="Chat with Memory Chat with Memory"
chat_history
key in the memory to get past dialogs, hence you use that key as memoryKey in BufferMemory.data:image/s3,"s3://crabby-images/313ad/313adc92f2fbd0ec9950461b6a32cd7644accb86" alt="Knowledge Bases for Amazon Bedrock Knowledge Bases for Amazon Bedrock"
data:image/s3,"s3://crabby-images/8d04f/8d04f3a830b9573c94a22cc685a124223993ccf8" alt="Amazon Bedrock Retrieve => LLM Amazon Bedrock Retrieve => LLM"
data:image/s3,"s3://crabby-images/2e180/2e1808f345adf774e23eaf44ea3fe126ef7b7594" alt="Amazon Bedrock Retrieve & Generate Amazon Bedrock Retrieve & Generate"
- first fork this repo:
- Create a New branch:
dev-branch
. - Then follow the steps in Getting started with existing code guide.
- In Step 1 Add repository branch, select main branch and Connecting a monorepo? Pick a folder and enter
reactjs-gen-ai-apps
as a root directory.Add repository branch - For the next Step, Build settings, select
building-a-gen-ai-gen-ai-personal-assistant-reactjs-apps(this app)
as App name, in Enviroment select Create a new envitoment and writedev.
data:image/s3,"s3://crabby-images/1ec9a/1ec9aab9c1761ecfc42bed39aea2ba6a4177ebaa" alt="App build and test settings App build and test settings"
- If there is no existing role, create a new one to service Amplify.
- Deploy your app.
data:image/s3,"s3://crabby-images/bc13e/bc13e507dea5086de58277f6e3e509dbb9d53964" alt="Amplify Deploy Amplify Deploy"
data:image/s3,"s3://crabby-images/52926/529263c594b01d0fd1a5e22163779bdd99455caa" alt="Sing In Window Sing In Window"
data:image/s3,"s3://crabby-images/2333f/2333f573b1596620438d23d3c6975adf4709d677" alt="Backend environments Backend environments"
data:image/s3,"s3://crabby-images/5e6cd/5e6cd2f546a7251bcf48ec736dda5ac5f29aea29" alt="View in Cognito View in Cognito"
hideSignUp: false
in App.jsx, but this can introduce a security flaw by giving anyone access to it.Any opinions in this post are those of the individual author and may not reflect the opinions of AWS.