diff --git a/.env.example b/.env.example index b4c372f..d99c76f 100644 --- a/.env.example +++ b/.env.example @@ -5,7 +5,6 @@ TEXT_ONLY_DOMAINS = "t.fxtwitter.com,t.twittpr.com,t.fixupx.com" INSTANT_VIEW_DOMAINS = "i.fxtwitter.com,i.twittpr.com,i.fixupx.com" GALLERY_DOMAINS = "g.fxtwitter.com,g.twittpr.com,g.fixupx.com" DEPRECATED_DOMAIN_LIST = "pxtwitter.com,www.pxtwitter.com" -DEPRECATED_DOMAIN_EPOCH = "1559320000000000000" MOSAIC_DOMAIN_LIST = "mosaic.fxtwitter.com" API_HOST_LIST = "api.fxtwitter.com,api-canary.fxtwitter.com" HOST_URL = "https://fxtwitter.com" diff --git a/esbuild.config.mjs b/esbuild.config.mjs index 9562607..65aa8a8 100644 --- a/esbuild.config.mjs +++ b/esbuild.config.mjs @@ -44,8 +44,7 @@ let envVariables = [ 'MOSAIC_DOMAIN_LIST', 'API_HOST_LIST', 'SENTRY_DSN', - 'DEPRECATED_DOMAIN_LIST', - 'DEPRECATED_DOMAIN_EPOCH' + 'DEPRECATED_DOMAIN_LIST' ]; // Create defines for all environment variables diff --git a/jestconfig.json b/jestconfig.json index 799557b..37e6521 100644 --- a/jestconfig.json +++ b/jestconfig.json @@ -12,7 +12,6 @@ "DIRECT_MEDIA_DOMAINS": "d.fxtwitter.com,dl.fxtwitter.com,d.fixupx.com,dl.fixupx.com", "MOSAIC_DOMAIN_LIST": "mosaic.fxtwitter.com", "DEPRECATED_DOMAIN_LIST": "pxtwitter.com,www.pxtwitter.com", - "DEPRECATED_DOMAIN_EPOCH": "1559320000000000000", "API_HOST_LIST": "api.fxtwitter.com", "HOST_URL": "https://fxtwitter.com", "REDIRECT_URL": "https://github.com/FixTweet/FixTweet", diff --git a/src/constants.ts b/src/constants.ts index af2d5f9..99cf212 100644 --- a/src/constants.ts +++ b/src/constants.ts @@ -7,7 +7,6 @@ export const Constants = { INSTANT_VIEW_DOMAINS: INSTANT_VIEW_DOMAINS.split(','), GALLERY_DOMAINS: GALLERY_DOMAINS.split(','), DEPRECATED_DOMAIN_LIST: DEPRECATED_DOMAIN_LIST.split(','), - DEPRECATED_DOMAIN_EPOCH: BigInt(DEPRECATED_DOMAIN_EPOCH), MOSAIC_DOMAIN_LIST: MOSAIC_DOMAIN_LIST.split(','), API_HOST_LIST: API_HOST_LIST.split(','), HOST_URL: HOST_URL, diff --git a/src/embed/status.ts b/src/embed/status.ts index 188d25b..b453d8d 100644 --- a/src/embed/status.ts +++ b/src/embed/status.ts @@ -3,7 +3,7 @@ import { Constants } from '../constants'; import { handleQuote } from '../helpers/quote'; import { formatNumber, sanitizeText, truncateWithEllipsis } from '../helpers/utils'; import { Strings } from '../strings'; -import { getAuthorText } from '../helpers/author'; +import { getSocialProof } from '../helpers/socialproof'; import { renderPhoto } from '../render/photo'; import { renderVideo } from '../render/video'; 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 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, ' '); let siteName = Constants.BRANDING_NAME; let newText = status.text; @@ -435,8 +435,10 @@ export const handleStatus = async ( if (!flags.gallery) { /* The additional oembed is pulled by Discord to enable improved embeds. Telegram does not use this. */ + let providerEngagementText = getSocialProof(status) ?? Strings.DEFAULT_AUTHOR_TEXT; + providerEngagementText = providerEngagementText.replace(/ {4}/g, ' '); headers.push( - ``.format( + ``.format( { base: Constants.HOST_URL, text: flags.gallery @@ -445,7 +447,8 @@ export const handleStatus = async ( deprecatedFlag: flags?.deprecated ? '&deprecated=true' : '', status: encodeURIComponent(statusId), 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)}` : '' } ) ); diff --git a/src/helpers/author.ts b/src/helpers/socialproof.ts similarity index 95% rename from src/helpers/author.ts rename to src/helpers/socialproof.ts index e9d1249..ecb0a13 100644 --- a/src/helpers/author.ts +++ b/src/helpers/socialproof.ts @@ -1,7 +1,7 @@ import { formatNumber } from './utils'; /* 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 */ if ( status.likes > 0 || diff --git a/src/realms/twitter/routes/oembed.ts b/src/realms/twitter/routes/oembed.ts index de80759..c822b81 100644 --- a/src/realms/twitter/routes/oembed.ts +++ b/src/realms/twitter/routes/oembed.ts @@ -15,13 +15,13 @@ export const oembed = async (c: Context) => { const random = Math.floor(Math.random() * Object.keys(motd).length); const [name, url] = Object.entries(motd)[random]; + const statusUrl = `${Constants.TWITTER_ROOT}/${encodeURIComponent(author)}/status/${status}`; + const data: OEmbed = { author_name: text, - author_url: `${Constants.TWITTER_ROOT}/${encodeURIComponent(author)}/status/${status}`, - /* Change provider name if status is on deprecated domain. */ - provider_name: - searchParams.get('deprecated') === 'true' ? Strings.DEPRECATED_DOMAIN_NOTICE_DISCORD : name, - provider_url: url, + author_url: statusUrl, + provider_name: searchParams.get('provider') ?? name, + provider_url: searchParams.get('provider') ? statusUrl : url, title: Strings.DEFAULT_AUTHOR_TEXT, type: 'link', version: '1.0' diff --git a/src/realms/twitter/routes/status.ts b/src/realms/twitter/routes/status.ts index 8b5d4c8..06b5e9a 100644 --- a/src/realms/twitter/routes/status.ts +++ b/src/realms/twitter/routes/status.ts @@ -66,8 +66,7 @@ export const statusRequest = async (c: Context) => { /* The pxtwitter.com domain is deprecated and statuses posted after deprecation date will have a notice saying we've moved to fxtwitter.com! */ if ( - Constants.DEPRECATED_DOMAIN_LIST.includes(url.hostname) && - BigInt(id?.match(/\d{2,20}/g)?.[0] || 0) > Constants.DEPRECATED_DOMAIN_EPOCH + Constants.DEPRECATED_DOMAIN_LIST.includes(url.hostname) ) { console.log('Request to deprecated domain'); flags.deprecated = true; diff --git a/src/render/instantview.ts b/src/render/instantview.ts index 043b67d..15058a2 100644 --- a/src/render/instantview.ts +++ b/src/render/instantview.ts @@ -1,6 +1,6 @@ /* eslint-disable no-irregular-whitespace */ import { Constants } from '../constants'; -import { getSocialTextIV } from '../helpers/author'; +import { getSocialTextIV } from '../helpers/socialproof'; import { sanitizeText } from '../helpers/utils'; import { Strings } from '../strings'; diff --git a/src/types/env.d.ts b/src/types/env.d.ts index d7af39a..2b04cf2 100644 --- a/src/types/env.d.ts +++ b/src/types/env.d.ts @@ -5,7 +5,6 @@ declare const TEXT_ONLY_DOMAINS: string; declare const INSTANT_VIEW_DOMAINS: string; declare const GALLERY_DOMAINS: string; declare const DEPRECATED_DOMAIN_LIST: string; -declare const DEPRECATED_DOMAIN_EPOCH: string; declare const HOST_URL: string; declare const EMBED_URL: string; declare const REDIRECT_URL: string;