@jeswr/css-auth-utils
v1.4.0
Published
This is a temporary library for logging into the Community Solid Server using [client credentials](https://communitysolidserver.github.io/CommunitySolidServer/5.x/usage/client-credentials/).
Readme
CSS Auth Utils
This is a temporary library for logging into the Community Solid Server using client credentials.
import { getAuthenticatedFetch } from '@jeswr/css-auth-utils';
const fetch = getAuthenticatedFetch({
podName: 'example',
email: '[email protected]',
password: 'abc123',
url: 'http://localhost:3002/'
})Logging in using the browser flow
In some testing use cases we wish to follow the browser login flow, but mock the user interaction with the browser. This can be achieved using the cssRedirectFactory which fills in the email and password and completes the user flow with the CSS using puppeteer.
Generally this should only be used when testing browser login flows in e2e tests.
import { cssRedirectFactory } from '@jeswr/css-auth-utils';
await session.login({
oidcIssuer: 'http://localhost:3000/',
redirectUrl: 'http://localhost:3001/',
handleRedirect: cssRedirectFactory('[email protected]', 'abc123')
});If you just wish to get the session, and don't need to control the server for redirect URLs then you can do:
import { getSessionFromBrowserLogin } from '@jeswr/css-auth-utils';
const session = await getSessionFromBrowserLogin({
email: '[email protected]',
password: 'abc123',
oidcIssuer: 'http://localhost:3000/',
});[ESS] Logging in using the browser flow
import { essRedirectFactory } from '@jeswr/css-auth-utils';
await session.login({
oidcIssuer: 'https://login.inrupt.com/',
redirectUrl: 'http://localhost:3001/',
handleRedirect: cssRedirectFactory('myUsername', 'abc123')
});import { getSessionFromBrowserLogin, essRedirectFactory } from '@jeswr/css-auth-utils';
const session = await getSessionFromBrowserLogin({
oidcIssuer: 'https://login.inrupt.com/',
email: 'myUsername',
password: 'abc123',
redirectFactory: essRedirectFactory
});License
©2023–present Jesse Wright, MIT License.
