Online Food Ordering System v1.0 - Multiple Unauthenticated SQL Injections (SQLi)

Summary

NameOnline Food Ordering System v1.0 - Multiple Unauthenticated SQL Injections (SQLi)
Code nameHann
ProductOnline Food Ordering System
VendorProjectworlds Pvt. Limited
Affected versionsVersion 1.0
StatePublic
Release date2023-11-01

Vulnerabilities

KindUnauthenticated SQL Injections (SQLi)
Rule146. SQL Injection
RemoteYes
CVSSv3 VectorCVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
CVSSv3 Base Score9.8
Exploit availableYes
CVE ID(s)CVE-2023-45323, CVE-2023-45325, CVE-2023-45334, CVE-2023-45336, CVE-2023-45338, CVE-2023-45340, CVE-2023-45341, CVE-2023-45342, CVE-2023-45343, CVE-2023-45344, CVE-2023-45345, CVE-2023-45346, CVE-2023-45347

Description

Online Food Ordering System v1.0 is vulnerable to multiple Unauthenticated SQL Injection vulnerabilities.

Vulnerabilities

CVE-2023-45323

The 'name' parameter of the routers/add-item.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

$name = $_POST['name']; $price = $_POST['price']; $sql = "INSERT INTO items (name, price) VALUES ('$name', $price)"; $con->query($sql);

CVE-2023-45325

The 'address' parameter of the routers/add-users.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

$username = $_POST['username']; $password = $_POST['password']; $name = $_POST['name']; $email = $_POST['email']; $contact = $_POST['contact']; $address = $_POST['address']; $role = $_POST['role']; $verified = $_POST['verified']; $deleted = $_POST['deleted']; $sql = "INSERT INTO users (username, password, name, email, contact, address, role, verified, deleted) VALUES ('$username', '$password', '$name', '$email', $contact, '$address', '$role', $verified, $deleted)"; if($con->query($sql)==true)

CVE-2023-45334

The 'status' parameter of the routers/edit-orders.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

$status = $_POST['status']; $id = $_POST['id']; $sql = "UPDATE orders SET status='$status' WHERE id=$id;"; $con->query($sql);

CVE-2023-45336

The 'password' parameter of the routers/router.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

$username = $_POST['username'];
$password = $_POST['password'];

$result = mysqli_query($con, "SELECT * FROM users WHERE username='$username' AND password='$password' AND role='Administrator' AND not deleted;");

CVE-2023-45338

The 'id' parameter of the routers/add-ticket.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

$type = $_POST['type'];
$user_id = $_POST['id'];
if($type != ''){
    $sql = "INSERT INTO tickets (poster_id, subject, description, type) VALUES ($user_id, '$subject', '$description', '$type')";

CVE-2023-45340

The 'phone' parameter of the routers/details-router.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

$phone = $_POST['phone'];
$email = htmlspecialchars($_POST['email']);
$address = htmlspecialchars($_POST['address']);
$sql = "UPDATE users SET name = '$name', username = '$username', password='$password', contact=$phone, email='$email', address='$address' WHERE id = $user_id;";

CVE-2023-45341

The '*_price' parameter of the routers/menu-router.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

if(preg_match("/[0-9]+_price/",$key)){ $key = strtok($key, '_'); $sql = "UPDATE items SET price = $value WHERE id = $key;"; $con->query($sql);
}

CVE-2023-45342

The 'phone' parameter of the routers/register-router.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

$phone = $_POST['phone']; $sql = "INSERT INTO users (name, username, password, contact) VALUES ('$name', '$username', '$password', $phone);"; if($con->query($sql)==true)

CVE-2023-45343

The 'ticket_id' parameter of the routers/ticket-message.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

$ticket_id = $_POST['ticket_id']; $role = $_POST['role']; if($role == 'Administrator'){ $sql = "UPDATE tickets SET status = 'Answered' WHERE id=$ticket_id;"; $con->query($sql);
}

CVE-2023-45344

The '*_balance' parameter of the routers/user-router.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

if(preg_match("/[0-9]+_balance/",$key)){ $key = strtok($key, '_'); $result = mysqli_query($con,"SELECT * from wallet WHERE customer_id = $key;"); if($row = mysqli_fetch_array($result)){ $wallet_id = $row['id']; $sql = "UPDATE wallet_details SET balance = '$value' WHERE wallet_id = $wallet_id;"; $con->query($sql);
    }
}

CVE-2023-45345

The '*_deleted' parameter of the routers/user-router.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

if(preg_match("/[0-9]+_deleted/",$key)){ $key = strtok($key, '_'); $sql = "UPDATE users SET deleted = '$value' WHERE id = $key;"; $con->query($sql);
}

CVE-2023-45346

The '*_role' parameter of the routers/user-router.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

if(preg_match("/[0-9]+_role/",$key)){ $key = strtok($key, '_'); $sql = "UPDATE users SET role = '$value' WHERE id = $key;"; $con->query($sql);
}

CVE-2023-45347

The '*_verified' parameter of the routers/user-router.php resource does not validate the characters received and they are sent unfiltered to the database. The vulnerable code is:

if(preg_match("/[0-9]+_verified/",$key)){ $key = strtok($key, '_'); $sql = "UPDATE users SET verified = '$value' WHERE id = $key;"; $con->query($sql);
}

Our security policy

We have reserved the IDs CVE-2023-45323, CVE-2023-45325, CVE-2023-45334, CVE-2023-45336, CVE-2023-45338, CVE-2023-45340, CVE-2023-45341, CVE-2023-45342, CVE-2023-45343, CVE-2023-45344, CVE-2023-45345, CVE-2023-45346 and CVE-2023-45347 to refer to these issues from now on.

System Information

  • Version: Online Food Ordering System v1.0
  • Operating System: Any

Mitigation

There is currently no patch available for this vulnerability.

Credits

The vulnerability was discovered by Andres Roldan from Fluid Attacks' Offensive Team.

References

Vendor page https://projectworlds.in/

Timeline

Time-lapse-logo

2023-10-06

Vulnerability discovered.

Time-lapse-logo

2023-10-06

Vendor contacted.

Time-lapse-logo

2023-11-01

Public Disclosure.

Fluid Logo Footer

Hacking software for over 20 years

Fluid Attacks tests applications and other systems, covering all software development stages. Our team assists clients in quickly identifying and managing vulnerabilities to reduce the risk of incidents and deploy secure technology.

Copyright © 0 Fluid Attacks. We hack your software. All rights reserved.