/
RobotsManager.php
128 lines (115 loc) · 2.42 KB
/
RobotsManager.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<?php
namespace DJStarCOM\RobotsManager;
/**
* Class RobotsManager
* @package DJStarCOM\RobotsManager
*/
class RobotsManager
{
/**
* The lines for the robots.txt.
*
* @var array
*/
protected $lines = [];
/**
* Generate the robots.txt data.
*
* @return string|null
*/
public function generate(): ?string
{
return implode(PHP_EOL, $this->lines);
}
/**
* Add a Sitemap to the robots.txt.
*
* @param string $sitemap
*/
public function addSitemap(string $sitemap): void
{
$this->addLine('Sitemap: ' . $sitemap);
}
/**
* Add a line to the robots.txt.
*
* @param string $line
*/
protected function addLine(string $line): void
{
$this->lines[] = $line;
}
/**
* Add a User-agent to the robots.txt.
*
* @param string $userAgent
*/
public function addUserAgent(string $userAgent): void
{
$this->addLine('User-agent: ' . $userAgent);
}
/**
* Add a Host to the robots.txt.
*
* @param string $host
*/
public function addHost(string $host): void
{
$this->addLine('Host: ' . $host);
}
/**
* Add a disallow rule to the robots.txt.
*
* @param string|array $directories
*/
public function addDisallow($directories): void
{
$this->addRuleLine($directories, 'Disallow');
}
/**
* Add a rule to the robots.txt.
*
* @param string|array $directories
* @param string $rule
*/
protected function addRuleLine($directories, string $rule): void
{
foreach ((array)$directories as $directory) {
$this->addLine($rule . ': ' . $directory);
}
}
/**
* Add a allow rule to the robots.txt.
*
* @param string|array $directories
*/
public function addAllow($directories): void
{
$this->addRuleLine($directories, 'Allow');
}
/**
* Add a comment to the robots.txt.
*
* @param string $comment
*/
public function addComment(string $comment): void
{
$this->addLine('# ' . $comment);
}
/**
* Add a spacer to the robots.txt.
*/
public function addSpacer(): void
{
$this->addLine('');
}
/**
* Reset the lines.
*
* @return void
*/
public function reset(): void
{
$this->lines = [];
}
}