Skip to content

Latest commit

 

History

History
151 lines (135 loc) · 5.19 KB

File metadata and controls

151 lines (135 loc) · 5.19 KB

Celtics Engine Frontend Web Application

About

This is a full stack project built on AWS Amplify with Angular and TypeScript. It provides a service for Celtics Game Engine users to search, save, and share game model assets.

Problem Statement

  • The Users of the the game engine will need a way to share asset models they have created with other users.
  • The Asset Management web application should provide the nessesary functionality to allow users to share their assets with other users

Top Questions to Resolve in Review

  • What tools should we use to build the application?
  • Does it make more sense to use a single page application or a multi page application?
  • Should the asset management system be a single full-stack application or a separate web application?
  • How should we structure the application? (Auth, Api, UI, etc...)
  • What should the user experience be like?

Client Use Cases

  • Post 3d asset models publicly so others can use it and/or get inspiration from it.
  • Store 3d asset models on the cloud.
  • Browse public community models and see what others have created.
  • Ability for logged in user to remove their own assets from the community search page.
  • Ability to sort assets by popularity and browse the website WITHOUT having to create an account or login

Project Scope

  • Create a single page application that allows users to manage and share their own custom asset models with other users publicly.
  • Retrieve and display the latest 3d assets from the community.

Out of Project Scope

  • Ability to create or edit an asset model from the browser

Proposed Architecture Overview

1. Users & Authentication [AWS Conginto]

  • Authentication and user managment will be handled by aws cognito
  • Login and register with the application
  • Confirmation email on registration
  • Change password

2. Single Page Application & UI [Angular]

  • Navigation bar will be explicity linked to the different PageStates of the application
  • The PageState will have logic to determine permissions for the user
  • Redirect routes will handle some of the navigation
    • Redirect to the home page after login
    • Redirect to asset details page if thumbnail is clicked
  • UI pages
    • Login
    • Profile
    • Asset Upload
    • Asset Details
    • Search / Explore

3. Storage [S3]

  • Storage access rules:
    • Signed-in users: upload, view, and delete
    • Signed-out users: view
  • Asset upload to S3 Bucket from user local machine
  • Upload forms will be limited to zip files and images exclusivly
  • A storage cap will be set for the user to upload

4. API [GraphQL]

  • Provides main functionality for public searchabe asset models
  • Queries will be used to retrieve asset models
  • Linked to S3 for identification of the asset model
  • Linked to cognito for authentication
  • Linked to DynamoDB for data model

5. Continues Deployment [AWS]

  • Deployment will be handled by AWS Amplify
  • Amplify push cmd will be used to deploy the application to either production or development
  • Cloudformation will be used to create the necessary resources for the application

Accomplishment Tracking

Week 1:

Goals:

  • Setup Tech Stack
  • Setup Data Model
  • Structure application and outline plan of execution with UML diagrams

Activity:

  • Initailize s3
  • Create user file storage bucket and dir structure

Important Docs, Commits, or Code Reviews:

Things learned:

  • privacy best practices for user file storage and permissions


Week 2:

Goals:

  • Migrate Java Backend to TypeScript
  • Setup Amplify and CI/CD
  • Create a user authentication system
  • Structure application PageState

Activity:

  • Create Amplify app
  • Create Login, Logged-In, Search, Public, and Private Application States
  • Redux-like implementation of Application PageStates
  • Research different authentication methods

Important Docs, Commits, or Code Reviews:

Things learned:

  • Redux concepts
  • Authentication system principles


Week 3:

Goals:

  • Setup Graphql API
  • Setup s3 bucket for user file storage
  • Start UI development

Activity:

  • Graphql API intergration with Amplify
  • Search functionality with API, both public and private assets
  • Sorting by an input param
  • Serealization and deseralization of bucket data
  • Account activation and User Data Model to store User info

Important Docs, Commits, or Code Reviews:

Things learned:

  • UI intergration with backend


Week 4

Goals: Bugs and Feature cleanup

Activity:

  • UI bugs
  • Graphql API optimizations
  • User file storage security
  • User authentication bugs

Important Docs, Commits, or Code Reviews:

Things learned:

  • Common UI bugs
  • UI optimizations