header-logo
Suggest Exploit
vendor:
LibreNMS
by:
Punt
7.5
CVSS
HIGH
SQL Injection
89
CWE
Product Name: LibreNMS
Affected Version From: 1.46 and less
Affected Version To: 1.46 and less
Patch Exists: YES
Related CWE: N/A
CPE: N/A
Metasploit: N/A
Other Scripts: N/A
Platforms Tested: Linux and Windows
2019

LibreNMS 1.46 – ‘search’ SQL Injection

Vulnerable script /html/ajax_serarch.php contains a search parameter $search = mres($_REQUEST['search']); which accepts a user input using $_REQUEST['']. The mres() fuction is located under /includes/common.php and calls the mysqli_real_escape_string() which can be bypassed by '%'. The POC involves logging into LibreNMS and going to /ajax_search.php?search=%27&type=group or /ajax_search.php?search=%27&type=alert-rules which will result in an SQL syntax error.

Mitigation:

The Librenms team have applied a patch.
Source

Exploit-DB raw data:

# Exploit Title: LibreNMS 1.46 - 'search' SQL Injection
# Google Dork:unknown
# Date: 2019-09-01
# Exploit Author: Punt
# Vendor Homepage: https://www.librenms.org
# Software Link: https://www.librenms.org 
# Version:1.46 and less
# Tested on:Linux and Windows
# CVE: N/A 

#Affected Device: more than 4k found on Shodan and Censys. 

#Description about the bug
Vunlerable script /html/ajax_serarch.php

if (isset($_REQUEST['search'])) {
    $search = mres($_REQUEST['search']);
    header('Content-type: application/json');
    if (strlen($search) > 0) {
        $found = 0;

        if ($_REQUEST['type'] == 'group') {
            include_once '../includes/device-groups.inc.php';
            foreach (dbFetchRows("SELECT id,name FROM device_groups WHERE name LIKE '%".$search."%'") as $group) {
                if ($_REQUEST['map']) {
                    $results[] = array(
                        'name'     => 'g:'.$group['name'],
                        'group_id' => $group['id'],


as you can there is a search parameter $search = mres($_REQUEST['search']); which accepts a user input using $_REQUEST['']

dbFetchRows() used to exectute sql query

now lets check the mres() function 

the mres() fuction is located under /includes/common.php

function mres($string)
{
    return $string; // 
    global $database_link;
    return mysqli_real_escape_string($database_link, $string);

as you can see the mres() function call's the mysqli_real_escape_string() which can be bypassed by '%'                    


#POC:
1st lgoin to your LibreNMS
2nd go to this /ajax_search.php?search=%27&type=group or /ajax_search.php?search=%27&type=alert-rules 
3rd you will see an sql syntax error 

The Librenms team have applyed a patch .
Thanks
Punt (From Ethiopia)