Fix routing and api robots.txt

This commit is contained in:
dangered wolf 2023-11-10 15:48:59 -05:00
parent c937f8543b
commit 3b14d1e63f
No known key found for this signature in database
GPG key ID: 41E4D37680ED8B58
5 changed files with 11 additions and 16 deletions

View file

@ -6,19 +6,12 @@ import { generateUserAgent } from './helpers/useragent';
const API_ATTEMPTS = 3; const API_ATTEMPTS = 3;
let wasElongatorDisabled = false; let wasElongatorDisabled = false;
/* TODO: Figure out why TS globals were broken when not forcing globalThis */
declare const globalThis: {
fetchCompletedTime: number;
};
const generateSnowflake = () => { const generateSnowflake = () => {
const epoch = 1288834974657n; /* Twitter snowflake epoch */ const epoch = 1288834974657n; /* Twitter snowflake epoch */
const timestamp = BigInt(Date.now()) - epoch; const timestamp = BigInt(Date.now()) - epoch;
return String((timestamp << 22n) | BigInt(Math.floor(Math.random() * 696969))); return String((timestamp << 22n) | BigInt(Math.floor(Math.random() * 696969)));
}; };
globalThis.fetchCompletedTime = 0;
export const twitterFetch = async ( export const twitterFetch = async (
c: Context, c: Context,
url: string, url: string,
@ -184,7 +177,6 @@ export const twitterFetch = async (
continue; continue;
} }
globalThis.fetchCompletedTime = performance.now();
if ( if (
!wasElongatorDisabled && !wasElongatorDisabled &&

View file

@ -9,8 +9,8 @@ export const api = new Hono();
/* Current v1 API endpoints. Currently, these still go through the Twitter embed requests. API v2+ won't do this. */ /* Current v1 API endpoints. Currently, these still go through the Twitter embed requests. API v2+ won't do this. */
api.get('/status/:id/:language?', statusRequest); api.get('/status/:id/:language?', statusRequest);
api.get('/:handle/status/:id/:language?', statusRequest); api.get('/:handle/status/:id/:language?', statusRequest);
api.get('/robots.txt', async c => c.text(Strings.ROBOTS_TXT_API));
api.get('/:handle', profileRequest); api.get('/:handle', profileRequest);
api.get('/robots.txt', async c => c.text(Strings.ROBOTS_TXT));
api.all('*', async c => c.redirect(Constants.API_DOCS_URL, 302)); api.all('*', async c => c.redirect(Constants.API_DOCS_URL, 302));

View file

@ -30,14 +30,14 @@ export const getBaseRedirectUrl = (c: Context) => {
const tweetRequest = async (c: Context) => await statusRequest(c); const tweetRequest = async (c: Context) => await statusRequest(c);
const _profileRequest = async (c: Context) => await profileRequest(c); const _profileRequest = async (c: Context) => await profileRequest(c);
twitter.get('/:prefix?/:handle?/:endpoint{status(es)?}/:id/:language?', tweetRequest); twitter.get('/:handle{[0-9a-zA-Z_]+}/:endpoint{status(es)?}/:id{[0-9]+}/:language{[a-z]+}?', tweetRequest);
twitter.get(':handle?/:endpoint{status(es)?}/:id/:language?', tweetRequest); twitter.get('/:prefix{(dir|dl)}/:handle{[0-9a-zA-Z_]+}/status/:id{[0-9]+}/:language{[a-z]+}?', tweetRequest);
twitter.get( twitter.get(
'/:prefix?/:handle/:endpoint{status(es)?}/:id/:mediaType{(photos?|videos?)}/:mediaNumber{[1-4]}/:language?', '/:handle{[0-9a-zA-Z_]+}/status/:id{[0-9]+}/:mediaType{(photos?|videos?)}/:mediaNumber{[1-4]}/:language{[a-z]+}?',
tweetRequest tweetRequest
); );
twitter.get( twitter.get(
'/:handle/:endpoint{status(es)?}/:id/:mediaType{(photos?|videos?)}/:mediaNumber{[1-4]}/:language?', '/:prefix{(dir|dl)}/:handle{[0-9a-zA-Z_]+}/status/:id{[0-9]+}/:mediaType{(photos?|videos?)}/:mediaNumber{[1-4]}/:language{[a-z]+}?',
tweetRequest tweetRequest
); );

View file

@ -6,7 +6,8 @@ import { Strings } from '../../../strings';
/* Handler for status (Tweet) request */ /* Handler for status (Tweet) request */
export const statusRequest = async (c: Context) => { export const statusRequest = async (c: Context) => {
const { handle, id, mediaNumber, language, prefix } = c.req.param(); const { prefix, handle, id, mediaNumber, language } = c.req.param();
console.log('req', JSON.stringify(c.req))
const url = new URL(c.req.url); const url = new URL(c.req.url);
const flags: InputFlags = {}; const flags: InputFlags = {};

View file

@ -228,5 +228,7 @@ Disallow: /owoembed/
Allow: /watch?v=dQw4w9WgXcQ Allow: /watch?v=dQw4w9WgXcQ
# 0100011101101111011011110110010000100000011000100110111101110100`, # 0100011101101111011011110110010000100000011000100110111101110100`,
X_DOMAIN_NOTICE: 'FixTweet - 🆕 x.com link? Try fixupx.com' ROBOTS_TXT_API: `# Crawlers should not crawl API endpoints
User-agent: *
Disallow: /`
}; };