summaryrefslogblamecommitdiffstats
path: root/sploit/__main__.py
blob: 5d53ca6338762d125f049e73482bda9f3de0eaed (plain) (tree)















































                                                                                                                                                  







                                                             



                                                           
                                    















                                                         
from argparse import ArgumentParser, REMAINDER
import gc
from os.path import isdir
import tempfile
import traceback

from sploit.comm.comm import *
from sploit.util.log import *
from sploit import __version__

def print_banner(color, line1=__version__, line2='', line3=''):
    ilog()
    ilog(' ░▒█▀▀▀█░▒█▀▀█░▒█░░░░▒█▀▀▀█░▀█▀░▀▀█▀▀    ', end='', color=ALT)
    ilog(line1, color=ALT)
    ilog(' ░░▀▀▀▄▄░▒█▄▄█░▒█░░░░▒█░░▒█░▒█░░░▒█░░    ', end='', color=color)
    ilog(line2, color=ALT)
    ilog(' ░▒█▄▄▄█░▒█░░░░▒█▄▄█░▒█▄▄▄█░▄█▄░░▒█░░    ', end='', color=ALT)
    ilog(line3, color=ALT)
    ilog()

def main():
    parser = ArgumentParser(description='Execute Sploit script against target')
    parser.add_argument('script', help='Exploit script to run')
    parser.add_argument('target', nargs=REMAINDER, help='Target cmdline or pipes directory')
    args = parser.parse_args()

    if len(args.target) == 0:
        with tempfile.TemporaryDirectory() as tmpdir:
            pipe(args.script, tmpdir)
    elif len(args.target) == 1 and isdir(args.target[0]):
        pipe(args.script, args.target[0])
    else:
        target(args.script, args.target)

def pipe(script, tmpdir):
    print_banner(ERROR, line3='Pipe Mode')
    while True:
        try:
            p = Pipes(tmpdir)
        except KeyboardInterrupt:
            break
        runscript(script, Comm(p))
        del p

def target(script, target):
    print_banner(STATUS, line3='Subprocess Mode')
    runscript(script, Comm(Process(target)))

def user_scope(comm):
    import sploit as lib
    scope = { name: getattr(lib, name) for name in dir(lib) }
    scope['__version__'] = __version__
    scope['print'] = elog
    scope['io'] = comm
    return scope

def runscript(script, comm):
    try:
        ilog("Running Script...")
        code = compile(open(script).read(), script, 'exec')
        exec(code, user_scope(comm))
        ilog("Script Finished!")
        return
    except KeyboardInterrupt:
        pass
    except:
        ilog(traceback.format_exc(), end='', color=ERROR)
    finally:
        comm.shutdown()
        comm.readall()
        gc.collect()

    ilog("Script Ended Early!", color=WARNING)


if __name__ == "__main__":
    main()