@@ -169,7 +169,7 @@ discard block |
||
| 169 | 169 | if (!empty($this->encryption)) { |
| 170 | 170 | if ($this->comments) |
| 171 | 171 | $this->addSpacer() |
| 172 | - ->addComment('Our PGP key'); |
|
| 172 | + ->addComment('Our PGP key'); |
|
| 173 | 173 | |
| 174 | 174 | $this->addLine('Encryption: ' . trim($this->encryption)); |
| 175 | 175 | } |
@@ -177,7 +177,7 @@ discard block |
||
| 177 | 177 | if (!empty($this->disclosure)) { |
| 178 | 178 | if ($this->comments) |
| 179 | 179 | $this->addSpacer() |
| 180 | - ->addComment('Our disclosure policy'); |
|
| 180 | + ->addComment('Our disclosure policy'); |
|
| 181 | 181 | |
| 182 | 182 | $this->addLine('Disclosure: ' . trim(ucfirst($this->disclosure))); |
| 183 | 183 | } |
@@ -185,20 +185,20 @@ discard block |
||
| 185 | 185 | if (!empty($this->acknowledgement)) { |
| 186 | 186 | if ($this->comments) |
| 187 | 187 | $this->addSpacer() |
| 188 | - ->addComment('Our public acknowledgement'); |
|
| 188 | + ->addComment('Our public acknowledgement'); |
|
| 189 | 189 | |
| 190 | 190 | $this->addLine('Acknowledgement: ' . trim($this->acknowledgement)); |
| 191 | 191 | } |
| 192 | 192 | |
| 193 | 193 | if ($this->debug) |
| 194 | 194 | $this->addSpacer() |
| 195 | - ->addComment() |
|
| 196 | - ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
|
| 197 | - ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
|
| 198 | - ->addComment() |
|
| 199 | - ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
|
| 200 | - ->addComment() |
|
| 201 | - ->addSpacer(); |
|
| 195 | + ->addComment() |
|
| 196 | + ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
|
| 197 | + ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
|
| 198 | + ->addComment() |
|
| 199 | + ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
|
| 200 | + ->addComment() |
|
| 201 | + ->addSpacer(); |
|
| 202 | 202 | |
| 203 | 203 | $output = implode(PHP_EOL, $this->lines); |
| 204 | 204 | |
@@ -7,7 +7,7 @@ discard block |
||
| 7 | 7 | * @version v0.3.0 |
| 8 | 8 | */ |
| 9 | 9 | |
| 10 | -declare(strict_types=1); |
|
| 10 | +declare(strict_types = 1); |
|
| 11 | 11 | |
| 12 | 12 | namespace AustinHeap\Security\Txt; |
| 13 | 13 | |
@@ -26,84 +26,84 @@ discard block |
||
| 26 | 26 | * |
| 27 | 27 | * @var array |
| 28 | 28 | */ |
| 29 | - protected $lines = []; |
|
| 29 | + protected $lines = []; |
|
| 30 | 30 | |
| 31 | 31 | /** |
| 32 | 32 | * Internal text cache. |
| 33 | 33 | * |
| 34 | 34 | * @var string |
| 35 | 35 | */ |
| 36 | - protected $text = null; |
|
| 36 | + protected $text = null; |
|
| 37 | 37 | |
| 38 | 38 | /** |
| 39 | 39 | * Enable SecurityTxt. |
| 40 | 40 | * |
| 41 | 41 | * @var bool |
| 42 | 42 | */ |
| 43 | - protected $enabled = false; |
|
| 43 | + protected $enabled = false; |
|
| 44 | 44 | |
| 45 | 45 | /** |
| 46 | 46 | * Enable debug output. |
| 47 | 47 | * |
| 48 | 48 | * @var bool |
| 49 | 49 | */ |
| 50 | - protected $debug = false; |
|
| 50 | + protected $debug = false; |
|
| 51 | 51 | |
| 52 | 52 | /** |
| 53 | 53 | * Enable built-in cache. |
| 54 | 54 | * |
| 55 | 55 | * @var bool |
| 56 | 56 | */ |
| 57 | - protected $cache = false; |
|
| 57 | + protected $cache = false; |
|
| 58 | 58 | |
| 59 | 59 | /** |
| 60 | 60 | * Minutes to cache output. |
| 61 | 61 | * |
| 62 | 62 | * @var int |
| 63 | 63 | */ |
| 64 | - protected $cacheTime = null; |
|
| 64 | + protected $cacheTime = null; |
|
| 65 | 65 | |
| 66 | 66 | /** |
| 67 | 67 | * Cache key to use. |
| 68 | 68 | * |
| 69 | 69 | * @var string |
| 70 | 70 | */ |
| 71 | - protected $cacheKey = 'cache:AustinHeap\Security\Txt\SecurityTxt'; |
|
| 71 | + protected $cacheKey = 'cache:AustinHeap\Security\Txt\SecurityTxt'; |
|
| 72 | 72 | |
| 73 | 73 | /** |
| 74 | 74 | * Enable built-in comments. |
| 75 | 75 | * |
| 76 | 76 | * @var bool |
| 77 | 77 | */ |
| 78 | - protected $comments = true; |
|
| 78 | + protected $comments = true; |
|
| 79 | 79 | |
| 80 | 80 | /** |
| 81 | 81 | * The security contacts to list. |
| 82 | 82 | * |
| 83 | 83 | * @var array |
| 84 | 84 | */ |
| 85 | - protected $contacts = []; |
|
| 85 | + protected $contacts = []; |
|
| 86 | 86 | |
| 87 | 87 | /** |
| 88 | 88 | * The PGP key file URL. |
| 89 | 89 | * |
| 90 | 90 | * @var string |
| 91 | 91 | */ |
| 92 | - protected $encryption = null; |
|
| 92 | + protected $encryption = null; |
|
| 93 | 93 | |
| 94 | 94 | /** |
| 95 | 95 | * The disclosure policy. |
| 96 | 96 | * |
| 97 | 97 | * @var string |
| 98 | 98 | */ |
| 99 | - protected $disclosure = null; |
|
| 99 | + protected $disclosure = null; |
|
| 100 | 100 | |
| 101 | 101 | /** |
| 102 | 102 | * The acknowledgement URL. |
| 103 | 103 | * |
| 104 | 104 | * @var string |
| 105 | 105 | */ |
| 106 | - protected $acknowledgement = null; |
|
| 106 | + protected $acknowledgement = null; |
|
| 107 | 107 | |
| 108 | 108 | /** |
| 109 | 109 | * Create a new SecurityTxt instance. |
@@ -113,16 +113,16 @@ discard block |
||
| 113 | 113 | public function __construct() |
| 114 | 114 | { |
| 115 | 115 | $keys = [ |
| 116 | - 'security-txt.enabled' => ['validator' => 'is_bool', 'setter' => 'setEnabled'], |
|
| 117 | - 'security-txt.debug' => ['validator' => 'is_bool', 'setter' => 'setDebug'], |
|
| 118 | - 'security-txt.cache' => ['validator' => 'is_bool', 'setter' => 'setCache'], |
|
| 119 | - 'security-txt.cache-time' => ['validator' => 'is_numeric', 'setter' => 'setCacheTime'], |
|
| 120 | - 'security-txt.cache-key' => ['validator' => 'is_string', 'setter' => 'setCacheKey'], |
|
| 121 | - 'security-txt.comments' => ['validator' => 'is_bool', 'setter' => 'setComments'], |
|
| 122 | - 'security-txt.contacts' => ['validator' => 'is_array', 'setter' => 'setContacts'], |
|
| 123 | - 'security-txt.encryption' => ['validator' => 'is_string', 'setter' => 'setEncryption'], |
|
| 124 | - 'security-txt.disclosure' => ['validator' => 'is_string', 'setter' => 'setDisclosure'], |
|
| 125 | - 'security-txt.acknowledgement' => ['validator' => 'is_string', 'setter' => 'setAcknowledgement'], |
|
| 116 | + 'security-txt.enabled' => ['validator' => 'is_bool', 'setter' => 'setEnabled'], |
|
| 117 | + 'security-txt.debug' => ['validator' => 'is_bool', 'setter' => 'setDebug'], |
|
| 118 | + 'security-txt.cache' => ['validator' => 'is_bool', 'setter' => 'setCache'], |
|
| 119 | + 'security-txt.cache-time' => ['validator' => 'is_numeric', 'setter' => 'setCacheTime'], |
|
| 120 | + 'security-txt.cache-key' => ['validator' => 'is_string', 'setter' => 'setCacheKey'], |
|
| 121 | + 'security-txt.comments' => ['validator' => 'is_bool', 'setter' => 'setComments'], |
|
| 122 | + 'security-txt.contacts' => ['validator' => 'is_array', 'setter' => 'setContacts'], |
|
| 123 | + 'security-txt.encryption' => ['validator' => 'is_string', 'setter' => 'setEncryption'], |
|
| 124 | + 'security-txt.disclosure' => ['validator' => 'is_string', 'setter' => 'setDisclosure'], |
|
| 125 | + 'security-txt.acknowledgement' => ['validator' => 'is_string', 'setter' => 'setAcknowledgement'], |
|
| 126 | 126 | ]; |
| 127 | 127 | |
| 128 | 128 | foreach ($keys as $key => $mapping) |
@@ -164,14 +164,14 @@ discard block |
||
| 164 | 164 | throw new \Exception('One (or more) contacts must be defined.'); |
| 165 | 165 | |
| 166 | 166 | foreach ($this->contacts as $contact) |
| 167 | - $this->addLine('Contact: ' . trim($contact)); |
|
| 167 | + $this->addLine('Contact: '.trim($contact)); |
|
| 168 | 168 | |
| 169 | 169 | if (!empty($this->encryption)) { |
| 170 | 170 | if ($this->comments) |
| 171 | 171 | $this->addSpacer() |
| 172 | 172 | ->addComment('Our PGP key'); |
| 173 | 173 | |
| 174 | - $this->addLine('Encryption: ' . trim($this->encryption)); |
|
| 174 | + $this->addLine('Encryption: '.trim($this->encryption)); |
|
| 175 | 175 | } |
| 176 | 176 | |
| 177 | 177 | if (!empty($this->disclosure)) { |
@@ -179,7 +179,7 @@ discard block |
||
| 179 | 179 | $this->addSpacer() |
| 180 | 180 | ->addComment('Our disclosure policy'); |
| 181 | 181 | |
| 182 | - $this->addLine('Disclosure: ' . trim(ucfirst($this->disclosure))); |
|
| 182 | + $this->addLine('Disclosure: '.trim(ucfirst($this->disclosure))); |
|
| 183 | 183 | } |
| 184 | 184 | |
| 185 | 185 | if (!empty($this->acknowledgement)) { |
@@ -187,16 +187,16 @@ discard block |
||
| 187 | 187 | $this->addSpacer() |
| 188 | 188 | ->addComment('Our public acknowledgement'); |
| 189 | 189 | |
| 190 | - $this->addLine('Acknowledgement: ' . trim($this->acknowledgement)); |
|
| 190 | + $this->addLine('Acknowledgement: '.trim($this->acknowledgement)); |
|
| 191 | 191 | } |
| 192 | 192 | |
| 193 | 193 | if ($this->debug) |
| 194 | 194 | $this->addSpacer() |
| 195 | 195 | ->addComment() |
| 196 | 196 | ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
| 197 | - ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
|
| 197 | + ->addComment('in '.round((microtime(true) - $time) * 1000, 6).' seconds on '.now().'.') |
|
| 198 | 198 | ->addComment() |
| 199 | - ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
|
| 199 | + ->addComment('Cache is '.($this->cache ? 'enabled with key "'.$this->cacheKey.'"' : 'disabled').'.') |
|
| 200 | 200 | ->addComment() |
| 201 | 201 | ->addSpacer(); |
| 202 | 202 | |
@@ -619,9 +619,9 @@ discard block |
||
| 619 | 619 | $comment = trim($comment); |
| 620 | 620 | |
| 621 | 621 | if (!empty($comment)) |
| 622 | - $comment = ' ' . $comment; |
|
| 622 | + $comment = ' '.$comment; |
|
| 623 | 623 | |
| 624 | - return $this->addLine('#' . $comment); |
|
| 624 | + return $this->addLine('#'.$comment); |
|
| 625 | 625 | } |
| 626 | 626 | |
| 627 | 627 | /** |
@@ -125,10 +125,11 @@ discard block |
||
| 125 | 125 | 'security-txt.acknowledgement' => ['validator' => 'is_string', 'setter' => 'setAcknowledgement'], |
| 126 | 126 | ]; |
| 127 | 127 | |
| 128 | - foreach ($keys as $key => $mapping) |
|
| 129 | - if (config($key, null) !== null && |
|
| 128 | + foreach ($keys as $key => $mapping) { |
|
| 129 | + if (config($key, null) !== null && |
|
| 130 | 130 | $mapping['validator'](config($key))) |
| 131 | 131 | $this->{$mapping['setter']}(config($key)); |
| 132 | + } |
|
| 132 | 133 | |
| 133 | 134 | return $this; |
| 134 | 135 | } |
@@ -145,53 +146,62 @@ discard block |
||
| 145 | 146 | $output = cache($this->cacheKey, null); |
| 146 | 147 | |
| 147 | 148 | if (!is_null($output) && |
| 148 | - is_string($output)) |
|
| 149 | - return $this->setText($output); |
|
| 149 | + is_string($output)) { |
|
| 150 | + return $this->setText($output); |
|
| 151 | + } |
|
| 150 | 152 | |
| 151 | 153 | unset($output); |
| 152 | 154 | } |
| 153 | 155 | |
| 154 | - if ($this->debug) |
|
| 155 | - $time = microtime(true); |
|
| 156 | + if ($this->debug) { |
|
| 157 | + $time = microtime(true); |
|
| 158 | + } |
|
| 156 | 159 | |
| 157 | - if ($reset) |
|
| 158 | - $this->resetLines(); |
|
| 160 | + if ($reset) { |
|
| 161 | + $this->resetLines(); |
|
| 162 | + } |
|
| 159 | 163 | |
| 160 | - if ($this->comments) |
|
| 161 | - $this->addComment('Our security address'); |
|
| 164 | + if ($this->comments) { |
|
| 165 | + $this->addComment('Our security address'); |
|
| 166 | + } |
|
| 162 | 167 | |
| 163 | - if (empty($this->contacts)) |
|
| 164 | - throw new \Exception('One (or more) contacts must be defined.'); |
|
| 168 | + if (empty($this->contacts)) { |
|
| 169 | + throw new \Exception('One (or more) contacts must be defined.'); |
|
| 170 | + } |
|
| 165 | 171 | |
| 166 | - foreach ($this->contacts as $contact) |
|
| 167 | - $this->addLine('Contact: ' . trim($contact)); |
|
| 172 | + foreach ($this->contacts as $contact) { |
|
| 173 | + $this->addLine('Contact: ' . trim($contact)); |
|
| 174 | + } |
|
| 168 | 175 | |
| 169 | 176 | if (!empty($this->encryption)) { |
| 170 | - if ($this->comments) |
|
| 171 | - $this->addSpacer() |
|
| 177 | + if ($this->comments) { |
|
| 178 | + $this->addSpacer() |
|
| 172 | 179 | ->addComment('Our PGP key'); |
| 180 | + } |
|
| 173 | 181 | |
| 174 | 182 | $this->addLine('Encryption: ' . trim($this->encryption)); |
| 175 | 183 | } |
| 176 | 184 | |
| 177 | 185 | if (!empty($this->disclosure)) { |
| 178 | - if ($this->comments) |
|
| 179 | - $this->addSpacer() |
|
| 186 | + if ($this->comments) { |
|
| 187 | + $this->addSpacer() |
|
| 180 | 188 | ->addComment('Our disclosure policy'); |
| 189 | + } |
|
| 181 | 190 | |
| 182 | 191 | $this->addLine('Disclosure: ' . trim(ucfirst($this->disclosure))); |
| 183 | 192 | } |
| 184 | 193 | |
| 185 | 194 | if (!empty($this->acknowledgement)) { |
| 186 | - if ($this->comments) |
|
| 187 | - $this->addSpacer() |
|
| 195 | + if ($this->comments) { |
|
| 196 | + $this->addSpacer() |
|
| 188 | 197 | ->addComment('Our public acknowledgement'); |
| 198 | + } |
|
| 189 | 199 | |
| 190 | 200 | $this->addLine('Acknowledgement: ' . trim($this->acknowledgement)); |
| 191 | 201 | } |
| 192 | 202 | |
| 193 | - if ($this->debug) |
|
| 194 | - $this->addSpacer() |
|
| 203 | + if ($this->debug) { |
|
| 204 | + $this->addSpacer() |
|
| 195 | 205 | ->addComment() |
| 196 | 206 | ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
| 197 | 207 | ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
@@ -199,11 +209,13 @@ discard block |
||
| 199 | 209 | ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
| 200 | 210 | ->addComment() |
| 201 | 211 | ->addSpacer(); |
| 212 | + } |
|
| 202 | 213 | |
| 203 | 214 | $output = implode(PHP_EOL, $this->lines); |
| 204 | 215 | |
| 205 | - if ($this->cache) |
|
| 206 | - cache([$this->cacheKey => $output], now()->addMinutes($this->cacheTime)); |
|
| 216 | + if ($this->cache) { |
|
| 217 | + cache([$this->cacheKey => $output], now()->addMinutes($this->cacheTime)); |
|
| 218 | + } |
|
| 207 | 219 | |
| 208 | 220 | return $this->setText($output); |
| 209 | 221 | } |
@@ -448,8 +460,9 @@ discard block |
||
| 448 | 460 | */ |
| 449 | 461 | public function getText(bool $generate = false, bool $reset = false): string |
| 450 | 462 | { |
| 451 | - if ($generate) |
|
| 452 | - $this->generate($reset); |
|
| 463 | + if ($generate) { |
|
| 464 | + $this->generate($reset); |
|
| 465 | + } |
|
| 453 | 466 | |
| 454 | 467 | return $this->text === null ? '' : $this->text; |
| 455 | 468 | } |
@@ -496,8 +509,9 @@ discard block |
||
| 496 | 509 | */ |
| 497 | 510 | public function addContacts(array $contacts): SecurityTxt |
| 498 | 511 | { |
| 499 | - foreach ($contacts as $contact) |
|
| 500 | - $this->contacts[$contact] = true; |
|
| 512 | + foreach ($contacts as $contact) { |
|
| 513 | + $this->contacts[$contact] = true; |
|
| 514 | + } |
|
| 501 | 515 | |
| 502 | 516 | return $this; |
| 503 | 517 | } |
@@ -523,9 +537,10 @@ discard block |
||
| 523 | 537 | */ |
| 524 | 538 | public function removeContacts(array $contacts): SecurityTxt |
| 525 | 539 | { |
| 526 | - foreach ($contacts as $contact) |
|
| 527 | - if (array_key_exists($contact, $this->contacts)) |
|
| 540 | + foreach ($contacts as $contact) { |
|
| 541 | + if (array_key_exists($contact, $this->contacts)) |
|
| 528 | 542 | unset($this->contacts[$contact]); |
| 543 | + } |
|
| 529 | 544 | |
| 530 | 545 | return $this; |
| 531 | 546 | } |
@@ -538,8 +553,9 @@ discard block |
||
| 538 | 553 | */ |
| 539 | 554 | public function setEncryption(string $encryption): SecurityTxt |
| 540 | 555 | { |
| 541 | - if (filter_var($encryption, FILTER_VALIDATE_URL) === false) |
|
| 542 | - throw new \Exception('Encryption must be a well-formed URL.'); |
|
| 556 | + if (filter_var($encryption, FILTER_VALIDATE_URL) === false) { |
|
| 557 | + throw new \Exception('Encryption must be a well-formed URL.'); |
|
| 558 | + } |
|
| 543 | 559 | |
| 544 | 560 | $this->encryption = $encryption; |
| 545 | 561 | |
@@ -564,8 +580,9 @@ discard block |
||
| 564 | 580 | */ |
| 565 | 581 | public function setDisclosure(string $disclosure): SecurityTxt |
| 566 | 582 | { |
| 567 | - if (!in_array(trim(strtolower($disclosure)), ['full', 'partial', 'none'])) |
|
| 568 | - throw new \Exception('Disclosure policy must be either "full", "partial", or "none".'); |
|
| 583 | + if (!in_array(trim(strtolower($disclosure)), ['full', 'partial', 'none'])) { |
|
| 584 | + throw new \Exception('Disclosure policy must be either "full", "partial", or "none".'); |
|
| 585 | + } |
|
| 569 | 586 | |
| 570 | 587 | $this->disclosure = $disclosure; |
| 571 | 588 | |
@@ -590,8 +607,9 @@ discard block |
||
| 590 | 607 | */ |
| 591 | 608 | public function setAcknowledgement(string $acknowledgement): SecurityTxt |
| 592 | 609 | { |
| 593 | - if (filter_var($acknowledgement, FILTER_VALIDATE_URL) === false) |
|
| 594 | - throw new \Exception('Acknowledgement must be a well-formed URL.'); |
|
| 610 | + if (filter_var($acknowledgement, FILTER_VALIDATE_URL) === false) { |
|
| 611 | + throw new \Exception('Acknowledgement must be a well-formed URL.'); |
|
| 612 | + } |
|
| 595 | 613 | |
| 596 | 614 | $this->acknowledgement = $acknowledgement; |
| 597 | 615 | |
@@ -618,8 +636,9 @@ discard block |
||
| 618 | 636 | { |
| 619 | 637 | $comment = trim($comment); |
| 620 | 638 | |
| 621 | - if (!empty($comment)) |
|
| 622 | - $comment = ' ' . $comment; |
|
| 639 | + if (!empty($comment)) { |
|
| 640 | + $comment = ' ' . $comment; |
|
| 641 | + } |
|
| 623 | 642 | |
| 624 | 643 | return $this->addLine('#' . $comment); |
| 625 | 644 | } |
@@ -169,7 +169,7 @@ discard block |
||
| 169 | 169 | if (!empty($this->encryption)) { |
| 170 | 170 | if ($this->comments) |
| 171 | 171 | $this->addSpacer() |
| 172 | - ->addComment('Our PGP key'); |
|
| 172 | + ->addComment('Our PGP key'); |
|
| 173 | 173 | |
| 174 | 174 | $this->addLine('Encryption: ' . trim($this->encryption)); |
| 175 | 175 | } |
@@ -177,7 +177,7 @@ discard block |
||
| 177 | 177 | if (!empty($this->disclosure)) { |
| 178 | 178 | if ($this->comments) |
| 179 | 179 | $this->addSpacer() |
| 180 | - ->addComment('Our disclosure policy'); |
|
| 180 | + ->addComment('Our disclosure policy'); |
|
| 181 | 181 | |
| 182 | 182 | $this->addLine('Disclosure: ' . trim(ucfirst($this->disclosure))); |
| 183 | 183 | } |
@@ -185,20 +185,20 @@ discard block |
||
| 185 | 185 | if (!empty($this->acknowledgement)) { |
| 186 | 186 | if ($this->comments) |
| 187 | 187 | $this->addSpacer() |
| 188 | - ->addComment('Our public acknowledgement'); |
|
| 188 | + ->addComment('Our public acknowledgement'); |
|
| 189 | 189 | |
| 190 | 190 | $this->addLine('Acknowledgement: ' . trim($this->acknowledgement)); |
| 191 | 191 | } |
| 192 | 192 | |
| 193 | 193 | if ($this->debug) |
| 194 | 194 | $this->addSpacer() |
| 195 | - ->addComment() |
|
| 196 | - ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
|
| 197 | - ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
|
| 198 | - ->addComment() |
|
| 199 | - ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
|
| 200 | - ->addComment() |
|
| 201 | - ->addSpacer(); |
|
| 195 | + ->addComment() |
|
| 196 | + ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
|
| 197 | + ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
|
| 198 | + ->addComment() |
|
| 199 | + ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
|
| 200 | + ->addComment() |
|
| 201 | + ->addSpacer(); |
|
| 202 | 202 | |
| 203 | 203 | $output = implode(PHP_EOL, $this->lines); |
| 204 | 204 | |
@@ -7,7 +7,7 @@ discard block |
||
| 7 | 7 | * @version v0.3.0 |
| 8 | 8 | */ |
| 9 | 9 | |
| 10 | -declare(strict_types=1); |
|
| 10 | +declare(strict_types = 1); |
|
| 11 | 11 | |
| 12 | 12 | namespace AustinHeap\Security\Txt; |
| 13 | 13 | |
@@ -26,84 +26,84 @@ discard block |
||
| 26 | 26 | * |
| 27 | 27 | * @var array |
| 28 | 28 | */ |
| 29 | - protected $lines = []; |
|
| 29 | + protected $lines = []; |
|
| 30 | 30 | |
| 31 | 31 | /** |
| 32 | 32 | * Internal text cache. |
| 33 | 33 | * |
| 34 | 34 | * @var string |
| 35 | 35 | */ |
| 36 | - protected $text = null; |
|
| 36 | + protected $text = null; |
|
| 37 | 37 | |
| 38 | 38 | /** |
| 39 | 39 | * Enable SecurityTxt. |
| 40 | 40 | * |
| 41 | 41 | * @var bool |
| 42 | 42 | */ |
| 43 | - protected $enabled = false; |
|
| 43 | + protected $enabled = false; |
|
| 44 | 44 | |
| 45 | 45 | /** |
| 46 | 46 | * Enable debug output. |
| 47 | 47 | * |
| 48 | 48 | * @var bool |
| 49 | 49 | */ |
| 50 | - protected $debug = false; |
|
| 50 | + protected $debug = false; |
|
| 51 | 51 | |
| 52 | 52 | /** |
| 53 | 53 | * Enable built-in cache. |
| 54 | 54 | * |
| 55 | 55 | * @var bool |
| 56 | 56 | */ |
| 57 | - protected $cache = false; |
|
| 57 | + protected $cache = false; |
|
| 58 | 58 | |
| 59 | 59 | /** |
| 60 | 60 | * Minutes to cache output. |
| 61 | 61 | * |
| 62 | 62 | * @var int |
| 63 | 63 | */ |
| 64 | - protected $cacheTime = null; |
|
| 64 | + protected $cacheTime = null; |
|
| 65 | 65 | |
| 66 | 66 | /** |
| 67 | 67 | * Cache key to use. |
| 68 | 68 | * |
| 69 | 69 | * @var string |
| 70 | 70 | */ |
| 71 | - protected $cacheKey = 'cache:AustinHeap\Security\Txt\SecurityTxt'; |
|
| 71 | + protected $cacheKey = 'cache:AustinHeap\Security\Txt\SecurityTxt'; |
|
| 72 | 72 | |
| 73 | 73 | /** |
| 74 | 74 | * Enable built-in comments. |
| 75 | 75 | * |
| 76 | 76 | * @var bool |
| 77 | 77 | */ |
| 78 | - protected $comments = true; |
|
| 78 | + protected $comments = true; |
|
| 79 | 79 | |
| 80 | 80 | /** |
| 81 | 81 | * The security contacts to list. |
| 82 | 82 | * |
| 83 | 83 | * @var array |
| 84 | 84 | */ |
| 85 | - protected $contacts = []; |
|
| 85 | + protected $contacts = []; |
|
| 86 | 86 | |
| 87 | 87 | /** |
| 88 | 88 | * The PGP key file URL. |
| 89 | 89 | * |
| 90 | 90 | * @var string |
| 91 | 91 | */ |
| 92 | - protected $encryption = null; |
|
| 92 | + protected $encryption = null; |
|
| 93 | 93 | |
| 94 | 94 | /** |
| 95 | 95 | * The disclosure policy. |
| 96 | 96 | * |
| 97 | 97 | * @var string |
| 98 | 98 | */ |
| 99 | - protected $disclosure = null; |
|
| 99 | + protected $disclosure = null; |
|
| 100 | 100 | |
| 101 | 101 | /** |
| 102 | 102 | * The acknowledgement URL. |
| 103 | 103 | * |
| 104 | 104 | * @var string |
| 105 | 105 | */ |
| 106 | - protected $acknowledgement = null; |
|
| 106 | + protected $acknowledgement = null; |
|
| 107 | 107 | |
| 108 | 108 | /** |
| 109 | 109 | * Create a new SecurityTxt instance. |
@@ -113,16 +113,16 @@ discard block |
||
| 113 | 113 | public function __construct() |
| 114 | 114 | { |
| 115 | 115 | $keys = [ |
| 116 | - 'security-txt.enabled' => ['validator' => 'is_bool', 'setter' => 'setEnabled'], |
|
| 117 | - 'security-txt.debug' => ['validator' => 'is_bool', 'setter' => 'setDebug'], |
|
| 118 | - 'security-txt.cache' => ['validator' => 'is_bool', 'setter' => 'setCache'], |
|
| 119 | - 'security-txt.cache-time' => ['validator' => 'is_numeric', 'setter' => 'setCacheTime'], |
|
| 120 | - 'security-txt.cache-key' => ['validator' => 'is_string', 'setter' => 'setCacheKey'], |
|
| 121 | - 'security-txt.comments' => ['validator' => 'is_bool', 'setter' => 'setComments'], |
|
| 122 | - 'security-txt.contacts' => ['validator' => 'is_array', 'setter' => 'setContacts'], |
|
| 123 | - 'security-txt.encryption' => ['validator' => 'is_string', 'setter' => 'setEncryption'], |
|
| 124 | - 'security-txt.disclosure' => ['validator' => 'is_string', 'setter' => 'setDisclosure'], |
|
| 125 | - 'security-txt.acknowledgement' => ['validator' => 'is_string', 'setter' => 'setAcknowledgement'], |
|
| 116 | + 'security-txt.enabled' => ['validator' => 'is_bool', 'setter' => 'setEnabled'], |
|
| 117 | + 'security-txt.debug' => ['validator' => 'is_bool', 'setter' => 'setDebug'], |
|
| 118 | + 'security-txt.cache' => ['validator' => 'is_bool', 'setter' => 'setCache'], |
|
| 119 | + 'security-txt.cache-time' => ['validator' => 'is_numeric', 'setter' => 'setCacheTime'], |
|
| 120 | + 'security-txt.cache-key' => ['validator' => 'is_string', 'setter' => 'setCacheKey'], |
|
| 121 | + 'security-txt.comments' => ['validator' => 'is_bool', 'setter' => 'setComments'], |
|
| 122 | + 'security-txt.contacts' => ['validator' => 'is_array', 'setter' => 'setContacts'], |
|
| 123 | + 'security-txt.encryption' => ['validator' => 'is_string', 'setter' => 'setEncryption'], |
|
| 124 | + 'security-txt.disclosure' => ['validator' => 'is_string', 'setter' => 'setDisclosure'], |
|
| 125 | + 'security-txt.acknowledgement' => ['validator' => 'is_string', 'setter' => 'setAcknowledgement'], |
|
| 126 | 126 | ]; |
| 127 | 127 | |
| 128 | 128 | foreach ($keys as $key => $mapping) |
@@ -164,14 +164,14 @@ discard block |
||
| 164 | 164 | throw new \Exception('One (or more) contacts must be defined.'); |
| 165 | 165 | |
| 166 | 166 | foreach ($this->contacts as $contact) |
| 167 | - $this->addLine('Contact: ' . trim($contact)); |
|
| 167 | + $this->addLine('Contact: '.trim($contact)); |
|
| 168 | 168 | |
| 169 | 169 | if (!empty($this->encryption)) { |
| 170 | 170 | if ($this->comments) |
| 171 | 171 | $this->addSpacer() |
| 172 | 172 | ->addComment('Our PGP key'); |
| 173 | 173 | |
| 174 | - $this->addLine('Encryption: ' . trim($this->encryption)); |
|
| 174 | + $this->addLine('Encryption: '.trim($this->encryption)); |
|
| 175 | 175 | } |
| 176 | 176 | |
| 177 | 177 | if (!empty($this->disclosure)) { |
@@ -179,7 +179,7 @@ discard block |
||
| 179 | 179 | $this->addSpacer() |
| 180 | 180 | ->addComment('Our disclosure policy'); |
| 181 | 181 | |
| 182 | - $this->addLine('Disclosure: ' . trim(ucfirst($this->disclosure))); |
|
| 182 | + $this->addLine('Disclosure: '.trim(ucfirst($this->disclosure))); |
|
| 183 | 183 | } |
| 184 | 184 | |
| 185 | 185 | if (!empty($this->acknowledgement)) { |
@@ -187,16 +187,16 @@ discard block |
||
| 187 | 187 | $this->addSpacer() |
| 188 | 188 | ->addComment('Our public acknowledgement'); |
| 189 | 189 | |
| 190 | - $this->addLine('Acknowledgement: ' . trim($this->acknowledgement)); |
|
| 190 | + $this->addLine('Acknowledgement: '.trim($this->acknowledgement)); |
|
| 191 | 191 | } |
| 192 | 192 | |
| 193 | 193 | if ($this->debug) |
| 194 | 194 | $this->addSpacer() |
| 195 | 195 | ->addComment() |
| 196 | 196 | ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
| 197 | - ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
|
| 197 | + ->addComment('in '.round((microtime(true) - $time) * 1000, 6).' seconds on '.now().'.') |
|
| 198 | 198 | ->addComment() |
| 199 | - ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
|
| 199 | + ->addComment('Cache is '.($this->cache ? 'enabled with key "'.$this->cacheKey.'"' : 'disabled').'.') |
|
| 200 | 200 | ->addComment() |
| 201 | 201 | ->addSpacer(); |
| 202 | 202 | |
@@ -619,9 +619,9 @@ discard block |
||
| 619 | 619 | $comment = trim($comment); |
| 620 | 620 | |
| 621 | 621 | if (!empty($comment)) |
| 622 | - $comment = ' ' . $comment; |
|
| 622 | + $comment = ' '.$comment; |
|
| 623 | 623 | |
| 624 | - return $this->addLine('#' . $comment); |
|
| 624 | + return $this->addLine('#'.$comment); |
|
| 625 | 625 | } |
| 626 | 626 | |
| 627 | 627 | /** |
@@ -125,10 +125,11 @@ discard block |
||
| 125 | 125 | 'security-txt.acknowledgement' => ['validator' => 'is_string', 'setter' => 'setAcknowledgement'], |
| 126 | 126 | ]; |
| 127 | 127 | |
| 128 | - foreach ($keys as $key => $mapping) |
|
| 129 | - if (config($key, null) !== null && |
|
| 128 | + foreach ($keys as $key => $mapping) { |
|
| 129 | + if (config($key, null) !== null && |
|
| 130 | 130 | $mapping['validator'](config($key))) |
| 131 | 131 | $this->{$mapping['setter']}(config($key)); |
| 132 | + } |
|
| 132 | 133 | |
| 133 | 134 | return $this; |
| 134 | 135 | } |
@@ -145,53 +146,62 @@ discard block |
||
| 145 | 146 | $output = cache($this->cacheKey, null); |
| 146 | 147 | |
| 147 | 148 | if (!is_null($output) && |
| 148 | - is_string($output)) |
|
| 149 | - return $this->setText($output); |
|
| 149 | + is_string($output)) { |
|
| 150 | + return $this->setText($output); |
|
| 151 | + } |
|
| 150 | 152 | |
| 151 | 153 | unset($output); |
| 152 | 154 | } |
| 153 | 155 | |
| 154 | - if ($this->debug) |
|
| 155 | - $time = microtime(true); |
|
| 156 | + if ($this->debug) { |
|
| 157 | + $time = microtime(true); |
|
| 158 | + } |
|
| 156 | 159 | |
| 157 | - if ($reset) |
|
| 158 | - $this->resetLines(); |
|
| 160 | + if ($reset) { |
|
| 161 | + $this->resetLines(); |
|
| 162 | + } |
|
| 159 | 163 | |
| 160 | - if ($this->comments) |
|
| 161 | - $this->addComment('Our security address'); |
|
| 164 | + if ($this->comments) { |
|
| 165 | + $this->addComment('Our security address'); |
|
| 166 | + } |
|
| 162 | 167 | |
| 163 | - if (empty($this->contacts)) |
|
| 164 | - throw new \Exception('One (or more) contacts must be defined.'); |
|
| 168 | + if (empty($this->contacts)) { |
|
| 169 | + throw new \Exception('One (or more) contacts must be defined.'); |
|
| 170 | + } |
|
| 165 | 171 | |
| 166 | - foreach ($this->contacts as $contact) |
|
| 167 | - $this->addLine('Contact: ' . trim($contact)); |
|
| 172 | + foreach ($this->contacts as $contact) { |
|
| 173 | + $this->addLine('Contact: ' . trim($contact)); |
|
| 174 | + } |
|
| 168 | 175 | |
| 169 | 176 | if (!empty($this->encryption)) { |
| 170 | - if ($this->comments) |
|
| 171 | - $this->addSpacer() |
|
| 177 | + if ($this->comments) { |
|
| 178 | + $this->addSpacer() |
|
| 172 | 179 | ->addComment('Our PGP key'); |
| 180 | + } |
|
| 173 | 181 | |
| 174 | 182 | $this->addLine('Encryption: ' . trim($this->encryption)); |
| 175 | 183 | } |
| 176 | 184 | |
| 177 | 185 | if (!empty($this->disclosure)) { |
| 178 | - if ($this->comments) |
|
| 179 | - $this->addSpacer() |
|
| 186 | + if ($this->comments) { |
|
| 187 | + $this->addSpacer() |
|
| 180 | 188 | ->addComment('Our disclosure policy'); |
| 189 | + } |
|
| 181 | 190 | |
| 182 | 191 | $this->addLine('Disclosure: ' . trim(ucfirst($this->disclosure))); |
| 183 | 192 | } |
| 184 | 193 | |
| 185 | 194 | if (!empty($this->acknowledgement)) { |
| 186 | - if ($this->comments) |
|
| 187 | - $this->addSpacer() |
|
| 195 | + if ($this->comments) { |
|
| 196 | + $this->addSpacer() |
|
| 188 | 197 | ->addComment('Our public acknowledgement'); |
| 198 | + } |
|
| 189 | 199 | |
| 190 | 200 | $this->addLine('Acknowledgement: ' . trim($this->acknowledgement)); |
| 191 | 201 | } |
| 192 | 202 | |
| 193 | - if ($this->debug) |
|
| 194 | - $this->addSpacer() |
|
| 203 | + if ($this->debug) { |
|
| 204 | + $this->addSpacer() |
|
| 195 | 205 | ->addComment() |
| 196 | 206 | ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
| 197 | 207 | ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
@@ -199,11 +209,13 @@ discard block |
||
| 199 | 209 | ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
| 200 | 210 | ->addComment() |
| 201 | 211 | ->addSpacer(); |
| 212 | + } |
|
| 202 | 213 | |
| 203 | 214 | $output = implode(PHP_EOL, $this->lines); |
| 204 | 215 | |
| 205 | - if ($this->cache) |
|
| 206 | - cache([$this->cacheKey => $output], now()->addMinutes($this->cacheTime)); |
|
| 216 | + if ($this->cache) { |
|
| 217 | + cache([$this->cacheKey => $output], now()->addMinutes($this->cacheTime)); |
|
| 218 | + } |
|
| 207 | 219 | |
| 208 | 220 | return $this->setText($output); |
| 209 | 221 | } |
@@ -448,8 +460,9 @@ discard block |
||
| 448 | 460 | */ |
| 449 | 461 | public function getText(bool $generate = false, bool $reset = false): string |
| 450 | 462 | { |
| 451 | - if ($generate) |
|
| 452 | - $this->generate($reset); |
|
| 463 | + if ($generate) { |
|
| 464 | + $this->generate($reset); |
|
| 465 | + } |
|
| 453 | 466 | |
| 454 | 467 | return $this->text === null ? '' : $this->text; |
| 455 | 468 | } |
@@ -496,8 +509,9 @@ discard block |
||
| 496 | 509 | */ |
| 497 | 510 | public function addContacts(array $contacts): SecurityTxt |
| 498 | 511 | { |
| 499 | - foreach ($contacts as $contact) |
|
| 500 | - $this->contacts[$contact] = true; |
|
| 512 | + foreach ($contacts as $contact) { |
|
| 513 | + $this->contacts[$contact] = true; |
|
| 514 | + } |
|
| 501 | 515 | |
| 502 | 516 | return $this; |
| 503 | 517 | } |
@@ -523,9 +537,10 @@ discard block |
||
| 523 | 537 | */ |
| 524 | 538 | public function removeContacts(array $contacts): SecurityTxt |
| 525 | 539 | { |
| 526 | - foreach ($contacts as $contact) |
|
| 527 | - if (array_key_exists($contact, $this->contacts)) |
|
| 540 | + foreach ($contacts as $contact) { |
|
| 541 | + if (array_key_exists($contact, $this->contacts)) |
|
| 528 | 542 | unset($this->contacts[$contact]); |
| 543 | + } |
|
| 529 | 544 | |
| 530 | 545 | return $this; |
| 531 | 546 | } |
@@ -538,8 +553,9 @@ discard block |
||
| 538 | 553 | */ |
| 539 | 554 | public function setEncryption(string $encryption): SecurityTxt |
| 540 | 555 | { |
| 541 | - if (filter_var($encryption, FILTER_VALIDATE_URL) === false) |
|
| 542 | - throw new \Exception('Encryption must be a well-formed URL.'); |
|
| 556 | + if (filter_var($encryption, FILTER_VALIDATE_URL) === false) { |
|
| 557 | + throw new \Exception('Encryption must be a well-formed URL.'); |
|
| 558 | + } |
|
| 543 | 559 | |
| 544 | 560 | $this->encryption = $encryption; |
| 545 | 561 | |
@@ -564,8 +580,9 @@ discard block |
||
| 564 | 580 | */ |
| 565 | 581 | public function setDisclosure(string $disclosure): SecurityTxt |
| 566 | 582 | { |
| 567 | - if (!in_array(trim(strtolower($disclosure)), ['full', 'partial', 'none'])) |
|
| 568 | - throw new \Exception('Disclosure policy must be either "full", "partial", or "none".'); |
|
| 583 | + if (!in_array(trim(strtolower($disclosure)), ['full', 'partial', 'none'])) { |
|
| 584 | + throw new \Exception('Disclosure policy must be either "full", "partial", or "none".'); |
|
| 585 | + } |
|
| 569 | 586 | |
| 570 | 587 | $this->disclosure = $disclosure; |
| 571 | 588 | |
@@ -590,8 +607,9 @@ discard block |
||
| 590 | 607 | */ |
| 591 | 608 | public function setAcknowledgement(string $acknowledgement): SecurityTxt |
| 592 | 609 | { |
| 593 | - if (filter_var($acknowledgement, FILTER_VALIDATE_URL) === false) |
|
| 594 | - throw new \Exception('Acknowledgement must be a well-formed URL.'); |
|
| 610 | + if (filter_var($acknowledgement, FILTER_VALIDATE_URL) === false) { |
|
| 611 | + throw new \Exception('Acknowledgement must be a well-formed URL.'); |
|
| 612 | + } |
|
| 595 | 613 | |
| 596 | 614 | $this->acknowledgement = $acknowledgement; |
| 597 | 615 | |
@@ -618,8 +636,9 @@ discard block |
||
| 618 | 636 | { |
| 619 | 637 | $comment = trim($comment); |
| 620 | 638 | |
| 621 | - if (!empty($comment)) |
|
| 622 | - $comment = ' ' . $comment; |
|
| 639 | + if (!empty($comment)) { |
|
| 640 | + $comment = ' ' . $comment; |
|
| 641 | + } |
|
| 623 | 642 | |
| 624 | 643 | return $this->addLine('#' . $comment); |
| 625 | 644 | } |
@@ -169,7 +169,7 @@ discard block |
||
| 169 | 169 | if (!empty($this->encryption)) { |
| 170 | 170 | if ($this->comments) |
| 171 | 171 | $this->addSpacer() |
| 172 | - ->addComment('Our PGP key'); |
|
| 172 | + ->addComment('Our PGP key'); |
|
| 173 | 173 | |
| 174 | 174 | $this->addLine('Encryption: ' . trim($this->encryption)); |
| 175 | 175 | } |
@@ -177,7 +177,7 @@ discard block |
||
| 177 | 177 | if (!empty($this->disclosure)) { |
| 178 | 178 | if ($this->comments) |
| 179 | 179 | $this->addSpacer() |
| 180 | - ->addComment('Our disclosure policy'); |
|
| 180 | + ->addComment('Our disclosure policy'); |
|
| 181 | 181 | |
| 182 | 182 | $this->addLine('Disclosure: ' . trim(ucfirst($this->disclosure))); |
| 183 | 183 | } |
@@ -185,20 +185,20 @@ discard block |
||
| 185 | 185 | if (!empty($this->acknowledgement)) { |
| 186 | 186 | if ($this->comments) |
| 187 | 187 | $this->addSpacer() |
| 188 | - ->addComment('Our public acknowledgement'); |
|
| 188 | + ->addComment('Our public acknowledgement'); |
|
| 189 | 189 | |
| 190 | 190 | $this->addLine('Acknowledgement: ' . trim($this->acknowledgement)); |
| 191 | 191 | } |
| 192 | 192 | |
| 193 | 193 | if ($this->debug) |
| 194 | 194 | $this->addSpacer() |
| 195 | - ->addComment() |
|
| 196 | - ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
|
| 197 | - ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
|
| 198 | - ->addComment() |
|
| 199 | - ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
|
| 200 | - ->addComment() |
|
| 201 | - ->addSpacer(); |
|
| 195 | + ->addComment() |
|
| 196 | + ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
|
| 197 | + ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
|
| 198 | + ->addComment() |
|
| 199 | + ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
|
| 200 | + ->addComment() |
|
| 201 | + ->addSpacer(); |
|
| 202 | 202 | |
| 203 | 203 | $output = implode(PHP_EOL, $this->lines); |
| 204 | 204 | |
@@ -7,7 +7,7 @@ discard block |
||
| 7 | 7 | * @version v0.3.0 |
| 8 | 8 | */ |
| 9 | 9 | |
| 10 | -declare(strict_types=1); |
|
| 10 | +declare(strict_types = 1); |
|
| 11 | 11 | |
| 12 | 12 | namespace AustinHeap\Security\Txt; |
| 13 | 13 | |
@@ -26,84 +26,84 @@ discard block |
||
| 26 | 26 | * |
| 27 | 27 | * @var array |
| 28 | 28 | */ |
| 29 | - protected $lines = []; |
|
| 29 | + protected $lines = []; |
|
| 30 | 30 | |
| 31 | 31 | /** |
| 32 | 32 | * Internal text cache. |
| 33 | 33 | * |
| 34 | 34 | * @var string |
| 35 | 35 | */ |
| 36 | - protected $text = null; |
|
| 36 | + protected $text = null; |
|
| 37 | 37 | |
| 38 | 38 | /** |
| 39 | 39 | * Enable SecurityTxt. |
| 40 | 40 | * |
| 41 | 41 | * @var bool |
| 42 | 42 | */ |
| 43 | - protected $enabled = false; |
|
| 43 | + protected $enabled = false; |
|
| 44 | 44 | |
| 45 | 45 | /** |
| 46 | 46 | * Enable debug output. |
| 47 | 47 | * |
| 48 | 48 | * @var bool |
| 49 | 49 | */ |
| 50 | - protected $debug = false; |
|
| 50 | + protected $debug = false; |
|
| 51 | 51 | |
| 52 | 52 | /** |
| 53 | 53 | * Enable built-in cache. |
| 54 | 54 | * |
| 55 | 55 | * @var bool |
| 56 | 56 | */ |
| 57 | - protected $cache = false; |
|
| 57 | + protected $cache = false; |
|
| 58 | 58 | |
| 59 | 59 | /** |
| 60 | 60 | * Minutes to cache output. |
| 61 | 61 | * |
| 62 | 62 | * @var int |
| 63 | 63 | */ |
| 64 | - protected $cacheTime = null; |
|
| 64 | + protected $cacheTime = null; |
|
| 65 | 65 | |
| 66 | 66 | /** |
| 67 | 67 | * Cache key to use. |
| 68 | 68 | * |
| 69 | 69 | * @var string |
| 70 | 70 | */ |
| 71 | - protected $cacheKey = 'cache:AustinHeap\Security\Txt\SecurityTxt'; |
|
| 71 | + protected $cacheKey = 'cache:AustinHeap\Security\Txt\SecurityTxt'; |
|
| 72 | 72 | |
| 73 | 73 | /** |
| 74 | 74 | * Enable built-in comments. |
| 75 | 75 | * |
| 76 | 76 | * @var bool |
| 77 | 77 | */ |
| 78 | - protected $comments = true; |
|
| 78 | + protected $comments = true; |
|
| 79 | 79 | |
| 80 | 80 | /** |
| 81 | 81 | * The security contacts to list. |
| 82 | 82 | * |
| 83 | 83 | * @var array |
| 84 | 84 | */ |
| 85 | - protected $contacts = []; |
|
| 85 | + protected $contacts = []; |
|
| 86 | 86 | |
| 87 | 87 | /** |
| 88 | 88 | * The PGP key file URL. |
| 89 | 89 | * |
| 90 | 90 | * @var string |
| 91 | 91 | */ |
| 92 | - protected $encryption = null; |
|
| 92 | + protected $encryption = null; |
|
| 93 | 93 | |
| 94 | 94 | /** |
| 95 | 95 | * The disclosure policy. |
| 96 | 96 | * |
| 97 | 97 | * @var string |
| 98 | 98 | */ |
| 99 | - protected $disclosure = null; |
|
| 99 | + protected $disclosure = null; |
|
| 100 | 100 | |
| 101 | 101 | /** |
| 102 | 102 | * The acknowledgement URL. |
| 103 | 103 | * |
| 104 | 104 | * @var string |
| 105 | 105 | */ |
| 106 | - protected $acknowledgement = null; |
|
| 106 | + protected $acknowledgement = null; |
|
| 107 | 107 | |
| 108 | 108 | /** |
| 109 | 109 | * Create a new SecurityTxt instance. |
@@ -113,16 +113,16 @@ discard block |
||
| 113 | 113 | public function __construct() |
| 114 | 114 | { |
| 115 | 115 | $keys = [ |
| 116 | - 'security-txt.enabled' => ['validator' => 'is_bool', 'setter' => 'setEnabled'], |
|
| 117 | - 'security-txt.debug' => ['validator' => 'is_bool', 'setter' => 'setDebug'], |
|
| 118 | - 'security-txt.cache' => ['validator' => 'is_bool', 'setter' => 'setCache'], |
|
| 119 | - 'security-txt.cache-time' => ['validator' => 'is_numeric', 'setter' => 'setCacheTime'], |
|
| 120 | - 'security-txt.cache-key' => ['validator' => 'is_string', 'setter' => 'setCacheKey'], |
|
| 121 | - 'security-txt.comments' => ['validator' => 'is_bool', 'setter' => 'setComments'], |
|
| 122 | - 'security-txt.contacts' => ['validator' => 'is_array', 'setter' => 'setContacts'], |
|
| 123 | - 'security-txt.encryption' => ['validator' => 'is_string', 'setter' => 'setEncryption'], |
|
| 124 | - 'security-txt.disclosure' => ['validator' => 'is_string', 'setter' => 'setDisclosure'], |
|
| 125 | - 'security-txt.acknowledgement' => ['validator' => 'is_string', 'setter' => 'setAcknowledgement'], |
|
| 116 | + 'security-txt.enabled' => ['validator' => 'is_bool', 'setter' => 'setEnabled'], |
|
| 117 | + 'security-txt.debug' => ['validator' => 'is_bool', 'setter' => 'setDebug'], |
|
| 118 | + 'security-txt.cache' => ['validator' => 'is_bool', 'setter' => 'setCache'], |
|
| 119 | + 'security-txt.cache-time' => ['validator' => 'is_numeric', 'setter' => 'setCacheTime'], |
|
| 120 | + 'security-txt.cache-key' => ['validator' => 'is_string', 'setter' => 'setCacheKey'], |
|
| 121 | + 'security-txt.comments' => ['validator' => 'is_bool', 'setter' => 'setComments'], |
|
| 122 | + 'security-txt.contacts' => ['validator' => 'is_array', 'setter' => 'setContacts'], |
|
| 123 | + 'security-txt.encryption' => ['validator' => 'is_string', 'setter' => 'setEncryption'], |
|
| 124 | + 'security-txt.disclosure' => ['validator' => 'is_string', 'setter' => 'setDisclosure'], |
|
| 125 | + 'security-txt.acknowledgement' => ['validator' => 'is_string', 'setter' => 'setAcknowledgement'], |
|
| 126 | 126 | ]; |
| 127 | 127 | |
| 128 | 128 | foreach ($keys as $key => $mapping) |
@@ -164,14 +164,14 @@ discard block |
||
| 164 | 164 | throw new \Exception('One (or more) contacts must be defined.'); |
| 165 | 165 | |
| 166 | 166 | foreach ($this->contacts as $contact) |
| 167 | - $this->addLine('Contact: ' . trim($contact)); |
|
| 167 | + $this->addLine('Contact: '.trim($contact)); |
|
| 168 | 168 | |
| 169 | 169 | if (!empty($this->encryption)) { |
| 170 | 170 | if ($this->comments) |
| 171 | 171 | $this->addSpacer() |
| 172 | 172 | ->addComment('Our PGP key'); |
| 173 | 173 | |
| 174 | - $this->addLine('Encryption: ' . trim($this->encryption)); |
|
| 174 | + $this->addLine('Encryption: '.trim($this->encryption)); |
|
| 175 | 175 | } |
| 176 | 176 | |
| 177 | 177 | if (!empty($this->disclosure)) { |
@@ -179,7 +179,7 @@ discard block |
||
| 179 | 179 | $this->addSpacer() |
| 180 | 180 | ->addComment('Our disclosure policy'); |
| 181 | 181 | |
| 182 | - $this->addLine('Disclosure: ' . trim(ucfirst($this->disclosure))); |
|
| 182 | + $this->addLine('Disclosure: '.trim(ucfirst($this->disclosure))); |
|
| 183 | 183 | } |
| 184 | 184 | |
| 185 | 185 | if (!empty($this->acknowledgement)) { |
@@ -187,16 +187,16 @@ discard block |
||
| 187 | 187 | $this->addSpacer() |
| 188 | 188 | ->addComment('Our public acknowledgement'); |
| 189 | 189 | |
| 190 | - $this->addLine('Acknowledgement: ' . trim($this->acknowledgement)); |
|
| 190 | + $this->addLine('Acknowledgement: '.trim($this->acknowledgement)); |
|
| 191 | 191 | } |
| 192 | 192 | |
| 193 | 193 | if ($this->debug) |
| 194 | 194 | $this->addSpacer() |
| 195 | 195 | ->addComment() |
| 196 | 196 | ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
| 197 | - ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
|
| 197 | + ->addComment('in '.round((microtime(true) - $time) * 1000, 6).' seconds on '.now().'.') |
|
| 198 | 198 | ->addComment() |
| 199 | - ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
|
| 199 | + ->addComment('Cache is '.($this->cache ? 'enabled with key "'.$this->cacheKey.'"' : 'disabled').'.') |
|
| 200 | 200 | ->addComment() |
| 201 | 201 | ->addSpacer(); |
| 202 | 202 | |
@@ -619,9 +619,9 @@ discard block |
||
| 619 | 619 | $comment = trim($comment); |
| 620 | 620 | |
| 621 | 621 | if (!empty($comment)) |
| 622 | - $comment = ' ' . $comment; |
|
| 622 | + $comment = ' '.$comment; |
|
| 623 | 623 | |
| 624 | - return $this->addLine('#' . $comment); |
|
| 624 | + return $this->addLine('#'.$comment); |
|
| 625 | 625 | } |
| 626 | 626 | |
| 627 | 627 | /** |
@@ -125,10 +125,11 @@ discard block |
||
| 125 | 125 | 'security-txt.acknowledgement' => ['validator' => 'is_string', 'setter' => 'setAcknowledgement'], |
| 126 | 126 | ]; |
| 127 | 127 | |
| 128 | - foreach ($keys as $key => $mapping) |
|
| 129 | - if (config($key, null) !== null && |
|
| 128 | + foreach ($keys as $key => $mapping) { |
|
| 129 | + if (config($key, null) !== null && |
|
| 130 | 130 | $mapping['validator'](config($key))) |
| 131 | 131 | $this->{$mapping['setter']}(config($key)); |
| 132 | + } |
|
| 132 | 133 | |
| 133 | 134 | return $this; |
| 134 | 135 | } |
@@ -145,53 +146,62 @@ discard block |
||
| 145 | 146 | $output = cache($this->cacheKey, null); |
| 146 | 147 | |
| 147 | 148 | if (!is_null($output) && |
| 148 | - is_string($output)) |
|
| 149 | - return $this->setText($output); |
|
| 149 | + is_string($output)) { |
|
| 150 | + return $this->setText($output); |
|
| 151 | + } |
|
| 150 | 152 | |
| 151 | 153 | unset($output); |
| 152 | 154 | } |
| 153 | 155 | |
| 154 | - if ($this->debug) |
|
| 155 | - $time = microtime(true); |
|
| 156 | + if ($this->debug) { |
|
| 157 | + $time = microtime(true); |
|
| 158 | + } |
|
| 156 | 159 | |
| 157 | - if ($reset) |
|
| 158 | - $this->resetLines(); |
|
| 160 | + if ($reset) { |
|
| 161 | + $this->resetLines(); |
|
| 162 | + } |
|
| 159 | 163 | |
| 160 | - if ($this->comments) |
|
| 161 | - $this->addComment('Our security address'); |
|
| 164 | + if ($this->comments) { |
|
| 165 | + $this->addComment('Our security address'); |
|
| 166 | + } |
|
| 162 | 167 | |
| 163 | - if (empty($this->contacts)) |
|
| 164 | - throw new \Exception('One (or more) contacts must be defined.'); |
|
| 168 | + if (empty($this->contacts)) { |
|
| 169 | + throw new \Exception('One (or more) contacts must be defined.'); |
|
| 170 | + } |
|
| 165 | 171 | |
| 166 | - foreach ($this->contacts as $contact) |
|
| 167 | - $this->addLine('Contact: ' . trim($contact)); |
|
| 172 | + foreach ($this->contacts as $contact) { |
|
| 173 | + $this->addLine('Contact: ' . trim($contact)); |
|
| 174 | + } |
|
| 168 | 175 | |
| 169 | 176 | if (!empty($this->encryption)) { |
| 170 | - if ($this->comments) |
|
| 171 | - $this->addSpacer() |
|
| 177 | + if ($this->comments) { |
|
| 178 | + $this->addSpacer() |
|
| 172 | 179 | ->addComment('Our PGP key'); |
| 180 | + } |
|
| 173 | 181 | |
| 174 | 182 | $this->addLine('Encryption: ' . trim($this->encryption)); |
| 175 | 183 | } |
| 176 | 184 | |
| 177 | 185 | if (!empty($this->disclosure)) { |
| 178 | - if ($this->comments) |
|
| 179 | - $this->addSpacer() |
|
| 186 | + if ($this->comments) { |
|
| 187 | + $this->addSpacer() |
|
| 180 | 188 | ->addComment('Our disclosure policy'); |
| 189 | + } |
|
| 181 | 190 | |
| 182 | 191 | $this->addLine('Disclosure: ' . trim(ucfirst($this->disclosure))); |
| 183 | 192 | } |
| 184 | 193 | |
| 185 | 194 | if (!empty($this->acknowledgement)) { |
| 186 | - if ($this->comments) |
|
| 187 | - $this->addSpacer() |
|
| 195 | + if ($this->comments) { |
|
| 196 | + $this->addSpacer() |
|
| 188 | 197 | ->addComment('Our public acknowledgement'); |
| 198 | + } |
|
| 189 | 199 | |
| 190 | 200 | $this->addLine('Acknowledgement: ' . trim($this->acknowledgement)); |
| 191 | 201 | } |
| 192 | 202 | |
| 193 | - if ($this->debug) |
|
| 194 | - $this->addSpacer() |
|
| 203 | + if ($this->debug) { |
|
| 204 | + $this->addSpacer() |
|
| 195 | 205 | ->addComment() |
| 196 | 206 | ->addComment('Generated by https://github.com/austinheap/laravel-security-txt') |
| 197 | 207 | ->addComment('in ' . round((microtime(true) - $time) * 1000, 6) . ' seconds on ' . now() . '.') |
@@ -199,11 +209,13 @@ discard block |
||
| 199 | 209 | ->addComment('Cache is ' . ($this->cache ? 'enabled with key "' . $this->cacheKey . '"' : 'disabled') . '.') |
| 200 | 210 | ->addComment() |
| 201 | 211 | ->addSpacer(); |
| 212 | + } |
|
| 202 | 213 | |
| 203 | 214 | $output = implode(PHP_EOL, $this->lines); |
| 204 | 215 | |
| 205 | - if ($this->cache) |
|
| 206 | - cache([$this->cacheKey => $output], now()->addMinutes($this->cacheTime)); |
|
| 216 | + if ($this->cache) { |
|
| 217 | + cache([$this->cacheKey => $output], now()->addMinutes($this->cacheTime)); |
|
| 218 | + } |
|
| 207 | 219 | |
| 208 | 220 | return $this->setText($output); |
| 209 | 221 | } |
@@ -448,8 +460,9 @@ discard block |
||
| 448 | 460 | */ |
| 449 | 461 | public function getText(bool $generate = false, bool $reset = false): string |
| 450 | 462 | { |
| 451 | - if ($generate) |
|
| 452 | - $this->generate($reset); |
|
| 463 | + if ($generate) { |
|
| 464 | + $this->generate($reset); |
|
| 465 | + } |
|
| 453 | 466 | |
| 454 | 467 | return $this->text === null ? '' : $this->text; |
| 455 | 468 | } |
@@ -496,8 +509,9 @@ discard block |
||
| 496 | 509 | */ |
| 497 | 510 | public function addContacts(array $contacts): SecurityTxt |
| 498 | 511 | { |
| 499 | - foreach ($contacts as $contact) |
|
| 500 | - $this->contacts[$contact] = true; |
|
| 512 | + foreach ($contacts as $contact) { |
|
| 513 | + $this->contacts[$contact] = true; |
|
| 514 | + } |
|
| 501 | 515 | |
| 502 | 516 | return $this; |
| 503 | 517 | } |
@@ -523,9 +537,10 @@ discard block |
||
| 523 | 537 | */ |
| 524 | 538 | public function removeContacts(array $contacts): SecurityTxt |
| 525 | 539 | { |
| 526 | - foreach ($contacts as $contact) |
|
| 527 | - if (array_key_exists($contact, $this->contacts)) |
|
| 540 | + foreach ($contacts as $contact) { |
|
| 541 | + if (array_key_exists($contact, $this->contacts)) |
|
| 528 | 542 | unset($this->contacts[$contact]); |
| 543 | + } |
|
| 529 | 544 | |
| 530 | 545 | return $this; |
| 531 | 546 | } |
@@ -538,8 +553,9 @@ discard block |
||
| 538 | 553 | */ |
| 539 | 554 | public function setEncryption(string $encryption): SecurityTxt |
| 540 | 555 | { |
| 541 | - if (filter_var($encryption, FILTER_VALIDATE_URL) === false) |
|
| 542 | - throw new \Exception('Encryption must be a well-formed URL.'); |
|
| 556 | + if (filter_var($encryption, FILTER_VALIDATE_URL) === false) { |
|
| 557 | + throw new \Exception('Encryption must be a well-formed URL.'); |
|
| 558 | + } |
|
| 543 | 559 | |
| 544 | 560 | $this->encryption = $encryption; |
| 545 | 561 | |
@@ -564,8 +580,9 @@ discard block |
||
| 564 | 580 | */ |
| 565 | 581 | public function setDisclosure(string $disclosure): SecurityTxt |
| 566 | 582 | { |
| 567 | - if (!in_array(trim(strtolower($disclosure)), ['full', 'partial', 'none'])) |
|
| 568 | - throw new \Exception('Disclosure policy must be either "full", "partial", or "none".'); |
|
| 583 | + if (!in_array(trim(strtolower($disclosure)), ['full', 'partial', 'none'])) { |
|
| 584 | + throw new \Exception('Disclosure policy must be either "full", "partial", or "none".'); |
|
| 585 | + } |
|
| 569 | 586 | |
| 570 | 587 | $this->disclosure = $disclosure; |
| 571 | 588 | |
@@ -590,8 +607,9 @@ discard block |
||
| 590 | 607 | */ |
| 591 | 608 | public function setAcknowledgement(string $acknowledgement): SecurityTxt |
| 592 | 609 | { |
| 593 | - if (filter_var($acknowledgement, FILTER_VALIDATE_URL) === false) |
|
| 594 | - throw new \Exception('Acknowledgement must be a well-formed URL.'); |
|
| 610 | + if (filter_var($acknowledgement, FILTER_VALIDATE_URL) === false) { |
|
| 611 | + throw new \Exception('Acknowledgement must be a well-formed URL.'); |
|
| 612 | + } |
|
| 595 | 613 | |
| 596 | 614 | $this->acknowledgement = $acknowledgement; |
| 597 | 615 | |
@@ -618,8 +636,9 @@ discard block |
||
| 618 | 636 | { |
| 619 | 637 | $comment = trim($comment); |
| 620 | 638 | |
| 621 | - if (!empty($comment)) |
|
| 622 | - $comment = ' ' . $comment; |
|
| 639 | + if (!empty($comment)) { |
|
| 640 | + $comment = ' ' . $comment; |
|
| 641 | + } |
|
| 623 | 642 | |
| 624 | 643 | return $this->addLine('#' . $comment); |
| 625 | 644 | } |