Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mjunaidca/caxai
CaX: Applied GenAI Multi User Todo GPT App - Implementation of Microservices GenUI Architecture.
https://github.com/mjunaidca/caxai
api architect custom-gpt custom-gpts fastapi fastapi-auth fastapi-nextjs fastapi-oa fastapi-sqlalchemy fastapi-vercel genai genai-poc gpt-ai nextjs14 oauth2 python-vercel todo-dashboard todoapp
Last synced: 3 months ago
JSON representation
CaX: Applied GenAI Multi User Todo GPT App - Implementation of Microservices GenUI Architecture.
- Host: GitHub
- URL: https://github.com/mjunaidca/caxai
- Owner: mjunaidca
- Created: 2024-01-04T15:29:10.000Z (about 1 year ago)
- Default Branch: feat/architect-microservices
- Last Pushed: 2024-03-30T23:13:50.000Z (10 months ago)
- Last Synced: 2024-10-11T09:36:12.768Z (4 months ago)
- Topics: api, architect, custom-gpt, custom-gpts, fastapi, fastapi-auth, fastapi-nextjs, fastapi-oa, fastapi-sqlalchemy, fastapi-vercel, genai, genai-poc, gpt-ai, nextjs14, oauth2, python-vercel, todo-dashboard, todoapp
- Language: TypeScript
- Homepage:
- Size: 2.45 MB
- Stars: 9
- Watchers: 1
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
# CaX: Applied GenAI Multi User Todo GPT App
Implementation of Microservices GenUI Architecture. The Current Microservices are:
- auth-server: Auth Server to manage Authentication & Authorization
- todo-server: Simple ToDo Server to authenticate using auth-server & perform TODOs Crud.
- nextjs-client: Conversational UI & TODOs Manager platform for you.# Running Locally & Development:
You can setup & run the project locally on your machine or on docker. Firstly let'e setup the env vars.
- In auth-server
` Rename .env.example to .env and add DB_URL, TEST_DB_URL, SECRET_KEY `- In todo-server add DB_URL & TEST_DB_URL. They can be same as above or different
- For nextjs-client run pnpm install - no need to update them
### 1. Local Machine
Open root dir i.e: cax in terminal and run
1. Terminal 1: `make auth` & visit `http://localhost:8080/api/docs`
2. Terminal 2: `make todo` & visit `http://localhost:8000/api/docs`
3. Terminal 3: `make next` & visit `http://localhost:3000`### 2. Docker
Rename root .env.example to .env and add the missing env vars (DB_URL=, TEST_DB_URL=, SECRET_KEY=)
Run: `docker compose -d up`
# Deployment:
We will be deploying FastAPI Microservices to Google Cloud Run and NextJS CUI to Vercel.
0. Ensure your have gcloud and vercel cli installed & authenticated
1. auth-server
```
cd auth-servergcloud run deploy auth-server --source . --port 8080 --env-vars-file .env.gcp.yaml --allow-unauthenticated --region us-central1 --min-instances 1
```2. todo-server
```
cd todo-servergcloud run deploy todo-micro-server --source . --port 8000 --env-vars-file .env.gcp.yaml --allow-unauthenticated --region us-central1 --min-instances 1
```3. nextjs-client
```
cd nextjs-clientvercel link
```Then visit vercel and add all env vars to your project and in terminal run:
`vercel --prod`