2021-05-23 08:27:51 +02:00
|
|
|
// to use with <input type="url"> fields, as the default pattern only checks for `:`,
|
|
|
|
export const DEFAULT_TEXTFIELD_URL_PATTERN = 'https?://.*';
|
|
|
|
|
2022-12-14 20:52:11 +01:00
|
|
|
/**
|
|
|
|
* Determines if a URL is valid
|
|
|
|
* @param {string} url - A URL to validate.
|
|
|
|
* @param {string[]} validProtocols - An array of valid protocols. Defaults to web.
|
|
|
|
* @returns {boolean} - True if the URI is valid, false otherwise.
|
|
|
|
*/
|
2022-12-15 08:33:32 +01:00
|
|
|
export function isValidUrl(url: string, validProtocols: string[] = ['http:', 'https:']): boolean {
|
2021-02-16 20:24:54 +01:00
|
|
|
try {
|
2022-05-12 08:31:31 +02:00
|
|
|
const validationObject = new URL(url);
|
2022-12-15 08:33:32 +01:00
|
|
|
|
2022-05-12 08:31:31 +02:00
|
|
|
if (
|
|
|
|
validationObject.protocol === '' ||
|
|
|
|
validationObject.hostname === '' ||
|
|
|
|
!validProtocols.includes(validationObject.protocol)
|
|
|
|
) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
} catch (e) {
|
2021-02-16 20:24:54 +01:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2021-02-16 20:41:24 +01:00
|
|
|
return true;
|
2021-02-07 05:07:01 +01:00
|
|
|
}
|
2022-12-14 20:52:11 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Determines if an account is valid by simply checking for a protocol, username
|
|
|
|
* and server, delimited by a colon. For example: @username:example.com
|
|
|
|
* @param {string} account - An account to validate.
|
|
|
|
* @param {string} protocol - The protocol we expect the account to be using.
|
|
|
|
* @returns {boolean} - True if the account is valid, false otherwise.
|
|
|
|
*/
|
|
|
|
export function isValidAccount(account: string, protocol: string): boolean {
|
|
|
|
if (account.startsWith('@')) {
|
|
|
|
// eslint-disable-next-line no-param-reassign
|
|
|
|
account = account.slice(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
const components = account.split(/:|@/);
|
|
|
|
const [service, user, host] = components;
|
|
|
|
|
|
|
|
console.log({ account, protocol, service, user, host });
|
|
|
|
if (service !== protocol) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (components.length !== 3 || !service || !user || !host) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determines if an account is valid by simply checking for a protocol, username
|
|
|
|
* and server, delimited by a colon. For example: @username:example.com
|
|
|
|
* @param {string} account - An account to validate.
|
|
|
|
* @returns {boolean} - True if the account is valid, false otherwise.
|
|
|
|
*/
|
|
|
|
export function isValidMatrixAccount(account: string): boolean {
|
|
|
|
if (account.startsWith('matrix:')) {
|
|
|
|
// eslint-disable-next-line no-param-reassign
|
|
|
|
account = account.slice(7);
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (account.startsWith('@')) {
|
|
|
|
// eslint-disable-next-line no-param-reassign
|
|
|
|
account = account.slice(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
const components = account.split(':');
|
|
|
|
const [user, host] = components;
|
|
|
|
|
|
|
|
if (components.length !== 2 || !user || !host) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|