Stories: Only render text link if it's a valid URL
Co-authored-by: Scott Nonnenberg <scott@signal.org>
This commit is contained in:
parent
394f184119
commit
207ee6a90e
3 changed files with 40 additions and 3 deletions
|
@ -12,7 +12,7 @@ import { Emojify } from './conversation/Emojify';
|
|||
import { StoryLinkPreview } from './StoryLinkPreview';
|
||||
import { TextAttachmentStyleType } from '../types/Attachment';
|
||||
import { count } from '../util/grapheme';
|
||||
import { getSafeDomain } from '../types/LinkPreview';
|
||||
import { isValidLink, getSafeDomain } from '../types/LinkPreview';
|
||||
import { getFontNameByTextScript } from '../util/getFontNameByTextScript';
|
||||
import {
|
||||
COLOR_WHITE_INT,
|
||||
|
@ -197,7 +197,7 @@ export const TextAttachment = forwardRef<HTMLTextAreaElement, PropsType>(
|
|||
the story, but it must be positioned using the scaled offset
|
||||
*/}
|
||||
{textAttachment.preview &&
|
||||
textAttachment.preview.url &&
|
||||
isValidLink(textAttachment.preview.url) &&
|
||||
linkPreviewOffsetTop &&
|
||||
!isThumbnail && (
|
||||
<a
|
||||
|
|
|
@ -5,12 +5,36 @@ import { assert } from 'chai';
|
|||
|
||||
import {
|
||||
findLinks,
|
||||
isLinkSneaky,
|
||||
isValidLink,
|
||||
shouldLinkifyMessage,
|
||||
shouldPreviewHref,
|
||||
isLinkSneaky,
|
||||
} from '../../types/LinkPreview';
|
||||
|
||||
describe('Link previews', () => {
|
||||
describe('#isValidLink', () => {
|
||||
it('returns false for random, non-https URLs', () => {
|
||||
assert.isFalse(isValidLink(''));
|
||||
assert.isFalse(isValidLink('signal.com'));
|
||||
assert.isFalse(isValidLink('signal.org'));
|
||||
assert.isFalse(isValidLink('https'));
|
||||
assert.isFalse(isValidLink('https://'));
|
||||
assert.isFalse(isValidLink('https://bad url'));
|
||||
assert.isFalse(isValidLink('http://signal.org'));
|
||||
});
|
||||
|
||||
it('returns true for https:// URLs', () => {
|
||||
assert.isTrue(isValidLink('https://signal.org'));
|
||||
assert.isTrue(isValidLink('https://somewhere.someplace.signal.org/'));
|
||||
assert.isTrue(isValidLink('https://signal.org/something/another/#thing'));
|
||||
assert.isTrue(
|
||||
isValidLink(
|
||||
'https://signal.org/something/another/?one=two&three=four#thing'
|
||||
)
|
||||
);
|
||||
});
|
||||
});
|
||||
|
||||
describe('#shouldPreviewHref', () => {
|
||||
it('returns false for invalid URLs', () => {
|
||||
assert.isFalse(shouldPreviewHref(''));
|
||||
|
|
|
@ -48,6 +48,19 @@ export type AddLinkPreviewOptionsType = Readonly<{
|
|||
|
||||
const linkify = LinkifyIt();
|
||||
|
||||
export function isValidLink(maybeUrl: string | undefined): boolean {
|
||||
if (maybeUrl == null) {
|
||||
return false;
|
||||
}
|
||||
|
||||
try {
|
||||
const url = new URL(maybeUrl);
|
||||
return url.protocol === 'https:';
|
||||
} catch (_error) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
export function shouldPreviewHref(href: string): boolean {
|
||||
const url = maybeParseUrl(href);
|
||||
return Boolean(
|
||||
|
|
Loading…
Reference in a new issue