2024-04-15 19:14:13 +09:00
|
|
|
<?php
|
2024-05-10 18:18:36 +09:00
|
|
|
// Copyright (C) 2024 Hong Yongmin <https://revi.xyz/>
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
2024-04-15 19:14:13 +09:00
|
|
|
|
2024-05-02 19:52:47 +09:00
|
|
|
abstract class PhabricatorRobotsController extends PhabricatorController {
|
2024-04-15 19:14:13 +09:00
|
|
|
|
2024-05-02 19:25:47 +09:00
|
|
|
public function shouldRequireLogin() {
|
|
|
|
return false;
|
2024-05-11 17:28:38 +09:00
|
|
|
}
|
2024-05-02 19:25:47 +09:00
|
|
|
|
2024-06-17 12:40:01 +09:00
|
|
|
// TODO: Different content for cdn domains
|
2024-04-15 19:14:13 +09:00
|
|
|
|
2024-05-11 17:28:38 +09:00
|
|
|
public function processRequest() {
|
|
|
|
$out = array();
|
2024-04-15 19:14:13 +09:00
|
|
|
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = '# Adapted from phabricator.wikimedia.org, we.phorge.it';
|
|
|
|
// Version timestamp is when I started editing them.
|
|
|
|
// Edit setLastModified at the bottom as well.
|
|
|
|
// Calculate EpochTime via go/epoch
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = '# version: 20240621T160501+0900';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = '# also at https://github.com/revi/sandbox.git';
|
|
|
|
$out[] = 'User-Agent: *';
|
|
|
|
$out[] = 'Disallow: /diffusion/';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /diffusion';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /source/';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /source';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /multimeter/';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /multimeter';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /policy/explain';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /auth/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /auth';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /login/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /login';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /maniphest/transaction/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /maniphest/transaction';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /tag/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /tag';
|
2024-05-22 19:11:36 +00:00
|
|
|
$out[] = 'Disallow: /search/';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /search';
|
|
|
|
$out[] = 'Disallow: /conduit/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /conduit';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /api/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /api';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /project/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /project';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /applications/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /applications';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /token/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /token';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /pholio/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /pholio';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /dashboard/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /dashboard';
|
|
|
|
$out[] = 'Disallow: /calendar';
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /herald/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /herald';
|
|
|
|
// This is commits.
|
|
|
|
$out[] = 'Disallow: /r*';
|
|
|
|
// This is differential revisions. (D*)
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /differential/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /differential';
|
|
|
|
$out[] = 'Disallow: /D*';
|
|
|
|
// This is Files. (F*)
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /file/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /file';
|
|
|
|
$out[] = 'Disallow: /F*';
|
|
|
|
// This is pastes (P*)
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /paste/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /paste';
|
|
|
|
$out[] = 'Disallow: /P*';
|
|
|
|
// This is blog entries (J$)
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /phame/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /phame';
|
|
|
|
$out[] = 'Disallow: /J*';
|
|
|
|
// This is user list.
|
|
|
|
// As of 2024-04-17 user list is behind auth but who knows it might change?
|
2024-06-21 16:02:42 +09:00
|
|
|
$out[] = 'Disallow: /people/';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'Disallow: /people';
|
|
|
|
// This is user profile link.
|
|
|
|
$out[] = 'Disallow: /p/';
|
|
|
|
// Phorge specific entries end here.
|
|
|
|
$out[] = '# This is cloudflare endpoint';
|
|
|
|
$out[] = '# Ref: https://issuetracker.revi.xyz/u/cloudflarecdncgi';
|
|
|
|
$out[] = 'Disallow: /cdn-cgi/';
|
|
|
|
$out[] = '# Google Ads are not welcome';
|
|
|
|
$out[] = 'User-agent: Mediapartners-Google';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = 'User-agent: AdsBot-Google';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = 'User-agent: AdsBot-Google-Mobile';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
// While I sometimes (borderline 'rare') use LLMs (GPT, Gemini, …), I'd rather prefer LLMs not use my stuff to profit
|
|
|
|
// Well I think my stuff is mostly out of interest for them, tho…
|
|
|
|
$out[] = '# ChatGPT Crawlers are not welcome';
|
|
|
|
$out[] = '# Ref: https://platform.openai.com/docs/plugins/bot';
|
|
|
|
$out[] = 'User-agent: ChatGPT-User';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = 'User-agent: GPTBot';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = '# Google Gemini AI Crawlers are also not welcome';
|
|
|
|
$out[] = '# Ref: https://issuetracker.revi.xyz/u/googleextended';
|
|
|
|
$out[] = 'User-agent: Google-Extended';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = '# CCBot (ab)used to train LLMs';
|
|
|
|
$out[] = '# Ref: https://darkvisitors.com/agents/ccbot';
|
|
|
|
$out[] = 'User-agent: CCBot';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = '# Facebook LLM Bot';
|
|
|
|
$out[] = '# Ref: https://developers.facebook.com/docs/sharing/bot/';
|
|
|
|
$out[] = 'User-agent: FacebookBot';
|
|
|
|
$out[] = 'Disallow: /';
|
2024-06-19 15:15:38 +09:00
|
|
|
$out[] =
|
|
|
|
'# DiffBot, though this one is known to have option to ignore robotstxt';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = '# Ref https://issuetracker.revi.xyz/u/robotstxtdiffbot';
|
|
|
|
$out[] = 'User-agent: Diffbot';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = '# Bytespider';
|
|
|
|
$out[] = '# Ref: https://darkvisitors.com/agents/bytespider';
|
|
|
|
$out[] = 'User-agent: Bytespider';
|
|
|
|
$out[] = 'Disallow: /';
|
2024-06-19 15:15:38 +09:00
|
|
|
$out[] = '# See https://revi.xyz/robots.txt for rationales';
|
|
|
|
$out[] = 'User-agent: TurnitinBot';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = 'User-agent: NPBot';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = 'User-agent: SlySearch';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = 'User-agent: BLEXBot';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = '# Block CheckMarkNetwork';
|
|
|
|
$out[] =
|
|
|
|
'User-agent: CheckMarkNetwork/1.0 (+https://www.checkmarknetwork.com/spider.html)';
|
|
|
|
$out[] = 'Disallow: /';
|
|
|
|
$out[] = 'User-agent: BrandVerity/1.0';
|
2024-05-22 19:11:36 +00:00
|
|
|
$out[] = 'Disallow: /';
|
2024-06-17 12:40:01 +09:00
|
|
|
$out[] = '# Block peer39';
|
|
|
|
$out[] = 'User-agent: peer39_crawler';
|
|
|
|
$out[] = 'User-agent: peer39_crawler/1.0';
|
|
|
|
$out[] = 'Disallow: /';
|
2024-06-19 15:15:38 +09:00
|
|
|
$out[] = '# Block PetalBot, misbehaving';
|
|
|
|
$out[] = 'User-agent: PetalBot';
|
2024-06-17 12:40:01 +09:00
|
|
|
$out[] = 'Disallow: /';
|
2024-06-19 15:15:38 +09:00
|
|
|
$out[] = '# Block DotBot';
|
|
|
|
$out[] = 'User-agent: DotBot';
|
2024-06-17 12:40:01 +09:00
|
|
|
$out[] = 'Disallow: /';
|
2024-06-19 15:15:38 +09:00
|
|
|
$out[] = '# Block MegaIndex';
|
|
|
|
$out[] = 'User-agent: MegaIndex';
|
2024-06-17 12:40:01 +09:00
|
|
|
$out[] = 'Disallow: /';
|
2024-06-19 15:15:38 +09:00
|
|
|
$out[] = '# Block SerpstatBot';
|
|
|
|
$out[] = 'User-agent: serpstatbot';
|
2024-06-17 12:40:01 +09:00
|
|
|
$out[] = 'Disallow: /';
|
2024-06-19 15:15:38 +09:00
|
|
|
$out[] = '# Block SeekportBot';
|
|
|
|
$out[] = 'User-agent: SeekportBot';
|
2024-06-17 12:40:01 +09:00
|
|
|
$out[] = 'Disallow: /';
|
2024-06-19 15:15:38 +09:00
|
|
|
$out[] = '# Block SemRushBot';
|
|
|
|
$out[] = 'User-agent: SemrushBot';
|
2024-06-17 12:40:01 +09:00
|
|
|
$out[] = 'Disallow: /';
|
2024-06-19 15:15:38 +09:00
|
|
|
$out[] = '# Block AhrefsBot';
|
|
|
|
$out[] = 'User-agent: AhrefsBot';
|
2024-06-17 12:40:01 +09:00
|
|
|
$out[] = 'Disallow: /';
|
2024-05-11 17:28:38 +09:00
|
|
|
// Crawl-delay entries at the bottom
|
|
|
|
// Ref: https://github.com/otwcode/otwarchive/pull/4411#discussion_r1044351129
|
2024-06-19 15:15:38 +09:00
|
|
|
$out[] = '# Throttle MJ12bot';
|
|
|
|
$out[] = 'User-agent: MJ12bot';
|
|
|
|
$out[] = 'Crawl-delay: 10';
|
|
|
|
$out[] = '# Throttle YandexBot';
|
|
|
|
$out[] = 'User-agent: YandexBot';
|
|
|
|
$out[] = 'Crawl-delay: 5';
|
|
|
|
$out[] = '# Throttle BingBot';
|
|
|
|
$out[] = 'User-agent: bingbot';
|
|
|
|
$out[] = 'Crawl-delay: 5';
|
|
|
|
$out[] = '# Throttle all other bots';
|
2024-05-11 17:28:38 +09:00
|
|
|
$out[] = 'User-agent: *';
|
2024-06-19 15:15:38 +09:00
|
|
|
$out[] = 'Crawl-delay: 5';
|
2024-04-15 19:14:13 +09:00
|
|
|
|
2024-05-11 17:28:38 +09:00
|
|
|
$content = implode("\n", $out)."\n";
|
2024-04-15 19:14:13 +09:00
|
|
|
|
2024-05-11 17:28:38 +09:00
|
|
|
return id(new AphrontPlainTextResponse())
|
|
|
|
->setContent($content)
|
|
|
|
->setCacheDurationInSeconds(phutil_units('2 hours in seconds'))
|
2024-06-19 15:15:38 +09:00
|
|
|
// ->setClientIDCookie(false) (Doesn't work /shrug)
|
2024-05-11 17:28:38 +09:00
|
|
|
->setCanCDN(true)
|
2024-06-21 16:02:42 +09:00
|
|
|
->setLastModified(1718953501);
|
2024-05-02 19:25:47 +09:00
|
|
|
}
|
|
|
|
}
|