-
Notifications
You must be signed in to change notification settings - Fork 27
/
setup.py
280 lines (225 loc) · 8.9 KB
/
setup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
#! /usr/bin/env python2
"""
Setup script for Balbuzard using distutils
Run:
python setup.py install
to install this package.
(this setup script contains parts borrowed from cherrypy)
"""
#--- CHANGELOG ----------------------------------------------------------------
# 2014-02-26 v0.01: - first working version
# 2014-03-23 v0.02: - added doc subfolder
#--- TODO ---------------------------------------------------------------------
# - deploy scripts?
# - version for python 3 using 2to3
#--- IMPORTS ------------------------------------------------------------------
##try:
## from setuptools import setup
##except ImportError:
from distutils.core import setup
from distutils.command.install import INSTALL_SCHEMES
import sys, os, fnmatch
from balbuzard.balbuzard import __version__
#--- METADATA -----------------------------------------------------------------
name = "balbuzard"
version = '0.20'
desc = "Malware analysis tools to extract patterns of interest from files and crack obfuscation such as XOR"
with open('README.md') as readme:
long_desc = readme.read()
author = "Philippe Lagadec"
author_email = "decalage at laposte dot net"
url = "http://www.decalage.info/python/balbuzard"
download_url = "https://bitbucket.org/decalage/balbuzard/downloads"
license = "BSD"
classifiers=[
"Development Status :: 3 - Alpha",
"Intended Audience :: Information Technology",
"Intended Audience :: Science/Research",
"Intended Audience :: System Administrators",
"License :: OSI Approved :: BSD License",
"Operating System :: OS Independent",
"Programming Language :: Python",
"Programming Language :: Python :: 2",
# "Programming Language :: Python :: 3",
"Topic :: Security",
]
#--- PACKAGES -----------------------------------------------------------------
packages=[
"balbuzard",
'balbuzard.thirdparty',
'balbuzard.thirdparty.magic',
]
##setupdir = '.'
##package_dir={'': setupdir}
#--- PACKAGE DATA -------------------------------------------------------------
## Often, additional files need to be installed into a package. These files are
## often data that?s closely related to the package?s implementation, or text
## files containing documentation that might be of interest to programmers using
## the package. These files are called package data.
##
## Package data can be added to packages using the package_data keyword argument
## to the setup() function. The value must be a mapping from package name to a
## list of relative path names that should be copied into the package. The paths
## are interpreted as relative to the directory containing the package
## (information from the package_dir mapping is used if appropriate); that is,
## the files are expected to be part of the package in the source directories.
## They may contain glob patterns as well.
##
## The path names may contain directory portions; any necessary directories will
## be created in the installation.
# the following functions are used to dynamically include package data without
# listing every file here:
def riglob(top, prefix='', pattern='*'):
"""
recursive iterator glob
- top: path to start searching from
- prefix: path to use instead of top when generating file path (in order to
choose the root of relative paths)
- pattern: wilcards to select files (same syntax as fnmatch)
Yields each file found in top and subdirectories, matching pattern
"""
#print 'top=%s prefix=%s pat=%s' % (top, prefix, pattern)
dirs = []
for path in os.listdir(top):
p = os.path.join(top, path)
if os.path.isdir(p):
dirs.append(path)
elif os.path.isfile(p):
#print ' - file:', path
if fnmatch.fnmatch(path, pattern):
yield os.path.join(prefix, path)
#print ' dirs =', dirs
for d in dirs:
dtop = os.path.join(top, d)
dprefix = os.path.join(prefix, d)
#print 'dtop=%s dprefix=%s' % (dtop, dprefix)
for p in riglob(dtop, dprefix, pattern):
yield p
def rglob(top, prefix='', pattern='*'):
"""
recursive glob
Same as riglob, but returns a list.
"""
return list(riglob(top, prefix, pattern))
package_data={
'balbuzard': [
'README.txt',
'README.html',
]
+ rglob('balbuzard/plugins', 'plugins', '*')
+ rglob('balbuzard/doc', 'doc', '*.html')
+ rglob('balbuzard/doc', 'doc', '*.md')
+ rglob('balbuzard/samples', 'samples', '*'),
'balbuzard.thirdparty.magic': [
'LICENSE.txt',
]
}
#--- data files ---------------------------------------------------------------
# not used for now.
## The data_files option can be used to specify additional files needed by the
## module distribution: configuration files, message catalogs, data files,
## anything which doesn?t fit in the previous categories.
##
## data_files specifies a sequence of (directory, files) pairs in the following way:
##
## setup(...,
## data_files=[('bitmaps', ['bm/b1.gif', 'bm/b2.gif']),
## ('config', ['cfg/data.cfg']),
## ('/etc/init.d', ['init-script'])]
## )
##
## Note that you can specify the directory names where the data files will be
## installed, but you cannot rename the data files themselves.
##
## Each (directory, files) pair in the sequence specifies the installation
## directory and the files to install there. If directory is a relative path,
## it is interpreted relative to the installation prefix (Python?s sys.prefix for
## pure-Python packages, sys.exec_prefix for packages that contain extension
## modules). Each file name in files is interpreted relative to the setup.py
## script at the top of the package source distribution. No directory information
## from files is used to determine the final location of the installed file;
## only the name of the file is used.
##
## You can specify the data_files options as a simple sequence of files without
## specifying a target directory, but this is not recommended, and the install
## command will print a warning in this case. To install data files directly in
## the target directory, an empty string should be given as the directory.
##data_files=[
## ('balbuzard', [
## 'balbuzard/README.txt',
## ]),
##]
##if sys.version_info >= (3, 0):
## required_python_version = '3.0'
## setupdir = 'py3'
##else:
## required_python_version = '2.3'
## setupdir = 'py2'
##data_files = [(install_dir, ['%s/%s' % (setupdir, f) for f in files])
## for install_dir, files in data_files]
##def fix_data_files(data_files):
## """
## bdist_wininst seems to have a bug about where it installs data files.
## I found a fix the django team used to work around the problem at
## http://code.djangoproject.com/changeset/8313 . This function
## re-implements that solution.
## Also see http://mail.python.org/pipermail/distutils-sig/2004-August/004134.html
## for more info.
## """
## def fix_dest_path(path):
## return '\\PURELIB\\%(path)s' % vars()
##
## if not 'bdist_wininst' in sys.argv: return
##
## data_files[:] = [
## (fix_dest_path(path), files)
## for path, files in data_files]
##fix_data_files(data_files)
#--- SCRIPTS ------------------------------------------------------------------
# not used for now.
#scripts = ["%s/cherrypy/cherryd" % setupdir]
# --- ENTRY POINTS ------------------------------------------------------------
# Entry points to create convenient scripts automatically
entry_points = {
'console_scripts': [
'balbuzard=balbuzard.balbuzard:main',
'bbcrack=balbuzard.bbcrack:main',
'bbharvest=balbuzard.bbharvest:main',
'bbtrans=balbuzard.bbtrans:main',
],
}
#=== MAIN =====================================================================
def main():
if sys.version >= '3.0':
s = "Sorry, %s %s requires Python 2.x."
print(s % (name, version))
sys.exit(1)
## if sys.version < required_python_version:
## s = "I'm sorry, but %s %s requires Python %s or later."
## print(s % (name, version, required_python_version))
## sys.exit(1)
## # set default location for "data_files" to
## # platform specific "site-packages" location
## for scheme in list(INSTALL_SCHEMES.values()):
## scheme['data'] = scheme['purelib']
dist = setup(
name=name,
version=version,
description=desc,
long_description=long_desc,
long_description_content_type="text/markdown",
classifiers=classifiers,
author=author,
# author_email=author_email,
url=url,
license=license,
## package_dir=package_dir,
packages=packages,
package_data = package_data,
download_url=download_url,
# data_files=data_files,
# scripts=scripts,
entry_points=entry_points,
)
if __name__ == "__main__":
main()