-
Notifications
You must be signed in to change notification settings - Fork 2k
Expand file tree
/
Copy pathcheck_permission_x.php
More file actions
95 lines (72 loc) · 2.27 KB
/
check_permission_x.php
File metadata and controls
95 lines (72 loc) · 2.27 KB
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
<?php
declare(strict_types=1);
/**
* This file is part of CodeIgniter 4 framework.
*
* (c) CodeIgniter Foundation <[email protected]>
*
* For the full copyright and license information, please view
* the LICENSE file that was distributed with this source code.
*/
namespace Utils;
require __DIR__ . '/../system/Test/bootstrap.php';
use CodeIgniter\CLI\CLI;
use RecursiveDirectoryIterator;
use RecursiveIteratorIterator;
use RuntimeException;
function findExecutableFiles($dir)
{
$execFileList = [
'admin/release-userguide',
'admin/release-deploy',
'admin/apibot',
'admin/alldocs',
'admin/release',
'admin/docbot',
'admin/release-notes.bb',
'admin/release-revert',
'admin/starter/builds',
'user_guide_src/add-edit-this-page',
];
$executableFiles = [];
// Check if the directory exists
if (! is_dir($dir)) {
throw new RuntimeException('No such directory: ' . $dir);
}
// Create a Recursive Directory Iterator
$iterator = new RecursiveIteratorIterator(
new RecursiveDirectoryIterator($dir),
);
// Iterate over each item in the directory
foreach ($iterator as $fileinfo) {
// Check if the item is a file and is executable
if ($fileinfo->isFile() && is_executable($fileinfo->getPathname())) {
$filePath = $fileinfo->getPathname();
// Check allow list
if (in_array($filePath, $execFileList, true)) {
continue;
}
if (str_ends_with($filePath, '.sh')) {
continue;
}
$executableFiles[] = $filePath;
}
}
return $executableFiles;
}
// Main
chdir(__DIR__ . '/../');
$dirs = ['admin', 'app', 'system', 'tests', 'user_guide_src', 'utils', 'writable'];
$executableFiles = [];
foreach ($dirs as $dir) {
$executableFiles = array_merge($executableFiles, findExecutableFiles($dir));
}
if ($executableFiles !== []) {
CLI::write('Files with unnecessary execution permissions were detected:', 'light_gray', 'red');
foreach ($executableFiles as $file) {
CLI::write('- ' . $file);
}
exit(1);
}
CLI::write('No files with unnecessary execution permissions were detected.', 'black', 'green');
exit(0);