/building-a-machine-learning-enabled-web-app

This repository contains sample app code to build an object and text detection web app. An individual can upload images that contains real world objects or text, and get the labels for all the detected objects and texts in the image.

Primary LanguageVueMIT No AttributionMIT-0

Building a Machine Learning-Enabled Web App: AcadeML

This repo contains app code to accompany AWS Workshop Studio Building a Machine Learning-Enabled Web App.
As this is a standalone repo, it can be used without AWS Workshop Studio.

There are currently 2 labs in the workshop:

  1. Lab 1: Adding Amazon Rekognition to an existing web app
  2. Lab 2: Adding Amazon Textract to an existing web app

Audience

This is a foundational repo aimed at students learning how to call ML APIs and interpret JSON returned for the first time.

Technology and Services

The app stack:

  • Node.js, Javascript, AWS SDK V3 (Javascript)
  • Vue.js, Vuetify.js, and Vite

Prerequisites

The following software is required:

  1. Node.js
  2. The app requires an AWS account to run:
    1. If you are attending an AWS Workshop event, this is supplied to you.
    2. If you are using this repo outside of an hosted Workshop event, you will need to supply your own AWS account: Create a new account or sign in to your existing account.

Warning: The repo calls AWS services, which incur a cost. While briefly running the app as a learning exercise would only incur a relatively small cost, care should be taken to monitor spend and delete AWS resources and associated services when no longer needed to ensure future charges do not accrue.

Branches

There are 2 branches in this repo; start-lab and complete-lab.
The start-lab branch contains the web app without the code for calling ML APIs.
The steps to add this code are in the workshop referenced above.
The complete-lab branch contains the final code the student would have at the end of the lab.

Installation

  1. Clone the start-lab (or complete-lab if not attempting the workshop) branch into a new folder:
    1. git clone --single-branch --branch start-lab https://github.com/build-on-aws/building-a-machine-learning-enabled-web-app
  2. In the repo root folder run: npm install

AWS Credentials

If you are attending a hosted workshop, an AWS account with an IAM user with the correct permissions will be supplied to you.
If attempting to run this independently, you will need to supply your own AWS account.

In the AWS Console:

  1. Create an IAM user with policies AmazonRekognitionFullAccess and AmazonTextractFullAccess attached.
  2. Create an access key and secret access key (copy these before navigating away from the page)
  3. Create a file in the root folder of the app called .env.local (note the . before the word env).
  4. Add the following lines to .env.local:
  • VITE_AWS_ACCESS_KEY_ID=AccessKeyFromStep2
  • VITE_AWS_SECRET_ACCESS_KEY=SecretAccessKeyFromStep2
  • VITE_AWS_REGION=us-east-1

Running

  1. In the repo root folder run npm run dev
  2. Open the localhost website (http://localhost:3000 is the default)

Clean-up (non-Workshop Studio users)

Delete the AWS IAM user that was created by the installation steps above when you no longer need this app.

Security

See CONTRIBUTING for more information.

License

This library is licensed under the MIT-0 License. See the LICENSE file.