Skip to content

Commit

Permalink
New security command
Browse files Browse the repository at this point in the history
  • Loading branch information
afbora committed Feb 28, 2024
1 parent 956ae92 commit 005ce24
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 0 deletions.
1 change: 1 addition & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,7 @@ This should print the Kirby CLI version and a list of available commands
- kirby register
- kirby remove:command
- kirby roots
- kirby security
- kirby unzip
- kirby upgrade
- kirby uuid:generate
Expand Down
55 changes: 55 additions & 0 deletions commands/security.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
<?php

declare(strict_types = 1);

use Kirby\CLI\CLI;
use Kirby\Http\Remote;
use Kirby\Http\Url;
use Kirby\Toolkit\I18n;

return [
'description' => 'Performs security checks of the site',
'command' => static function (CLI $cli): void {
$kirby = $cli->kirby();
$system = $kirby->system();
$updateStatus = $system->updateStatus();
$messages = [
...array_column($updateStatus?->messages() ?? [], 'text'),
...$updateStatus->exceptionMessages()
];

if ($kirby->option('debug', false) === true) {
$messages[] = I18n::translate('system.issues.debug');
}

if ($kirby->environment()->https() !== true) {
$messages[] = I18n::translate('system.issues.https');
}

// checks exposable urls of the site
// works only site url is absolute since can't get it in CLI mode
// and CURL won't work for relative urls
if (Url::isAbsolute($kirby->url())) {
$urls = [
'content' => $system->exposedFileUrl('content'),
'git' => $system->exposedFileUrl('git'),
'kirby' => $system->exposedFileUrl('kirby'),
'site' => $system->exposedFileUrl('site')
];

foreach ($urls as $key => $url) {
if (empty($url) === false && Remote::get($url)->code() < 400) {
$messages[] = I18n::translate('system.issues.' . $key);
}
}
}

if (empty($messages) === false) {
foreach ($messages as $message) {
$cli->error('> ' . $message);
}
} else {
$cli->success('No security warnings were detected');
}
}
];

0 comments on commit 005ce24

Please sign in to comment.