Add social proof for videos on discord

This commit is contained in:
dangered wolf 2023-12-08 20:08:05 -05:00
parent b00032808b
commit e394cbc931
No known key found for this signature in database
GPG key ID: 41E4D37680ED8B58
4 changed files with 14 additions and 11 deletions

View file

@ -3,7 +3,7 @@ import { Constants } from '../constants';
import { handleQuote } from '../helpers/quote'; import { handleQuote } from '../helpers/quote';
import { formatNumber, sanitizeText, truncateWithEllipsis } from '../helpers/utils'; import { formatNumber, sanitizeText, truncateWithEllipsis } from '../helpers/utils';
import { Strings } from '../strings'; import { Strings } from '../strings';
import { getAuthorText } from '../helpers/author'; import { getSocialProof } from '../helpers/socialproof';
import { renderPhoto } from '../render/photo'; import { renderPhoto } from '../render/photo';
import { renderVideo } from '../render/video'; import { renderVideo } from '../render/video';
import { renderInstantView } from '../render/instantview'; import { renderInstantView } from '../render/instantview';
@ -157,7 +157,7 @@ export const handleStatus = async (
/* At this point, we know we're going to have to create a /* At this point, we know we're going to have to create a
regular embed because it's not an API or direct media request */ regular embed because it's not an API or direct media request */
let authorText = getAuthorText(status) || Strings.DEFAULT_AUTHOR_TEXT; let authorText = getSocialProof(status) || Strings.DEFAULT_AUTHOR_TEXT;
const engagementText = authorText.replace(/ {4}/g, ' '); const engagementText = authorText.replace(/ {4}/g, ' ');
let siteName = Constants.BRANDING_NAME; let siteName = Constants.BRANDING_NAME;
let newText = status.text; let newText = status.text;
@ -435,8 +435,10 @@ export const handleStatus = async (
if (!flags.gallery) { if (!flags.gallery) {
/* The additional oembed is pulled by Discord to enable improved embeds. /* The additional oembed is pulled by Discord to enable improved embeds.
Telegram does not use this. */ Telegram does not use this. */
let providerEngagementText = getSocialProof(status) ?? Strings.DEFAULT_AUTHOR_TEXT;
providerEngagementText = providerEngagementText.replace(/ {4}/g, ' ');
headers.push( headers.push(
`<link rel="alternate" href="{base}/owoembed?text={text}{deprecatedFlag}&status={status}&author={author}" type="application/json+oembed" title="{name}">`.format( `<link rel="alternate" href="{base}/owoembed?text={text}{deprecatedFlag}&status={status}&author={author}{provider}" type="application/json+oembed" title="{name}">`.format(
{ {
base: Constants.HOST_URL, base: Constants.HOST_URL,
text: flags.gallery text: flags.gallery
@ -445,7 +447,8 @@ export const handleStatus = async (
deprecatedFlag: flags?.deprecated ? '&deprecated=true' : '', deprecatedFlag: flags?.deprecated ? '&deprecated=true' : '',
status: encodeURIComponent(statusId), status: encodeURIComponent(statusId),
author: encodeURIComponent(status.author.screen_name || ''), author: encodeURIComponent(status.author.screen_name || ''),
name: status.author.name || '' name: status.author.name || '',
provider: (status.embed_card === 'player' && providerEngagementText !== Strings.DEFAULT_AUTHOR_TEXT) ? `&provider=${encodeURIComponent(providerEngagementText)}` : ''
} }
) )
); );

View file

@ -1,7 +1,7 @@
import { formatNumber } from './utils'; import { formatNumber } from './utils';
/* The embed "author" text we populate with replies, retweets, and likes unless it's a video */ /* The embed "author" text we populate with replies, retweets, and likes unless it's a video */
export const getAuthorText = (status: APITwitterStatus): string | null => { export const getSocialProof = (status: APITwitterStatus): string | null => {
/* Build out reply, retweet, like counts */ /* Build out reply, retweet, like counts */
if ( if (
status.likes > 0 || status.likes > 0 ||

View file

@ -15,13 +15,13 @@ export const oembed = async (c: Context) => {
const random = Math.floor(Math.random() * Object.keys(motd).length); const random = Math.floor(Math.random() * Object.keys(motd).length);
const [name, url] = Object.entries(motd)[random]; const [name, url] = Object.entries(motd)[random];
const statusUrl = `${Constants.TWITTER_ROOT}/${encodeURIComponent(author)}/status/${status}`;
const data: OEmbed = { const data: OEmbed = {
author_name: text, author_name: text,
author_url: `${Constants.TWITTER_ROOT}/${encodeURIComponent(author)}/status/${status}`, author_url: statusUrl,
/* Change provider name if status is on deprecated domain. */ provider_name: searchParams.get('provider') ?? name,
provider_name: provider_url: searchParams.get('provider') ? statusUrl : url,
searchParams.get('deprecated') === 'true' ? Strings.DEPRECATED_DOMAIN_NOTICE_DISCORD : name,
provider_url: url,
title: Strings.DEFAULT_AUTHOR_TEXT, title: Strings.DEFAULT_AUTHOR_TEXT,
type: 'link', type: 'link',
version: '1.0' version: '1.0'

View file

@ -1,6 +1,6 @@
/* eslint-disable no-irregular-whitespace */ /* eslint-disable no-irregular-whitespace */
import { Constants } from '../constants'; import { Constants } from '../constants';
import { getSocialTextIV } from '../helpers/author'; import { getSocialTextIV } from '../helpers/socialproof';
import { sanitizeText } from '../helpers/utils'; import { sanitizeText } from '../helpers/utils';
import { Strings } from '../strings'; import { Strings } from '../strings';