YGGo/library/robots.php

85 lines
1.6 KiB
PHP
Raw Normal View History

2023-04-03 21:27:32 +00:00
<?php
2023-04-03 22:38:32 +00:00
// @TODO #2
2023-04-03 21:27:32 +00:00
class Robots {
2023-04-03 22:38:32 +00:00
private $_rule = [];
2023-04-03 21:27:32 +00:00
public function __construct(string $data) {
$read = false;
foreach ((array) explode(PHP_EOL, $data) as $row) {
$row = strtolower(trim($row));
// User-agent * begin
if (preg_match('!^user-agent:\s?\*!', $row)) {
$read = true;
continue;
}
if ($read) {
$part = explode(' ', $row);
if (isset($part[0]) && isset($part[1])) {
if (false !== strpos($part[0], 'allow')) {
2023-04-03 22:38:32 +00:00
$this->_rule[$this->_regex(trim($part[1]))] = true;
2023-04-03 21:27:32 +00:00
}
if (false !== strpos($part[0], 'disallow')) {
2023-04-03 22:38:32 +00:00
$this->_rule[$this->_regex(trim($part[1]))] = false;
2023-04-03 21:27:32 +00:00
}
}
}
// User-agent * end
if ($read && preg_match('!^user-agent:!', $row)) {
break;
}
}
}
public function indexURL(string $url) {
// Unify case match
$url = strtolower(trim($url));
// Convert to URI
$url = str_replace(parse_url($url, PHP_URL_SCHEME) . '://' .
parse_url($url, PHP_URL_HOST) .
parse_url($url, PHP_URL_PORT),
'', $url);
// Index by default
$result = true;
// Begin index rules by ASC priority
2023-04-03 22:38:32 +00:00
foreach ($this->_rule as $rule => $value) {
2023-04-03 21:27:32 +00:00
if (preg_match('!^' . $rule . '!', $url)) {
2023-04-03 22:38:32 +00:00
$result = $value;
2023-04-03 21:27:32 +00:00
}
}
return $result;
}
private function _regex(string $string) {
return str_replace(
[
'*',
'?'
],
[
'.*',
'\?'
],
$string
);
}
}