Skip to content

cmanikandan/gen-ai-trivia

 
 

Repository files navigation

Gen AI Trivia

alt text

Description

Gen AI Trivia is an interactive trivia application that generates questions and answers using artificial intelligence. It provides an engaging and educational experience for users to test their knowledge across various topics. Gen AI Trivia utilizes advanced natural language processing and machine learning techniques to generate unique and challenging trivia questions. The application consists of a backend API that handles question generation and a user-friendly frontend interface for users to interact with the trivia game.

Architecture

alt text

Folder Structure

The project's folder structure is organized as follows:

Folder/File Description
app/ Contains the application's infrastructure code that will be built and transformed within the CI/CD pipeline.
configs/ Contains the application's deployment configurations.
images/ Contains the images used within the README file.
pipeline/ Contains the application's infrastructure code for the CI/CD pipeline.
res/electron/ Contains the application's Electron settings file.
scripts/ Contains the scripts used to update configurations for the application.
www/ Contains the frontend code and related files.
requirements.txt Pip requirements file for the deployment environment.
README.md The main README file for the project.
CONTRIBUTING.md Guidelines for contributing to the project.
FAQ.md Frequently asked questions and their answers.
LICENSE The license file for the project.

Prerequisites

Before installing and running Gen AI Trivia, ensure that you have the following prerequisites:

Installation and Setup

Note: This solution can only be used in AWS Regions that have access to the Amazon Bedrock Claude 3 Sonnet model.

Get access to Amazon Bedrock Claude 3 Sonnet Model

The Gen AI Trivia solution uses the Amazon Bedrock Claude 3 Sonnet model as the method to generate the topic questions.

  1. Navigate to the Amazon Bedrock Service.

    alt text

  2. Click on "Get started".

    alt text

  3. If this is your first time using Amazon Bedrock, you will receive a welcome message. From there, click on "Manage model access".

    alt text

  4. Once on the Model access page, click on "Enable specific models".

    alt text

  5. Scroll down to the "Anthropic" section and click on the box next to the "Claude 3 Sonnet" model. Scroll down to the bottom of the page and click "Next".

    alt text

  6. Review that you've selected the correct model and click "Submit".

    alt text

  7. Once the model access request has been submitted, it should be approved. To verify it was approved, navigate back to the "Model access" page and ensure you see an "Access granted" text next to the requested model.

    alt text

Deploy CI/CD Pipeline

The Gen AI Trivia code will deploy a CI/CD Pipeline that will deploy the Gen AI Trivia application. To install and set up the Gen AI Trivia Pipeline, follow these steps:

  1. Clone the repository.

    git clone https://github.com/aws-samples/gen-ai-trivia.git
  2. Navigate to the project directory.

    cd gen-ai-trivia
  3. Install Python dependencies.

    pip install -r requirements.txt
  4. Ensure you have access to an AWS Account.

  5. Create initial CDK Bootstrap dependencies, then generate AWS CloudFormation Code and finally deploy the generated code.

    cdk bootstrap
    cdk synth gen-ai-trivia-pipeline
    cdk deploy gen-ai-trivia-pipeline --require-approval never
  6. To trigger the run of the AWS CodePipeline, the code must be uploaded to the designated Source S3 Bucket. Optionally, this step can be automated by leveraging GitHub Actions or equivalent version control and Continuous Integration (CI) technologies.

    python ./scripts/upload_to_source_bucket.py

    The pipeline run will create 3 AWS CloudFormation stacks (gen-ai-trivia-pipeline, gen-ai-trivia-application, and gen-ai-trivia-s3-artifact-deployment). Once the pipeline completes, continue to the next step.

    alt text

  7. Add users to the Amazon Cognito User Pool.

    a. Navigate to the Amazon Cognito service.

    alt text

    b. Ensure you're in the "User pools" section and select the generated user pool.

    alt text

    c. Ensure you're in the "Users" section and click on "Create user".

    alt text

    d. Select "Send an email invitation", enter in the desired "User name", enter an email address you have access to, select "Mark email address as verified", and select "Generate a password". Doing the following will generate an email with a password for the first time you log in.

    alt text

  8. Once the deployment is complete, access the application using the provided URL. The URL can be found in the "Outputs" tab of the AWS CloudFormation stack "gen-ai-trivia-application".

    alt text

    Or run the following command to get the URL:

    aws cloudformation describe-stacks --stack-name "gen-ai-trivia-application" --query 'Stacks[*].Outputs[?OutputKey==`oTerraformBucket`].OutputValue' --output text
  9. Navigate to and log in to the URL from step 7. Use the email with the generated password from step 5 to log in. Once you are logged in, you will be prompted to change the password.

    alt text alt text

  10. Work hard. Have fun. Make history.

alt text

Uninstall Solution

  1. To remove the AWS CloudFormation Stacks along with the AWS Resources they create, run the following commands:

    cdk destroy gen-ai-trivia-s3-artifact-deployment --force
    aws cloudformation delete-stack --stack-name gen-ai-trivia-application
    aws cloudformation wait stack-delete-complete --stack-name gen-ai-trivia-application
    cdk destroy gen-ai-trivia-pipeline --force

Contributing

We welcome contributions to improve the Gen AI Trivia project. Please refer to the CONTRIBUTING.md file for detailed guidelines on how to contribute.

FAQ

For common issues and their resolutions, please refer to the FAQ.md file.

License

This project is licensed under the MIT License.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 57.7%
  • Vue 36.4%
  • JavaScript 4.8%
  • Other 1.1%