Skip to content

Multi-tenant AWS app, for providing CMS to repair-focused businesses.

Notifications You must be signed in to change notification settings

ThugPigeon653/repairshop

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 

Repository files navigation

This application focuses on cms and invoicing needs of a repair shop. For a better understanding of the function of this application, see scripts/ddl.sql, and scripts/ cloudformation/template.json

IMPORTANT: This web application has been created for my own eduction, and should not be considered production-ready. The application is mostly complete, but is still currently under active development. Some important things to keep in mind are: - Built for lowest cost: multi-az, high-performance instances, etc. have not been applied. This is to reduce cost during development phase. - The cloudforamtion currently contains some variables which will become sensitive, if this is deployed as-is. Be sure you understand who might be able to gain access to these values, and what that means for you. - There is a major vulnerability at the moment, regarding one of the API gateway methods currently NOT configured to require auth. This has been done for testing purposes, and is not suitable for production. - The frontend is partially complete. Extensive testing will be required once this is done - No CICD pipeline has been added yet for the lambda functions. This is a critical step if you wish to has a managable, upgradable application


DEPLOYMENT: The final deployment process should be far more streamlined, however the currrent deployment process is as follows:

1. Setup s3 bucket
 - Create a bucket s3, called 'repair-lneil'. This naming does need to be 
 globally unique - if you need to change the name, you will also need to ammend
 the cloudformation template, as well as the .sh and .bat files in scripts/.
 - Windows users can run 'upload.bat', which will automatically upload all 
 scripts to the previously mentioned s3 location. If you cannot run .bat, a
 manual upload to s3 will be required. This can easily be done with s3 cli, or
 by using the s3 console directly. If this is the case, only add the full contents
 of the scripts/ directory.
 - Next, you will need to run 'zip-python.sh' on a linux machine, with s3 
 access. The easiest way to do this is by using cloudshell. The bash script
 has been written to cleanup after itself automatically, so no files will be 
 inadvertently left on the machine. 
 - Note: both of the provided helper scripts are dynamic, so you do not need to 
 change them if more backed scripts are added to this folder - they  will 
 indiscriminantly upload and zip all scripts/*.py files to s3.

2. Cloudformation deployment
 - Deploy 'template.json', using Cloudformation. This will automatically create
 all the aws infrastructure require. 

3. Frontend
 - The frontend is in the midst of development, and is only partially functional.
 - To connect to the api gateway, you will need to update the url found in 
 "src/custom-exports.js", and the value of 'proxy' in package.json. 
 - The frontend can be run anywhere at the moment. 
 - The frontend should work after cors has been corrected, and auth has been fully
 implemented (i.e. Amplify Authenticator frontend component)

DEVELOPER INFO: Lachlan Neilsen lnelisen1996@outlook.com

About

Multi-tenant AWS app, for providing CMS to repair-focused businesses.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published