import { h, Component } from '/js/web_modules/preact.js'; import htm from '/js/web_modules/htm.js'; const html = htm.bind(h); export default class IndieAuthForm extends Component { constructor(props) { super(props); this.submitButtonPressed = this.submitButtonPressed.bind(this); this.state = { errorMessage: null, loading: false, valid: false, }; } async submitButtonPressed() { const { accessToken, authenticated } = this.props; const { host, valid } = this.state; if (!valid) { return; } const url = `/api/auth/indieauth?accessToken=${accessToken}`; const data = { authHost: host }; this.setState({ loading: true }); try { const rawResponse = await fetch(url, { method: 'POST', headers: { Accept: 'application/json', 'Content-Type': 'application/json', }, body: JSON.stringify(data), }); const content = await rawResponse.json(); if (content.message) { this.setState({ errorMessage: content.message, loading: false }); return; } else if (!content.redirect) { this.setState({ errorMessage: 'Auth provider did not return a redirect URL.', loading: false, }); return; } if (content.redirect) { const redirect = content.redirect; window.location = redirect; } } catch (e) { console.error(e); this.setState({ errorMessage: e, loading: false }); } } onInput = (e) => { const { value } = e.target; let valid = validateURL(value); this.setState({ host: value, valid }); }; render() { const { errorMessage, loading, host, valid } = this.state; const { authenticated } = this.props; const buttonState = valid ? '' : 'cursor-not-allowed opacity-50'; const loaderStyle = loading ? 'flex' : 'none'; const message = !authenticated ? `While you can chat completely anonymously you can also add authentication so you can rejoin with the same chat persona from any device or browser.` : html`You are already authenticated. However, you can add other external sites or log in as a different user.`; let errorMessageText = errorMessage; if (!!errorMessageText) { if (errorMessageText.includes('url does not support indieauth')) { errorMessageText = 'The provided URL is either invalid or does not support IndieAuth.'; } } const error = errorMessage ? html` ` : null; return html`

${message}

${error}

Learn more about IndieAuth

IndieAuth allows for a completely independent and decentralized way of identifying yourself using your own domain.

If you run an Owncast instance, you can use that domain here. Otherwise, ${' '} learn more about how you can support IndieAuth.

Note: This is for authentication purposes only, and no personal information will be accessed or stored.

Authenticating.

Please wait...

`; } } function validateURL(url) { if (!url) { return false; } try { const u = new URL(url); if (!u) { return false; } if (u.protocol !== 'https:') { return false; } } catch (e) { return false; } return true; }