diff --git a/app/Config/Routes.php b/app/Config/Routes.php index 81a4f2956..58b9b3421 100755 --- a/app/Config/Routes.php +++ b/app/Config/Routes.php @@ -86,6 +86,7 @@ $routes->get('about', 'Help::about', ['filter' => \App\Filters\Session::class, 'as' => 'about']); $routes->get('api', 'Help::api', ['filter' => \App\Filters\Session::class, 'as' => 'api']); $routes->get('help', 'Help::about', ['filter' => \App\Filters\Session::class, 'as' => 'helpCollection']); +$routes->get('faq', 'Help::faq', ['filter' => \App\Filters\Session::class, 'as' => 'helpFAQ']); $routes->get('features', 'Help::features', ['filter' => \App\Filters\Session::class, 'as' => 'features']); $routes->get('prereq', 'Help::prereq', ['filter' => \App\Filters\Session::class, 'as' => 'prereq']); $routes->get('welcome', 'Help::welcome', ['filter' => \App\Filters\Session::class, 'as' => 'welcome']); @@ -94,6 +95,7 @@ $routes->get('getting_started', 'Help::gettingStarted', ['filter' => \App\Filters\Session::class, 'as' => 'getting_started']); $routes->get('discovery_issues/(:num)', 'Help::discoveryIssues/$1', ['filter' => \App\Filters\Session::class, 'as' => 'discoveryIssues']); + $routes->post('input/benchmarks', 'Input::benchmarks'); $routes->post('input/devices', 'Input::devices'); $routes->post('input/logs', 'Input::logs'); diff --git a/app/Controllers/Help.php b/app/Controllers/Help.php index 1498de697..64a69639e 100644 --- a/app/Controllers/Help.php +++ b/app/Controllers/Help.php @@ -142,6 +142,32 @@ public function discoveryIssues() . view('shared/footer', ['license_string' => $this->resp->meta->license_string]); } + /** + * The FAQ pages + * + * @access public + * @return NULL + */ + public function faq() + { + #$request = \Config\Services::request(); + $name = $this->request->getGet('name'); + $valid_names = array('Creating a Query', 'Running Open-AudIT Apache Service Under Windows', 'Google Maps API Key'); + if (!in_array($name, $valid_names)) { + redirect('home'); + } + return view('shared/header', [ + 'config' => $this->config, + 'dashboards' => filter_response($this->dashboards), + 'meta' => filter_response($this->resp->meta), + 'orgs' => filter_response($this->orgsUser), + 'queries' => filter_response($this->queriesUser), + 'roles' => filter_response($this->roles), + 'user' => filter_response($this->user)]) . + view('helpFAQ', ['name' => $name]) + . view('shared/footer', ['license_string' => $this->resp->meta->license_string]); + } + /** * The Features page * diff --git a/app/Helpers/utility_helper.php b/app/Helpers/utility_helper.php index 46b86e87b..fda82cbfe 100644 --- a/app/Helpers/utility_helper.php +++ b/app/Helpers/utility_helper.php @@ -53,7 +53,7 @@ function nmapInstalled($setNotice = false) } unset($test_path); if ($nmap_installed === 'n' and $setNotice) { - \Config\Services::session()->setFlashdata('error', "WARNING - Nmap not detected. Get it from http://nmap.org/download.html.
Please see https://community.opmantek.com/display/OA/Open-AudIT+and+Nmap for information about why Open-AudIT requires Nmap and how to install it."); + \Config\Services::session()->setFlashdata('error', "WARNING - Nmap not detected. Get it from http://nmap.org/download.html.
Please see Open-AudIT and Nmap for information about why Open-AudIT requires Nmap and how to install it."); } } if (php_uname('s') !== 'Windows NT') { @@ -76,7 +76,7 @@ function nmapInstalled($setNotice = false) } } if ($nmap_installed === 'n' and $setNotice) { - \Config\Services::session()->setFlashdata('error', "WARNING - Nmap not detected. Please install it using your package manager.
Please see https://community.opmantek.com/display/OA/Open-AudIT+and+Nmap for information about why Open-AudIT requires Nmap and how to install it."); + \Config\Services::session()->setFlashdata('error', "WARNING - Nmap not detected. Please install it using your package manager.
Please see Open-AudIT and Nmap for information about why Open-AudIT requires Nmap and how to install it."); } } return $nmap_installed; @@ -119,7 +119,7 @@ function nmapSuid($setNotice = false) } } if ($suid === 'n' and $setNotice) { - \Config\Services::session()->setFlashdata('error', "WARNING - Nmap SUID not set.
Please see https://community.opmantek.com/display/OA/Open-AudIT+and+Nmap for information about why Open-AudIT requires Nmap and how to configure it."); + \Config\Services::session()->setFlashdata('error', "WARNING - Nmap SUID not set.
Please see Open-AudIT and Nmap for information about why Open-AudIT requires Nmap and how to configure it."); } return $suid; } diff --git a/app/Models/DiscoveriesModel.php b/app/Models/DiscoveriesModel.php index 65b5ea21b..fa5182d17 100644 --- a/app/Models/DiscoveriesModel.php +++ b/app/Models/DiscoveriesModel.php @@ -827,12 +827,12 @@ public function permissions() log_message('error', "Cannot find Nmap."); } } - if (php_uname('s') === 'Windows NT') { - if (strtolower(get_current_user()) === 'system' or exec('whoami') === 'nt authority\system') { - $warning = 'The Apache service is running as SYSTEM. Discoveries will not function. Please see this wiki page and make the configuration change. Running Open-AudIT Apache Service under Windows.'; + #if (php_uname('s') === 'Windows NT') { + #if (strtolower(get_current_user()) === 'system' or exec('whoami') === 'nt authority\system') { + $warning = 'The Apache service is running as SYSTEM. Discoveries will not function. Please see this wiki page and make the configuration change. Running Open-AudIT Apache Service Under Windows.'; log_message('error', 'PHP process is owned by "nt authority\system" on Windows'); - } - } + #} + #} if (!empty($warning)) { \Config\Services::session()->setFlashdata('warning', $warning); } diff --git a/app/Models/FilesModel.php b/app/Models/FilesModel.php index a65752831..7d9af4fac 100644 --- a/app/Models/FilesModel.php +++ b/app/Models/FilesModel.php @@ -234,7 +234,11 @@ public function dictionary(): object $dictionary->about = '

Open-AudIT can retrieve details about a file or directory of files and monitor these files for changes as per other attributes in the Open-AudIT database.

This feature works out of the box for Linux Open-AudIT servers, but needs a change to the service account name under a Windows Open-AudIT server.

Supported clients are Windows and Linux.

' . $instance->dictionary->link . '

'; - $dictionary->notes = '

See the note about enabling this feature when running a Windows Open-AudIT server on the wiki, here - https://community.opmantek.com/display/OA/files#Files-EnablingtheFeatureUnderWindows.

'; + $dictionary->notes = '

There is no need to do anything if you\'re running Open-AudIT on a Linux server.
+
+Windows clients are just fine and require no special actions, however.... to enable this feature the audit script must be run locally on the target Windows system. It cannot be run remotely as we do with WMI calls when running the audit script on one Windows machine, while targeting a second Windows machine. To do this we need to copy the audit script to the target Windows machine and then run it. Unfortunately the service account that Apache runs under is the Local System account. This account has no access to remote (network based) resources. To work around this issue the service must be run under another account. It is easiest to just use the local Administrator account, but you can try any account you like as long as it has the required privileges. The Local System account has as much local access as the local Administrator account.
+
+See our page on enabling Running Open-AudIT Apache Service Under Windows

'; $dictionary->product = 'enterprise'; diff --git a/app/Models/LocationsModel.php b/app/Models/LocationsModel.php index f5d22ed35..7cc7a3c16 100644 --- a/app/Models/LocationsModel.php +++ b/app/Models/LocationsModel.php @@ -149,7 +149,7 @@ public function includedCreateForm(int $id = 0): array { $instance = & get_instance(); if (empty($instance->config->maps_api_key)) { - \Config\Services::session()->setFlashdata('warning', 'Google Maps API key required to retrieve lat/long and display map. See here.'); + \Config\Services::session()->setFlashdata('warning', 'Google Maps API key required to retrieve lat/long and display map. See here.'); } $attributesModel = new \App\Models\AttributesModel(); $include = array(); diff --git a/app/Views/faq/Creating a Query.php b/app/Views/faq/Creating a Query.php new file mode 100644 index 000000000..b4e754bb1 --- /dev/null +++ b/app/Views/faq/Creating a Query.php @@ -0,0 +1,67 @@ +Queries are an important part of Open-AudIT. They are what enables you to get meaningful information from all the device data you have discovered. Along with summaries and groups, they provide a powerful mechanism to extract crucial information.

'; + +$body = ' +

A query is essentially a SQL statement. This statement is run against the database with the automatic addition of the limit, filtered to apply to only those requested items and only those items the user has permission to view. A Query can be created using menu -> Manage -> Queries -> Create Queries. Queries contain an org_id and are hence restricted to the appropriate users. A user must have the org_admin or reporter role(s) to create, update or delete a query. All users can execute a query. A query has a name attribute used for the menu item as well as a menu category attribute. This tells the Open-Audit GUI which submenu to place the query in. There is also menu display which should be set to \'y\' to enable the query in the GUI (\'n\' to prevent the query from appearing at all). The query would still run if called using it\'s $id, regardless of menu display\'s value.

+

To view the details of a query, the standard URL structure of /open-audit/index.php/queries/{$id} should be used.

+

To actually execute the query, append a /execute, thus /open-audit/index.php/queries/{$id}/execute.

+ +

Breaking it Down

+

The SQL query is essentially broken into three parts.

+

The SELECT

+

The SELECT section of the query should use full dot notation and also request the field with it\'s full dot name. IE - SELECT devices.id AS `devices.id`. Each field should be selected in this fashion to enable GUI side attribute filtering.

+

Queries for Groups should select only the devices.id column.

+

SELECT devices.id AS `devices.id`, devices.icon AS `devices.icon`, devices.type AS `devices.type`, devices.name AS `devices.name`, devices.domain AS `devices.domain`, devices.ip AS `devices.ip`, user_group.name as `user_group.name`, user_group.members AS `user_group.members` +

+
+ +

The FROM

+

You should use only those tables that contain attributes you need. I usually use a LEFT JOIN. IE - SELECT devices.id AS `devices.id`, ip.ip AS `ip.ip` FROM devices LEFT JOIN ip ON (devices.id = ip.device_id).

+

All device sub-tables contain a couple of important columns. $table.device_id and $table.current. $table.device_id is the link to the devices.id column. The $table.current column will contain either \'y\' or \'n\'. This indicates if this row is currently present on the device. For example software may be installed (which would result in software.current = \'y\'), but on a subsequent audit it may not be detected. Open-AudIT will then change this rows current attribute to \'n\'.

+

FROM user_group LEFT JOIN devices ON (user_group.device_id = devices.id AND user_group.current = \'y\')

+
+ +

The WHERE

+

In order for Open-AudIT to be able to apply user permissions on items, we mandate the user of WHERE @filter. If you do not use this format, the queryCreateForm will throw a warning. Only users with the Admin role are permitted to create queries that lack this attribute and even then, only after the configuration item for \'advanced_queries\' has been enavled.

+

Other than that restriction, you are free to select attributes as required. It\'s a good idea to use the menu -> Admin -> Database -> List Tables item to view the specific tables and their columns. This will enable you to find exactly what you need, rather than trawling through the MySQL console of the schema creation script.

+

WHERE @filter AND (user_group.name = \'Administrators\' OR user_group.name = \'Power Users\' OR user_group.name = \'Remote Desktop Users\' OR user_group.name = \'wheel\' OR user_group.name = \'sudo\') AND user_group.members > \'\' GROUP BY devices.id, user_group.name ORDER BY devices.name

+ +

Database Schema

+

The database schema can be found in the application if the user has database::read permission by going to menu: Admin -> Database -> List Tables, then clicking on the details button for the table. Device details are stored in the devices table.

+ +

Examples

+

Note - The SQL queries used in Open-AudIT require the use of the backtick - ` character and NOT the standard single quote for fields. On most US Windows keyboards the backtick key is located in the top-left of the keyboard along with the tilde ~. On a US Mac keyboard the backtick key is located next to the SHIFT key. The standard single quote is still used to enclose values as the examples below illustrate.

+ +

The Elevated User query

+

SELECT devices.id AS `devices.id`, devices.icon AS `devices.icon`, devices.type AS `devices.type`, devices.name AS `devices.name`, devices.domain AS `devices.domain`, devices.ip AS `devices.ip`, user_group.name as `user_group.name`, user_group.members AS `user_group.members` FROM user_group LEFT JOIN devices ON (user_group.device_id = devices.id AND user_group.current = \'y\') WHERE @filter AND (user_group.name = \'Administrators\' OR user_group.name = \'Power Users\' OR user_group.name = \'Remote Desktop Users\' OR user_group.name = \'wheel\' OR user_group.name = \'sudo\') AND user_group.members > \'\' GROUP BY devices.id, user_group.name ORDER BY devices.name

+
+ +

Devices Older Than X

+

This example query retrieves a list of devices OVER 3 years old. The query uses today NOW() and devices.purchase_date as the reference point and filters out all virtual machines via a check of the system.serial field for %VM%.

+

SELECT devices.id AS `devices.id`, devices.purchase_date AS `devices.purchase_date`, devices.type AS `devices.type`, devices.name AS `devices.name`, devices.last_seen AS `devices.last_seen`, devices.manufacturer AS `devices.manufacturer`, devices.model AS `devices.model`, devices.description AS `devices.description`, devices.function AS `devices.function`, locations.name AS `locations.name` FROM devices LEFT JOIN locations ON (devices.location_id = locations.id) LEFT JOIN windows ON (devices.id = windows.device_id AND windows.current = \'y\') LEFT JOIN orgs ON (devices.org_id = orgs.id) WHERE @filter AND devices.purchase_date < DATE_SUB(NOW(),INTERVAL 3 YEAR) AND devices.serial NOT LIKE \'%VM%\'

+
+ +

Devices with Expired Warranties

+

This example uses devices.warranty_expires and looks for a warranty expiration date prior to today.

+

SELECT devices.id AS `devices.id`, devices.warranty_expires AS `devices.warranty_expires`, devices.type AS `devices.type`, devices.name AS `devices.name`, devices.last_seen AS `devices.last_seen`, devices.manufacturer AS `devices.manufacturer`, devices.model AS `devices.model`, devices.description AS `devices.description`, devices.function AS `devices.function`, locations.name AS `locations.name` FROM devices LEFT JOIN locations ON (devices.location_id = locations.id) LEFT JOIN windows ON (devices.id = windows.device_id AND windows.current = \'y\') LEFT JOIN orgs ON (devices.org_id = orgs.id) WHERE @filter AND devices.warranty_expires <= CURDATE() AND devices.serial NOT LIKE \'%VM%\'

+
+ +

Devices Missing Information

+

This example creates a list of devices where the Function or Description fields are blank OR the Purchase Date is the default.

+

SELECT devices.id AS `devices.id`, devices.ip AS `devices.ip`, devices.name AS `devices.name`, devices.description AS `devices.description`, devices.function AS `devices.function`, devices.purchase_date AS `devices.purchase_date`, devices.type AS `devices.type`, locations.name AS `locations.name` FROM system LEFT JOIN locations ON (devices.location_id = locations.id) WHERE @filter AND devices.purchase_date = \'2000-01-01\' OR devices.function = \'\' OR devices.description = \'\'

+
+ +

List All NMAP Ports, Protocols and Programs for Each Device

+

This example creates a list of devices and the open Ports, Protocols, and Programs found by the NMAP scan.

+

SELECT devices.id AS `devices.id`, devices.type AS `devices.type`, devices.name AS `devices.name`, devices.domain AS `devices.domain`, devices.ip AS `devices.ip`, nmap.first_seen AS `nmap.first_seen`, nmap.last_seen AS `nmap.last_seen`, nmap.port AS `nmap.port`, nmap.protocol AS `nmap.protocol`, nmap.program AS `nmap.program` FROM nmap LEFT JOIN devices ON (nmap.device_id = devices.id) WHERE @filter

+
+ +

Return a list of all Modules installed on Routers

+

This example creates a list of all Modules marked as current=\'y\' on devices of type \'router\'.

+

SELECT devices.id AS `devices.id`, devices.type AS `devices.type`, devices.name AS `devices.name`, devices.manufacturer AS `devices.manufacturer`, devices.model AS `devices.model`, devices.serial AS `devices.serial`, module.description AS `module.description` FROM devices LEFT JOIN module ON (module.device_id = devices.id AND module.current = \'y\') WHERE @filter AND devices.type = \'router\' ORDER BY devices.name

+ '; diff --git a/app/Views/faq/Google Maps API Key.php b/app/Views/faq/Google Maps API Key.php new file mode 100644 index 000000000..a76244813 --- /dev/null +++ b/app/Views/faq/Google Maps API Key.php @@ -0,0 +1,17 @@ +Starting June 2018 Google has implemented a pay-as-you-go pricing model for the Google Maps Platform APIs. Previously, most users with moderate usage could use Google Maps, which are embedded into opCharts and Open-AudIT Professional/Enterprise, for free. Google\'s new policy is outlined here, https://developers.google.com/maps/documentation/javascript/usage-and-billing.
+
+In order to enable Google Maps you will need to a Google API Key follow this link and log in with your Google account, https://cloud.google.com/maps-platform/#get-started.
+
+For more information please see the following guide which includes a video. Use API Keys | Maps JavaScript API | Google Developers.
+
+If you are having issues with Google Maps API keys or your company does not have access to create Google Maps API keys, please contact the FirstWave support team.
+
+

'; + +$body = ''; diff --git a/app/Views/faq/Open-AudIT and Nmap.php b/app/Views/faq/Open-AudIT and Nmap.php new file mode 100644 index 000000000..3e040dd68 --- /dev/null +++ b/app/Views/faq/Open-AudIT and Nmap.php @@ -0,0 +1,47 @@ +Open-AudIT uses Nmap in its Discovery function. Without Nmap, Open-AudIT will not function correctly. Every Open-AudIT install assumes Nmap is installed and will test for it on the Discovery web pages.
+
+

'; + +$body = '

Linux

+

The Linux Open-AudIT installer will test for and if required, install Open-AudIT\'s dependencies from your distributions repository, including setting the Nmap SetUID. This is required for SNMP (UDP 161) detection by a non-root user. This is supported on RedHat/CentOS and Debian/Ubuntu. If you need to manually install Nmap:
+
+For RedHat/CentOS do (NOTE - if you upgrade using yum, you will need to reapply this "chmod" setting).
+sudo yum install nmap
+sudo chmod u+s `which nmap`
+
+
+For Debian/Ubuntu run (including setting dpkg to remember your override so an apt-get upgrade will not break Open-AudIT).
+sudo apt-get install nmap
+sudo chmod u+s `which nmap`
+sudo dpkg-statoverride --list `which nmap`
+
+
+

+

Windows

+

The Windows Open-AudIT installer will test for the presence of Nmap in it\'s standard install locations of:

+
+ +
+
+

+If the binary is not found in either of these locations, a warning message will be displayed in the installer.
+
+To install Nmap on Windows, visit the Nmap page at https://nmap.org/download.html and download the Latest Release self-installer. You may need to scroll down the page to find it.

+Nmap Download +

+Save and run the file. Make sure you run the file as an Administrator in order to install it (right click, Run as Administrator). +

+Nmap Install +

+Use the standard install options when displayed and click the "I Agree", "Next" and "Install" buttons to install Nmap. + +'; diff --git a/app/Views/faq/Running Open-AudIT Apache Service Under Windows.php b/app/Views/faq/Running Open-AudIT Apache Service Under Windows.php new file mode 100644 index 000000000..3b95f7048 --- /dev/null +++ b/app/Views/faq/Running Open-AudIT Apache Service Under Windows.php @@ -0,0 +1,29 @@ + +If you\'re running an Open-AudIT server on Linux, this doesn\'t affect you.
+
+When running Open-AudIT on Windows the Apache service account must be that of a \'regular\' user (or the Administrator). This is because the "Local System" account normally used to run Apache has no access to any network resources. IE - We cannot use Apache when running as the Local System account account to copy the audit script to Windows PCs.
+

+

Fixing the Issue

+

To make the change, just follow the steps below.
+
+Select the Start menu and type "services". Click the Services icon.

+ +

+Next, right click the Apache2.4 service and select Properties, then click the Log On tab.

+ +

+Select the "This Account" checkbox and provide the account name and password.
+
+Next, click OK, then right click the Apache 2.4 service and click Restart. Done!
+
+ + +

'; + +$body = ''; diff --git a/app/Views/help/files.php b/app/Views/help/files.php index 98d605f00..714ed538b 100644 --- a/app/Views/help/files.php +++ b/app/Views/help/files.php @@ -25,4 +25,9 @@ The audit script will use the files[ ] array and retrieve the file details.
If you would like to use the script outside of Discovery we have created another endpoint called "scripts". See the documentation here - Scripts.

'; -$body = '
'; +$body = '

Enabling the Feature Under Windows

+

There is no need to do anything if you\'re running Open-AudIT on a Linux server.
+
+Windows clients are just fine and require no special actions, however.... to enable this feature the audit script must be run locally on the target Windows system. It cannot be run remotely as we do with WMI calls when running the audit script on one Windows machine, while targeting a second Windows machine. To do this we need to copy the audit script to the target Windows machine and then run it. Unfortunately the service account that Apache runs under is the Local System account. This account has no access to remote (network based) resources. To work around this issue the service must be run under another account. It is easiest to just use the local Administrator account, but you can try any account you like as long as it has the required privileges. The Local System account has as much local access as the local Administrator account.
+
+See our page on enabling Running Open-AudIT Apache Service Under Windows

'; diff --git a/app/Views/help/groups.php b/app/Views/help/groups.php index 159c6f7c7..fea0aed0c 100644 --- a/app/Views/help/groups.php +++ b/app/Views/help/groups.php @@ -2,8 +2,8 @@ # Copyright © 2023 FirstWave. All Rights Reserved. # SPDX-License-Identifier: AGPL-3.0-or-later -$intro = '

Groups are used as simple lists of devices that match the required conditions. If requested using JSON they return a list of devices.id\'s only. If requested using the web interface, they return the standard column attribute list.

'; - -$body = '

Creating a SQL Statement for Groups

-

Please see the wiki here.

+$intro = '

Groups are used as simple lists of devices that match the required conditions. If requested using JSON they return a list of devices.id\'s only. If requested using the web interface, they return the standard column attribute list. Groups can be used for Integrations, Baselines and other items.

Creating a SQL Statement for Groups

+

Please see the FAQ here.


'; + +$body = ''; diff --git a/app/Views/help/queries.php b/app/Views/help/queries.php index f9a2a5402..62d45b526 100644 --- a/app/Views/help/queries.php +++ b/app/Views/help/queries.php @@ -5,5 +5,5 @@ $intro = '

Open-AudIT comes with many queries inbuilt. If you require a specific query and none of the pre-packaged queries fit your needs, it\'s quite easy to create a new one and load it into Open-AudIT for running.

'; $body = '

Creating a SQL Statement for Queries

-

Please see the wiki here.

+

Please see the wiki here.


'; diff --git a/app/Views/helpFAQ.php b/app/Views/helpFAQ.php new file mode 100644 index 000000000..1dd9957e4 --- /dev/null +++ b/app/Views/helpFAQ.php @@ -0,0 +1,28 @@ + +
+
+
+
+
+
+
+
+

+
+
+ +
+ +
+ +
+
+
+
+
+
diff --git a/app/Views/helpPrereq.php b/app/Views/helpPrereq.php index 853c8cfd9..17f5d4b62 100644 --- a/app/Views/helpPrereq.php +++ b/app/Views/helpPrereq.php @@ -23,15 +23,7 @@

Nmap

-


Open-AudIT uses Nmap in its Discovery function. Without Nmap, Open-AudIT will not function correctly. Every Open-AudIT install assumes Nmap is installed and will also test for it on the Discovery web pages. More information about Open-AudIT and Nmap is available here - Open-AudIT and Nmap.


-

Windows

-

Nmap is available for Windows, here - https://nmap.org/download.html. All other dependencies are packaged with the Open-AudIT download.
-

-
-

Linux

-

The Linux Open-AudIT installer will test for and if required, install Open-AudIT's dependencies from your distributions repository. After installing you should run the below to SetUID. This is required for SNMP (UDP 161) detection. This is supported on RedHat/CentOS and Debian/Ubuntu. To enable the Apache user to use Nmap to detect port UDP 161, run the below commands:

- For Centos / Redhat: (NOTE - if you upgrade using yum, you will need to reapply this "chmod" setting).

sudo chmod u+s `which nmap`


- For Debian / Ubuntu:

sudo chmod u+s `which nmap`
sudo dpkg-statoverride --list `which nmap`

+


Open-AudIT uses Nmap in its Discovery function. Without Nmap, Open-AudIT will not function correctly. Every Open-AudIT install assumes Nmap is installed and will also test for it on the Discovery web pages. More information about Open-AudIT and Nmap is available here - Open-AudIT and Nmap.


Permissions


Open-AudIT needs specific directory permissions to be able to create files, upload results, etc. Please set as below.


Linux

diff --git a/app/Views/locationsRead.php b/app/Views/locationsRead.php index 18a32f396..d65d03086 100644 --- a/app/Views/locationsRead.php +++ b/app/Views/locationsRead.php @@ -77,7 +77,7 @@
diff --git a/public/images/faq_01.png b/public/images/faq_01.png new file mode 100644 index 000000000..732c070fc Binary files /dev/null and b/public/images/faq_01.png differ diff --git a/public/images/faq_02.png b/public/images/faq_02.png new file mode 100644 index 000000000..a77fe6fd4 Binary files /dev/null and b/public/images/faq_02.png differ diff --git a/public/images/faq_03.png b/public/images/faq_03.png new file mode 100644 index 000000000..38df234cc Binary files /dev/null and b/public/images/faq_03.png differ diff --git a/public/images/faq_04.png b/public/images/faq_04.png new file mode 100644 index 000000000..32b71b69c Binary files /dev/null and b/public/images/faq_04.png differ