Analyzing grub
This commit is contained in:
parent
03143c4c0d
commit
9843ca26b9
@ -1,11 +1,8 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
def grub() -> list:
|
||||
grub = list()
|
||||
grub.append({
|
||||
'description': 'Boot permission',
|
||||
'filename': '/boot/grub/grub.cfg'
|
||||
'chmod': 600,
|
||||
})
|
||||
def grub() -> dict:
|
||||
grub = dict()
|
||||
grub['description'] = 'Change boot permission'
|
||||
grub['filename'] = '/boot/grub/grub.cfg'
|
||||
grub['value'] = 0o600
|
||||
return grub
|
||||
|
||||
|
@ -13,6 +13,7 @@ AUDIT_SYSTEM = [
|
||||
"postfix",
|
||||
"apache",
|
||||
"localaccount",
|
||||
"grub",
|
||||
]
|
||||
|
||||
AUDIT_APPLICATION = [
|
||||
@ -31,6 +32,7 @@ def generateConfig() -> dict:
|
||||
config["system"]["sysctl"] = dict()
|
||||
config["system"]["sysctl"]["sysctl_file"] = "/etc/sysctl.conf"
|
||||
config['system']['localaccount'] = dict()
|
||||
config['system']['grub'] = dict()
|
||||
config["system"]["exclude_plugins"] = list()
|
||||
# Application
|
||||
config["application"] = dict()
|
||||
|
@ -5,6 +5,7 @@ from core.plugins.sysctl import Sysctl
|
||||
from core.plugins.postfix import Postfix
|
||||
from core.plugins.apache import Apache
|
||||
from core.plugins.localaccount import LocalAccount
|
||||
from core.plugins.grub import Grub
|
||||
from core.report import generateHtmlReport
|
||||
from core.config import AUDIT_SYSTEM, AUDIT_APPLICATION, generateConfig, parsingConfigFile
|
||||
from core.dispatcher import Dispatcher
|
||||
@ -70,7 +71,6 @@ def main():
|
||||
audit,
|
||||
configs["system"][audit]
|
||||
)
|
||||
|
||||
if args.audit == "application":
|
||||
print("Auditing the application...")
|
||||
pass
|
||||
@ -102,5 +102,11 @@ def localaccount(*args) -> dict:
|
||||
account.runAudit()
|
||||
return account.getReports()
|
||||
|
||||
@Dispatcher.register_plugins
|
||||
def grub(*args) -> dict:
|
||||
grub = Grub(args[1])
|
||||
grub.runAudit()
|
||||
return grub.getReports()
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
|
85
core/plugins/grub.py
Normal file
85
core/plugins/grub.py
Normal file
@ -0,0 +1,85 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
from os import stat
|
||||
from os.path import isfile
|
||||
from audit.system.plugins.grub import grub
|
||||
|
||||
|
||||
class Grub:
|
||||
def __init__(self, arguments):
|
||||
self._object = grub()
|
||||
self._reports = dict()
|
||||
|
||||
# Create the report
|
||||
self._constructReports()
|
||||
|
||||
def runAudit(self):
|
||||
print("Running test for Grub")
|
||||
self._analyzingGrub()
|
||||
|
||||
def getReports(self) -> dict:
|
||||
return self._reports
|
||||
|
||||
def _analyzingGrub(self):
|
||||
# Check if the file exist
|
||||
path = self._object['filename']
|
||||
try:
|
||||
if isfile(path):
|
||||
permission = self._check_permission(path)
|
||||
|
||||
if permission != oct(self._object['value']):
|
||||
self._reports['result'] = 'failed'
|
||||
else:
|
||||
self._reports['result'] = 'success'
|
||||
self._reports['description'] = self._object['description']
|
||||
self._reports['recommand_value'] = self._object['value']
|
||||
except FileNotFoundError:
|
||||
self._reports['grub']['error'] = \
|
||||
f'File {path} not found'
|
||||
|
||||
def _check_permission(self, path) -> oct:
|
||||
"""
|
||||
In this function, we get the permission of the file
|
||||
"""
|
||||
permission = stat(path).st_mode
|
||||
|
||||
octal = 0o000
|
||||
# Check user permission
|
||||
if permission & 0o400: # Read
|
||||
octal += 0o400
|
||||
if permission & 0o200: # Write
|
||||
octal += 0o200
|
||||
if permission & 0o100: # Execute
|
||||
octal += 0o100
|
||||
|
||||
# Check group permission
|
||||
if permission & 0o040:
|
||||
octal += 0o040
|
||||
if permission & 0o020:
|
||||
octal += 0o020
|
||||
if permission & 0o010:
|
||||
octal += 0o010
|
||||
|
||||
# Check other permission
|
||||
if permission & 0o004:
|
||||
octal += 0o004
|
||||
if permission & 0o002:
|
||||
octal += 0o002
|
||||
if permission & 0o001:
|
||||
octal += 0o001
|
||||
|
||||
return oct(octal)
|
||||
|
||||
def _constructReports(self):
|
||||
"""
|
||||
Construct dictionary for result of the tests
|
||||
Each entry contains:
|
||||
Key:
|
||||
- filename: filename of the test
|
||||
- line: line of the test
|
||||
- parse: Display the line where the vulnerabilites has been found
|
||||
- description: description of the vulnerability
|
||||
- level: high, medium or low
|
||||
"""
|
||||
self._reports = dict()
|
||||
self._reports['filename'] = self._object['filename']
|
@ -50,6 +50,11 @@ def generateHtmlReport(data):
|
||||
_generateAccordion(dataJinja2['profile']['vulnerabilities'], 'profile')
|
||||
if 'pwd_quality' in data['system']['localaccount']:
|
||||
pass
|
||||
if 'grub' in data['system']:
|
||||
dataJinja2['grub'] = data['system']['grub']
|
||||
dataJinja2['grub']['accordion-id'] = f"accordion-grub-1"
|
||||
#_generateAccordion(dataJinja2['grub'], 'grub')
|
||||
print(dataJinja2['grub'])
|
||||
|
||||
dataJinja2['year'] = '2023'
|
||||
dataJinja2['hostname'] = data['hostname']
|
||||
|
@ -13,7 +13,7 @@
|
||||
{% endif %}
|
||||
</button>
|
||||
</h2>
|
||||
<div id="{{ data['postfix']['vulnerabilities'][item]['accordion-id'] }}" class="accordion-collapse collapse" data-bs-parent="#accordionPostfix">
|
||||
<div id="{{ data['postfix']['vulnerabilities'][item]['accordion-id'] }}" class="accordion-collapse collapse" data-bs-parent="#accordionApache">
|
||||
<div class="accordion-body">
|
||||
{{ data['postfix']['vulnerabilities'][item]['description'] }}. <br />
|
||||
{% if data['postfix']['vulnerabilities'][item]['result'] == 'success' %}
|
||||
|
39
reports/templates/grub.html.j2
Normal file
39
reports/templates/grub.html.j2
Normal file
@ -0,0 +1,39 @@
|
||||
<h3 class="fs-3">Grub</h3>
|
||||
|
||||
<div class="accordion" id="accordionSysctl">
|
||||
<div class="accordion-item">
|
||||
<h2 class="accordion-header">
|
||||
<button class="accordion-button collapsed" type="button" data-bs-toggle="collapse" data-bs-target="#{{ data['grub']['accordion-id'] }}" aria-expanded="true" aria-controls="{{ data['grub']['accordion-id'] }}">
|
||||
<strong>Grub</strong>
|
||||
{% if data['grub']['result'] == 'failed' %}
|
||||
<span class="text-bg-danger p-1" style="padding-left:10pt;padding-right:10pt;margin-left:15pt;">{{ data['grub']['result'] }}</span>
|
||||
{% elif data['grub']['result'] == 'success' %}
|
||||
<span class="text-bg-success p-1" style="padding-left:10pt;padding-right:10pt;margin-left:15pt;">{{ data['grub']['result'] }}</span>
|
||||
{% endif %}
|
||||
</button>
|
||||
</h2>
|
||||
<div id="{{ data['grub']['accordion-id'] }}" class="accordion-collapse collapse" data-bs-parent="#accordionGrub">
|
||||
<div class="accordion-body">
|
||||
{{ data['grub']['description'] }}. <br />
|
||||
{% if data['grub']['result'] == 'success' %}
|
||||
<div class="bd-example-snippet bd-code-snippet">
|
||||
<div class="highlight">
|
||||
<pre tabindex="0" class="chroma"><code class="language-shell">
|
||||
{{ data['grub']['recommand_value'] }}
|
||||
</pre></code>
|
||||
</div>
|
||||
</div>
|
||||
{% else %}
|
||||
For resolving the issue, add this line in the <strong>{{ data['filename'] }}</strong> profile:
|
||||
<div class="bd-example-snippet bd-code-snippet">
|
||||
<div class="highlight">
|
||||
<pre tabindex="0" class="chroma"><code class="language-shell">
|
||||
{{ data['grub']['recommand_value'] }}
|
||||
</pre></code>
|
||||
</div>
|
||||
</div>
|
||||
{% endif %}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
@ -13,7 +13,7 @@
|
||||
{% endif %}
|
||||
</button>
|
||||
</h2>
|
||||
<div id="{{ data['profile']['vulnerabilities'][item]['accordion-id'] }}" class="accordion-collapse collapse" data-bs-parent="#accordionPostfix">
|
||||
<div id="{{ data['profile']['vulnerabilities'][item]['accordion-id'] }}" class="accordion-collapse collapse" data-bs-parent="#accordionProfile">
|
||||
<div class="accordion-body">
|
||||
{{ data['profile']['vulnerabilities'][item]['description'] }}. <br />
|
||||
{% if data['profile']['vulnerabilities'][item]['result'] == 'success' %}
|
||||
|
Loading…
Reference in New Issue
Block a user