summaryrefslogblamecommitdiffstats
path: root/sploit/main.py
blob: 0bc799edaeab1fc0610b945ac77b147241abf6bf (plain) (tree)
1
2
3

               
                












                                                                                              



                                                              
                                            
             





                                   


                                           
                                                 
                    




                                     
                                           




                                     


                                     
                                     
 
                           
                                      
                                             
 
                            

                              
                             
                  
 
import argparse
import tempfile
import traceback

from sploit.comm import *

def main():
    parser = argparse.ArgumentParser(description='Execute Sploit Script Against Target')
    parser.add_argument('-d', '--daemon', action='store_true',
                        help='run in "daemon" mode with pipes instead of a designated target')
    parser.add_argument('script',
                        help='exploit script to run')
    parser.add_argument('target', nargs=argparse.REMAINDER,
                        help='target program to exploit')
    args = parser.parse_args()

    try:
        if(len(args.target)>0):
            if(args.daemon):
                print("Target Given. Ignoring Daemon Flag...")
            target(args.script, args.target)
        else:
            if(args.daemon):
                daemon(args.script)
            else:
                pipe(args.script)
    except KeyboardInterrupt:
        pass

def daemon(script):
    print("Running in Pipe Daemon Mode...")
    with tempfile.TemporaryDirectory() as tmpdir:
        while(True):
            try:
                p = Pipes(tmpdir)
            except KeyboardInterrupt:
                break
            try:
                runscript(script, Comm(p));
            except KeyboardInterrupt:
                pass
            except:
                traceback.print_exc()
            del p

def pipe(script):
    print("Running in Pipe Mode...");
    runscript(script, Comm(Pipes()));

def target(script, target):
    print("Running in Target Mode...")
    runscript(script, Comm(Process(target)));

def runscript(script, comm):
    print("Running Script...")
    exec(open(script).read())
    print("Script Finished!")
    comm.readall()