Skip to content

Commit

Permalink
feat: allow to disable auth during development (stackblitz#21)
Browse files Browse the repository at this point in the history
  • Loading branch information
d3lm authored Jul 30, 2024
1 parent 4df1da4 commit 58af0de
Show file tree
Hide file tree
Showing 6 changed files with 11 additions and 20 deletions.
2 changes: 1 addition & 1 deletion packages/bolt/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,10 +37,10 @@ VITE_LOG_LEVEL=debug
```

If you want to run authentication against a local StackBlitz instance, add:

```
VITE_CLIENT_ORIGIN=https://local.stackblitz.com:3000
```
`

**Important**: Never commit your `.env.local` file to version control. It's already included in .gitignore.

Expand Down
2 changes: 1 addition & 1 deletion packages/bolt/app/components/chat/Chat.client.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ export function ChatImpl({ initialMessages, storeMessageHistory }: ChatProps) {
const { messages, isLoading, input, handleInputChange, setInput, handleSubmit, stop, append } = useChat({
api: '/api/chat',
onError: (error) => {
logger.error(error);
logger.error('Request failed\n\n', error);
toast.error('There was an error processing your request');
},
onFinish: () => {
Expand Down
2 changes: 1 addition & 1 deletion packages/bolt/app/components/header/Header.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { ClientOnly } from 'remix-utils/client-only';
import { OpenStackBlitz } from './OpenStackBlitz.client';
import { IconButton } from '~/components/ui/IconButton';
import { OpenStackBlitz } from './OpenStackBlitz.client';

export function Header() {
return (
Expand Down
13 changes: 3 additions & 10 deletions packages/bolt/app/lib/.server/login.ts
Original file line number Diff line number Diff line change
@@ -1,20 +1,13 @@
import { env } from 'node:process';
import { isAuthenticated } from './sessions';
import { json, redirect, type LoaderFunctionArgs } from '@remix-run/cloudflare';

export function verifyPassword(password: string, cloudflareEnv: Env) {
const loginPassword = env.LOGIN_PASSWORD || cloudflareEnv.LOGIN_PASSWORD;

return password === loginPassword;
}
import { isAuthenticated } from './sessions';

type RequestArgs = Pick<LoaderFunctionArgs, 'request' | 'context'>;

export async function handleAuthRequest<T extends RequestArgs>(args: T, body: object = {}) {
const { request, context } = args;
const { authenticated, response } = await isAuthenticated(request, context.cloudflare.env);

if (authenticated) {
if (authenticated || import.meta.env.VITE_DISABLE_AUTH) {
return json(body, response);
}

Expand All @@ -25,7 +18,7 @@ export async function handleWithAuth<T extends RequestArgs>(args: T, handler: (a
const { request, context } = args;
const { authenticated, response } = await isAuthenticated(request, context.cloudflare.env);

if (authenticated) {
if (authenticated || import.meta.env.VITE_DISABLE_AUTH) {
const handlerResponse = await handler(args);

if (response) {
Expand Down
4 changes: 2 additions & 2 deletions packages/bolt/app/lib/.server/sessions.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import { createCookieSessionStorage, redirect } from '@remix-run/cloudflare';
import { decodeJwt } from 'jose';
import { request as doRequest } from '~/lib/fetch';
import { CLIENT_ID, CLIENT_ORIGIN } from '~/lib/constants';
import { request as doRequest } from '~/lib/fetch';
import { logger } from '~/utils/logger';

const DEV_SESSION_SECRET = import.meta.env.DEV ? 'LZQMrERo3Ewn/AbpSYJ9aw==' : undefined;
Expand Down Expand Up @@ -33,7 +33,7 @@ export async function isAuthenticated(request: Request, env: Env) {
try {
data = await refreshToken(token);
} catch {
// ignore
// we can ignore the error here because it's handled below
}

if (data != null) {
Expand Down
8 changes: 3 additions & 5 deletions packages/bolt/app/routes/login.tsx
Original file line number Diff line number Diff line change
@@ -1,16 +1,16 @@
import {
json,
redirect,
redirectDocument,
type ActionFunctionArgs,
type LoaderFunctionArgs,
redirectDocument,
} from '@remix-run/cloudflare';
import { useFetcher, useLoaderData } from '@remix-run/react';
import { auth, type AuthAPI } from '@webcontainer/api';
import { useEffect, useState } from 'react';
import { createUserSession, isAuthenticated, validateAccessToken } from '~/lib/.server/sessions';
import { request as doRequest } from '~/lib/fetch';
import { CLIENT_ID, CLIENT_ORIGIN } from '~/lib/constants';
import { request as doRequest } from '~/lib/fetch';
import { logger } from '~/utils/logger';

export async function loader({ request, context }: LoaderFunctionArgs) {
Expand Down Expand Up @@ -49,7 +49,7 @@ export async function action({ request, context }: ActionFunctionArgs) {
throw await response.json();
}
} catch (error) {
logger.warn('Authentication failure');
logger.warn('Authentication failed');
logger.warn(error);

return json({ error: 'invalid-token' as const }, { status: 401 });
Expand Down Expand Up @@ -100,7 +100,6 @@ export default function Login() {
<div>
<h2 className="mt-6 text-center text-3xl font-extrabold text-gray-900">Login</h2>
</div>

{redirected ? 'Processing auth...' : <LoginForm />}
</div>
</div>
Expand Down Expand Up @@ -162,7 +161,6 @@ function LoginForm() {
>
{login?.kind === 'pending' ? 'Authenticating...' : 'Continue with StackBlitz'}
</button>

{login?.kind === 'error' && (
<div>
<h2>
Expand Down

0 comments on commit 58af0de

Please sign in to comment.