authservice-nextjs
Version:
Next.js SDK for Auth Service - Server and client-side authentication with App Router support
97 lines • 4.05 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
exports.NextAuthProvider = NextAuthProvider;
exports.useNextAuth = useNextAuth;
const react_1 = __importStar(require("react"));
const authservice_react_sdk_1 = require("authservice-react-sdk");
const router_1 = require("next/router");
const authservice_core_1 = require("authservice-core");
const NextAuthContext = (0, react_1.createContext)(null);
function NextAuthProviderInner({ children, config }) {
const router = (0, router_1.useRouter)();
const reactAuth = (0, authservice_react_sdk_1.useAuth)();
const redirectToLogin = (returnUrl) => {
const loginUrl = config.loginUrl || '/login';
const url = new URL(loginUrl, window.location.origin);
if (returnUrl || router.asPath !== '/') {
url.searchParams.set('returnUrl', returnUrl || router.asPath);
}
router.push(url.pathname + url.search);
};
const redirectToUnauthorized = () => {
router.push(config.unauthorizedUrl || '/unauthorized');
};
return (react_1.default.createElement(NextAuthContext.Provider, { value: {
...reactAuth,
loading: reactAuth.isLoading,
error: null,
hasPermission: (permission) => {
const user = reactAuth.user;
if (!user?.permissions)
return false;
return user.permissions.includes(permission);
},
hasAnyPermission: (permissions) => {
const user = reactAuth.user;
if (!user?.permissions)
return false;
return permissions.some(p => user.permissions.includes(p));
},
hasAllPermissions: (permissions) => {
const user = reactAuth.user;
if (!user?.permissions)
return false;
return permissions.every(p => user.permissions.includes(p));
},
redirectToLogin,
redirectToUnauthorized,
} }, children));
}
function NextAuthProvider({ children, config }) {
return (react_1.default.createElement(authservice_react_sdk_1.AuthProvider, { client: new authservice_core_1.AuthServiceClient({
apiUrl: config.authServiceUrl,
appId: config.appId
}) },
react_1.default.createElement(NextAuthProviderInner, { config: config }, children)));
}
function useNextAuth() {
const context = (0, react_1.useContext)(NextAuthContext);
if (!context) {
throw new Error('useNextAuth must be used within NextAuthProvider');
}
return context;
}
//# sourceMappingURL=provider.js.map