Skip to content

Commit

Permalink
Revert "feat(nextjs): Allow for redirectUrl to be the first parameter"
Browse files Browse the repository at this point in the history
This reverts commit ee5708a.
  • Loading branch information
panteliselef committed Dec 13, 2023
1 parent ee5708a commit 2b0f942
Showing 1 changed file with 13 additions and 29 deletions.
42 changes: 13 additions & 29 deletions packages/nextjs/src/app-router/server/auth.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,23 +17,15 @@ type AuthSignedIn = AuthObjectWithoutResources<
* This function is experimental as it throws a Nextjs notFound error if user is not authenticated or authorized.
* In the future we would investigate a way to throw a more appropriate error that clearly describes the not authorized of authenticated status.
*/
protect: {
(
params?:
| CheckAuthorizationParamsWithCustomPermissions
| ((has: CheckAuthorizationWithCustomPermissions) => boolean),
options?: { redirectUrl: string },
): AuthObjectWithoutResources<SignedInAuthObject>;

(params?: { redirectUrl: string }): AuthObjectWithoutResources<SignedInAuthObject>;
};
protect: (
params?:
| CheckAuthorizationParamsWithCustomPermissions
| ((has: CheckAuthorizationWithCustomPermissions) => boolean),
options?: { redirectUrl: string },
) => AuthObjectWithoutResources<SignedInAuthObject>;
}
>;

type ProtectGeneric = {
protect: (params?: unknown, options?: unknown) => AuthObjectWithoutResources<SignedInAuthObject>;
};

type AuthSignedOut = AuthObjectWithoutResources<
SignedOutAuthObject & {
/**
Expand All @@ -51,21 +43,13 @@ export const auth = () => {
noAuthStatusMessage: authAuthHeaderMissing(),
})(buildRequestLike());

(authObject as unknown as ProtectGeneric).protect = (params: any, options: any) => {
const paramsOrFunction = params?.redirectUrl
? undefined
: (params as
| CheckAuthorizationParamsWithCustomPermissions
| ((has: CheckAuthorizationWithCustomPermissions) => boolean));
const redirectUrl = (params?.redirectUrl || options?.redirectUrl) as string | undefined;

(authObject as AuthSignedIn).protect = (params, options) => {
const handleUnauthorized = (): never => {
if (redirectUrl) {
redirect(redirectUrl);
if (options?.redirectUrl) {
redirect(options.redirectUrl);
}
notFound();
};

/**
* User is not authenticated
*/
Expand All @@ -76,15 +60,15 @@ export const auth = () => {
/**
* User is authenticated
*/
if (!paramsOrFunction) {
if (!params) {
return { ...authObject };
}

/**
* if a function is passed and returns false then throw not found
*/
if (typeof paramsOrFunction === 'function') {
if (paramsOrFunction(authObject.has)) {
if (typeof params === 'function') {
if (params(authObject.has)) {
return { ...authObject };
}
return handleUnauthorized();
Expand All @@ -93,7 +77,7 @@ export const auth = () => {
/**
* Checking if user is authorized when permission or role is passed
*/
if (authObject.has(paramsOrFunction)) {
if (authObject.has(params)) {
return { ...authObject };
}

Expand Down

0 comments on commit 2b0f942

Please sign in to comment.