Skip to content

Commit

Permalink
fix: return error if missing session or missing custom auth header (#891
Browse files Browse the repository at this point in the history
)

## What kind of change does this PR introduce?
* Adds a new property `hasCustomAuthorizationHeader` which will be set
by supabase-js
* `getUser` should return an `AuthSessionMissingError` if there is no
session and no custom auth header is set

---------

Co-authored-by: Stojan Dimitrovski <[email protected]>
  • Loading branch information
kangmingtay and hf authored Apr 25, 2024
1 parent a26f771 commit 8d16578
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 0 deletions.
8 changes: 8 additions & 0 deletions src/GoTrueClient.ts
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,7 @@ const DEFAULT_OPTIONS: Omit<Required<GoTrueClientOptions>, 'fetch' | 'storage' |
headers: DEFAULT_HEADERS,
flowType: 'implicit',
debug: false,
hasCustomAuthorizationHeader: false,
}

/** Current session will be checked for refresh at this interval. */
Expand Down Expand Up @@ -154,6 +155,7 @@ export default class GoTrueClient {
protected headers: {
[key: string]: string
}
protected hasCustomAuthorizationHeader = false
protected fetch: Fetch
protected lock: LockFunc
protected lockAcquired = false
Expand Down Expand Up @@ -202,6 +204,7 @@ export default class GoTrueClient {
this.lock = settings.lock || lockNoOp
this.detectSessionInUrl = settings.detectSessionInUrl
this.flowType = settings.flowType
this.hasCustomAuthorizationHeader = settings.hasCustomAuthorizationHeader

if (settings.lock) {
this.lock = settings.lock
Expand Down Expand Up @@ -1174,6 +1177,11 @@ export default class GoTrueClient {
throw error
}

// returns an error if there is no access_token or custom authorization header
if (!data.session?.access_token && !this.hasCustomAuthorizationHeader) {
return { data: { user: null }, error: new AuthSessionMissingError() }
}

return await _request(this.fetch, 'GET', `${this.url}/user`, {
headers: this.headers,
jwt: data.session?.access_token ?? undefined,
Expand Down
5 changes: 5 additions & 0 deletions src/lib/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,11 @@ export type GoTrueClientOptions = {
* @experimental
*/
lock?: LockFunc
/**
* Set to "true" if there is a custom authorization header set globally.
* @experimental
*/
hasCustomAuthorizationHeader?: boolean
}

export type WeakPasswordReasons = 'length' | 'characters' | 'pwned' | string
Expand Down

0 comments on commit 8d16578

Please sign in to comment.