Lovable deployment

Environment Variables Undefined in Production Build

API keys and configuration values are undefined in production. Supabase URL and API key return undefined, causing all API calls to fail. Works locally with .env.local but not in production.

Vite only exposes variables prefixed with VITE_ to the client. Production requires proper build-time or runtime environment setup.

Error Messages You Might See

Cannot read property of undefined Supabase URL is undefined API key is required
Cannot read property of undefinedSupabase URL is undefinedAPI key is required

Common Causes

  1. Environment variable doesn't have VITE_ prefix
  2. .env file not loaded during build
  3. Using process.env instead of import.meta.env
  4. Environment variables not set in production deployment platform
  5. Build cache not cleared after env change

How to Fix It

Use VITE_ prefix for client-side variables in .env:

VITE_SUPABASE_URL=https://xxx.supabase.co
VITE_SUPABASE_KEY=xxx

Access in code:

import.meta.env.VITE_SUPABASE_URL

Set same variables in production platform (Vercel, Netlify, Railway env settings).

Real developers can help you.

Milan Surelia Milan Surelia Milan Surelia is a Mobile App Developer with 5+ years of experience crafting scalable, cross-platform apps at 7Span and Meticha. At 7Span, he engineers feature-rich Flutter apps with smooth performance and modern UI. As the Co-Founder of Meticha, he builds open-source tools and developer-focused products that solve real-world problems. Expertise: ๐Ÿ’ก Developing cross-platform apps using Flutter, Dart, and Jetpack Compose for Android, iOS, and Web. ๐Ÿ–‹๏ธ Sharing insights through technical writing, blogging, and open-source contributions. ๐Ÿค Collaborating closely with designers, PMs, and developers to build seamless mobile experiences. Notable Achievements: ๐ŸŽฏ Revamped the Vepaar app into Vepaar Store & CRM with a 2x performance boost and smoother UX. ๐Ÿš€ Launched Compose101 โ€” a Jetpack Compose starter kit to speed up Android development. ๐ŸŒŸ Open source contributions on Github & StackOverflow for Flutter & Dart ๐ŸŽ–๏ธ Worked on improving app performance and user experience with smart solutions. Milan is always happy to connect, work on new ideas, and explore the latest in technology. Simon A. Simon A. I'm a backend developer building APIs, emulators, and interactive game systems. Professionally, I've developed Java/Spring reporting solutions, managed relational and NoSQL databases, and implemented CI/CD workflows. Matthew Butler Matthew Butler Systems Development Engineer @ Amazon Web Services BurnHavoc BurnHavoc Been around fixing other peoples code for 20 years. Caio Rodrigues Caio Rodrigues I'm a full-stack developer focused on building practical and scalable web applications. My main experience is with **React, TypeScript, and modern frontend architectures**, where I prioritize clean code, component reusability, and maintainable project structures. I have strong experience working with **dynamic forms, state management (Redux / React Hook Form), and complex data-driven interfaces**. I enjoy solving real-world problems by turning ideas into reliable software that companies can actually use in their daily operations. Beyond coding, I care about **software quality and architecture**, following best practices for componentization, code organization, and performance optimization. I'm also comfortable working across the stack when needed, integrating APIs, handling business logic, and helping transform prototypes into production-ready systems. My goal is always to deliver solutions that are **simple, efficient, and genuinely useful for the people using them.** Jen Jacobsen Jen Jacobsen Iโ€™m a Full-Stack Developer with over 10 years of experience building modern web and mobile applications. I enjoy working across the full product lifecycle โ€” turning ideas into real, well-built products that are intuitive for users and scalable for businesses. I particularly enjoy building mobile apps, modern web platforms, and solving complex technical problems in a way that keeps systems clean, reliable, and easy to maintain. Bastien Labelle Bastien Labelle Full stack dev w/ 20+ years of experience Franck Plazanet Franck Plazanet I am a Strategic Engineering Leader with over 8 years of experience building high-availability enterprise systems and scaling high-performing technical teams. My focus is on bridging the gap between complex technology and business growth. Core Expertise: ๐Ÿš€ Leadership: Managing and coaching teams of 15+ engineers, fostering a culture of accountability and continuous improvement. ๐Ÿ—๏ธ Architecture: Enterprise Core Systems, Multi-system Integration (ERP/API/ETL), and Core Database Structure. โ˜๏ธ Cloud & Scale: AWS Expert; architected systems handling 10B+ monthly requests and managing 100k+ SKUs. ๐Ÿ“ˆ Business Impact: Aligning tech strategy with P&L goals to drive $70k+ in monthly recurring revenue. I thrive on "out-of-the-box" thinking to solve complex technical bottlenecks and am always looking for ways to use automation to improve business productivity. Daniel Vรกzquez Daniel Vรกzquez Software Engineer with over 10 years of experience on Startups, Government, big tech industry & consulting. Vlad Temian Vlad Temian 15+ years shipping production infrastructure for startups. Former CTO at qed.builders (acquired by The Sandbox). Cursor ambassador and agentic tooling builder. I've scaled systems, automated deployments, and built observability tools for AI coding workflows. I specialize in taking vibe-coded apps from broken prototype to production-ready: fixing Supabase auth/RLS, Stripe integrations, deployment pipelines, and cleaning up AI-generated spaghetti. I build tools in this space (agentprobe, claudebin, micode) and understand both sides: how AI generates code and why it breaks. https://blog.vtemian.com/

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help

Frequently Asked Questions

How do I expose env variables to browser?

Use VITE_ prefix in .env file. Access with import.meta.env.VITE_VARIABLE_NAME

How do I set env in production?

Use deployment platform's environment variable settings (Vercel, Netlify dashboards) or set in hosting environment.

Related Lovable Issues

Can't fix it yourself?
Real developers can help.

You don't need to be technical. Just describe what's wrong and a verified developer will handle the rest.

Get Help