Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 15 additions & 2 deletions src/lib/api-client.ts
Original file line number Diff line number Diff line change
Expand Up @@ -187,6 +187,19 @@ class ApiClient {
return 'to continue';
}

/**
* Check if endpoint should trigger auth modal on 401
* Auth checking endpoints should not auto-trigger modals
*/
private shouldTriggerAuthModal(endpoint: string): boolean {
// Don't trigger modal for auth state checking endpoints
if (endpoint === '/api/auth/profile') return false;
if (endpoint === '/api/auth/providers') return false;
if (endpoint === '/api/auth/sessions') return false;

return true;
}

/**
* Make HTTP request with proper error handling and type safety
*/
Expand Down Expand Up @@ -219,8 +232,8 @@ class ApiClient {
const data = await response.json();

if (!response.ok) {
// Intercept 401 responses and trigger auth modal
if (response.status === 401 && globalAuthModalTrigger) {
// Intercept 401 responses and trigger auth modal (but not for auth checking endpoints)
if (response.status === 401 && globalAuthModalTrigger && this.shouldTriggerAuthModal(endpoint)) {
// Determine context based on endpoint
const authContext = this.getAuthContextForEndpoint(endpoint);
globalAuthModalTrigger(authContext);
Expand Down
5 changes: 4 additions & 1 deletion vite.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,8 @@ import tailwindcss from '@tailwindcss/vite';
export default defineConfig({
optimizeDeps: {
exclude: ['format', 'editor.all'],
include: ['monaco-editor/esm/vs/editor/editor.api']
include: ['monaco-editor/esm/vs/editor/editor.api'],
force: true // Force re-optimization on every start
},
// build: {
// rollupOptions: {
Expand Down Expand Up @@ -64,4 +65,6 @@ export default defineConfig({
server: {
allowedHosts: true
},
// Clear cache more aggressively
cacheDir: 'node_modules/.vite'
});
8 changes: 4 additions & 4 deletions worker-configuration.d.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,11 @@
/* eslint-disable */
// Generated by Wrangler by running `wrangler types` (hash: 1c1d7051b80a70b551f16bfc274a9872)
// Generated by Wrangler by running `wrangler types` (hash: a12a0aff0cea8699250810648e5a7084)
// Runtime types generated with workerd@1.20250816.0 2025-08-10 nodejs_compat
declare namespace Cloudflare {
interface Env {
INSTANCE_REGISTRY: KVNamespace;
TEMPLATES_REPOSITORY: "https://github.com/AshishKumar4/cloudflare-build-templates";
CUSTOM_DOMAIN: "build.cloudflare.dev";
CLOUDFLARE_AI_GATEWAY: "orange-build-gateway";
ANTHROPIC_API_KEY: string;
OPENAI_API_KEY: string;
GOOGLE_AI_STUDIO_API_KEY: string;
Expand All @@ -19,7 +19,6 @@ declare namespace Cloudflare {
CLOUDFLARE_API_TOKEN: string;
CLOUDFLARE_ACCOUNT_ID: string;
CLOUDFLARE_AI_GATEWAY_URL: string;
CLOUDFLARE_AI_GATEWAY: string;
CLOUDFLARE_AI_GATEWAY_TOKEN: string;
SERPAPI_KEY: string;
GOOGLE_CLIENT_SECRET: string;
Expand All @@ -33,6 +32,7 @@ declare namespace Cloudflare {
ENVIRONMENT: string;
MAX_SANDBOX_INSTANCES: string;
SANDBOX_INSTANCE_TYPE: string;
CUSTOM_DOMAIN: string;
CodeGenObject: DurableObjectNamespace<import("./worker/index").CodeGeneratorAgent>;
Sandbox: DurableObjectNamespace<import("./worker/index").UserAppSandboxService>;
DeployerServiceObject: DurableObjectNamespace<import("./worker/index").DeployerService>;
Expand All @@ -50,7 +50,7 @@ type StringifyValues<EnvType extends Record<string, unknown>> = {
[Binding in keyof EnvType]: EnvType[Binding] extends string ? EnvType[Binding] : string;
};
declare namespace NodeJS {
interface ProcessEnv extends StringifyValues<Pick<Cloudflare.Env, "TEMPLATES_REPOSITORY" | "CUSTOM_DOMAIN" | "ANTHROPIC_API_KEY" | "OPENAI_API_KEY" | "GOOGLE_AI_STUDIO_API_KEY" | "OPENROUTER_API_KEY" | "CEREBRAS_API_KEY" | "GROQ_API_KEY" | "SANDBOX_SERVICE_API_KEY" | "SANDBOX_SERVICE_TYPE" | "SANDBOX_SERVICE_URL" | "CLOUDFLARE_DATABASE_ID" | "CLOUDFLARE_API_TOKEN" | "CLOUDFLARE_ACCOUNT_ID" | "CLOUDFLARE_AI_GATEWAY_URL" | "CLOUDFLARE_AI_GATEWAY" | "CLOUDFLARE_AI_GATEWAY_TOKEN" | "SERPAPI_KEY" | "GOOGLE_CLIENT_SECRET" | "GOOGLE_CLIENT_ID" | "GITHUB_CLIENT_ID" | "GITHUB_CLIENT_SECRET" | "JWT_SECRET" | "WEBHOOK_SECRET" | "AI_GATEWAY_PROXY_FOR_TEMPLATES_JWT_SECRET" | "AI_GATEWAY_PROXY_FOR_TEMPLATES_URL" | "ENVIRONMENT" | "MAX_SANDBOX_INSTANCES" | "SANDBOX_INSTANCE_TYPE">> {}
interface ProcessEnv extends StringifyValues<Pick<Cloudflare.Env, "TEMPLATES_REPOSITORY" | "CLOUDFLARE_AI_GATEWAY" | "ANTHROPIC_API_KEY" | "OPENAI_API_KEY" | "GOOGLE_AI_STUDIO_API_KEY" | "OPENROUTER_API_KEY" | "CEREBRAS_API_KEY" | "GROQ_API_KEY" | "SANDBOX_SERVICE_API_KEY" | "SANDBOX_SERVICE_TYPE" | "SANDBOX_SERVICE_URL" | "CLOUDFLARE_DATABASE_ID" | "CLOUDFLARE_API_TOKEN" | "CLOUDFLARE_ACCOUNT_ID" | "CLOUDFLARE_AI_GATEWAY_URL" | "CLOUDFLARE_AI_GATEWAY_TOKEN" | "SERPAPI_KEY" | "GOOGLE_CLIENT_SECRET" | "GOOGLE_CLIENT_ID" | "GITHUB_CLIENT_ID" | "GITHUB_CLIENT_SECRET" | "JWT_SECRET" | "WEBHOOK_SECRET" | "AI_GATEWAY_PROXY_FOR_TEMPLATES_JWT_SECRET" | "AI_GATEWAY_PROXY_FOR_TEMPLATES_URL" | "ENVIRONMENT" | "MAX_SANDBOX_INSTANCES" | "SANDBOX_INSTANCE_TYPE" | "CUSTOM_DOMAIN">> {}
}

// Begin runtime types
Expand Down
Loading