Implement JWT authentication using cookies.
Implement authorization headers for non-SSE routes.
Implement basic rate limiting to prevent abuse.
Create a demo chat interface.
React state update too frequently during SSE.
Add GitHub OAuth login functionality.
Implement front-end validation for various fields.
Used Vercel built-in CDN caching for PDFs metadata. Changed Cache-Control header to 1 year.
Reduce bandwidth usage by caching PDFs.
Used Vercel Blob Storage Built-in CDN & Firebase Storage Caching Strategy
Rename chat session to be more descriptive.
Utilized another LLM chain to generate a more descriptive title
Let user manually rename chat session.
Created a new endpoint to update chat session title
Improve data parsing and display in the chat interface.
Currently using React Markdown, better spacing with proper <br> and parsing
Limit free tier user to 10 mb per month
Updated interface and current-user route and uploadp page to handle upload limit
Cron job or API to reset users upload limit monthly
Used cron-job.org
Have an option for user to optimize their uploaded PDFs before upserting to save bytes.
Update the dashboard and setting page to include functionality.
Use cookies for SSE route authentication.
Add CSRF protection to secure the application.
Enhance the user interface for better usability.
Upgrade the current approach of streaming text only.
Not Necessary --> Used React Markdown for now
Create a test to simulate handling 100+ users.
Implement chat functionality without PDF support.
Add custom memory implementation for chat sessions.
Add advanced rate limiting mechanisms.
Set up a reverse proxy for the application.
Not Needed