Files
supabase/apps/studio/lib/gotrue.test.ts

52 lines
1.9 KiB
TypeScript

import { describe, expect, it } from 'vitest'
import { DEFAULT_FALLBACK_PATH, validateReturnTo } from './gotrue'
describe('validateReturnTo', () => {
const fallback = DEFAULT_FALLBACK_PATH
it('should return the path if it is a valid internal path', () => {
expect(validateReturnTo('/dashboard')).toBe('/dashboard')
expect(validateReturnTo('/settings/profile')).toBe('/settings/profile')
expect(validateReturnTo('/projects?id=123')).toBe('/projects?id=123')
})
it('should return fallback if given an external URL', () => {
expect(validateReturnTo('https://example.com')).toBe(fallback)
expect(validateReturnTo('http://malicious-site.com')).toBe(fallback)
expect(validateReturnTo('//evil.com')).toBe(fallback)
})
it('should return fallback for potentially malicious paths', () => {
expect(validateReturnTo('/%2e%2e/etc/passwd')).toBe(fallback)
expect(validateReturnTo('/..')).toBe(fallback)
expect(validateReturnTo('/@evil/path')).toBe(fallback)
expect(validateReturnTo('/$malicious')).toBe(fallback)
})
it('should use custom fallback when provided', () => {
const customFallback = '/custom-fallback'
expect(validateReturnTo('https://example.com', customFallback)).toBe(customFallback)
expect(validateReturnTo('/%2e%2e/etc/passwd', customFallback)).toBe(customFallback)
})
it('should handle paths with query parameters correctly', () => {
expect(validateReturnTo('/dashboard?param1=value1&param2=value2')).toBe(
'/dashboard?param1=value1&param2=value2'
)
})
it('should handle nextjs dynamic path js', () => {
expect(
validateReturnTo(
'%2F%5B%5Bx%5D%5Djavascript%3Aalert(%22H4CK3D%22)%2F%5By%5D%2F%5B%5Bx%5D%5D%2F%5By%5D%3Fx%26y'
)
).toBe(fallback)
expect(
validateReturnTo(
'/%2F%5B%5Bx%5D%5Djavascript%3Aalert(%22H4CK3D%22)%2F%5By%5D%2F%5B%5Bx%5D%5D%2F%5By%5D%3Fx%26y'
)
).toBe(fallback)
})
})