mirror of
https://github.com/rapid7/metasploit-payloads
synced 2025-02-22 03:19:04 +01:00
162 lines
4.0 KiB
Ruby
162 lines
4.0 KiB
Ruby
require "bundler/gem_tasks"
|
|
require 'openssl'
|
|
require 'metasploit-payloads/crypto'
|
|
|
|
c_source = "../c/meterpreter/"
|
|
java_source = "../java"
|
|
php_source = "../php/meterpreter/"
|
|
python_source = "../python/meterpreter/"
|
|
dest = "./data"
|
|
meterpreter_dest = "./data/meterpreter"
|
|
android_dest = "./data/android"
|
|
java_dest = "./data/java"
|
|
manifest_file = './manifest'
|
|
manifest_uuid_file = './manifest.uuid'
|
|
manifest_hash_type = 'SHA3-256'
|
|
|
|
platform_config = {
|
|
:windows => {
|
|
:sources => [
|
|
"../c/meterpreter/output"
|
|
],
|
|
:extensions => [
|
|
"dll"
|
|
]
|
|
},
|
|
:java_meterpreter => {
|
|
:sources => [
|
|
"../java/output/data/meterpreter"
|
|
],
|
|
:extensions => [
|
|
"jar"
|
|
],
|
|
},
|
|
:java_output => {
|
|
:sources => [
|
|
"../java/output/data/java"
|
|
],
|
|
:extensions => [
|
|
"class"
|
|
]
|
|
},
|
|
:android => {
|
|
:sources => [
|
|
"../java/output/data/android"
|
|
],
|
|
:extensions => [
|
|
"jar",
|
|
"dex",
|
|
"xml",
|
|
"arsc"
|
|
]
|
|
},
|
|
:php => {
|
|
:sources => [
|
|
php_source
|
|
],
|
|
:extensions => [
|
|
"php"
|
|
]
|
|
},
|
|
:python => {
|
|
:sources => [
|
|
python_source
|
|
],
|
|
:extensions => [
|
|
"py"
|
|
]
|
|
}
|
|
}
|
|
|
|
def copy_files(cnf, meterpreter_dest)
|
|
cnf[:sources].each do |f|
|
|
cnf[:extensions].each do |ext|
|
|
Dir.glob("#{f}/**/*.#{ext}").each do |bin|
|
|
f_path = ::Pathname.new(f)
|
|
bin_path = ::Pathname.new(bin)
|
|
target = File.join(meterpreter_dest, bin_path.relative_path_from(f_path))
|
|
print("Copying: #{bin} -> #{target}\n")
|
|
contents = ::File.binread(bin_path)
|
|
encrypted_contents = ::MetasploitPayloads::Crypto.encrypt(plaintext: contents)
|
|
output = ::Pathname.new(::File.expand_path(target))
|
|
::FileUtils.mkdir_p(output.dirname) unless output.dirname.exist?
|
|
::File.binwrite(output, encrypted_contents)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
task :create_dir do
|
|
Dir.mkdir(dest) unless Dir.exist?(dest)
|
|
Dir.mkdir(meterpreter_dest) unless Dir.exist?(meterpreter_dest)
|
|
Dir.mkdir(java_dest) unless Dir.exist?(java_dest)
|
|
Dir.mkdir(android_dest) unless Dir.exist?(android_dest)
|
|
end
|
|
|
|
task :win_compile do
|
|
Dir.chdir(c_source) do
|
|
system('cmd.exe /c make.bat')
|
|
end
|
|
end
|
|
|
|
task :java_compile do
|
|
Dir.chdir(java_source) do
|
|
system('mvn package -Ddeploy.path=output -Dandroid.sdk.path=$ANDROID_HOME -Dandroid.ndk.path=$ANDROID_NDK_HOME -Dandroid.release=true -q -P deploy')
|
|
end
|
|
end
|
|
|
|
task :win_copy do
|
|
copy_files(platform_config[:windows], meterpreter_dest)
|
|
end
|
|
|
|
task :java_copy do
|
|
copy_files(platform_config[:java_meterpreter], meterpreter_dest)
|
|
copy_files(platform_config[:java_output], java_dest)
|
|
copy_files(platform_config[:android], android_dest)
|
|
end
|
|
|
|
task :php_copy do
|
|
copy_files(platform_config[:php], meterpreter_dest)
|
|
end
|
|
|
|
task :python_copy do
|
|
copy_files(platform_config[:python], meterpreter_dest)
|
|
end
|
|
|
|
task :create_manifest do
|
|
all_data_files = ::Dir.glob(dest + '/**/*').select { |f| ::File.file?(f) }.sort
|
|
manifest = all_data_files.map { |f| [f, manifest_hash_type, ::OpenSSL::Digest.new(manifest_hash_type, ::File.binread(f))].join(':') }
|
|
::File.binwrite(manifest_file, manifest.join("\n"))
|
|
::File.binwrite(manifest_uuid_file, ::OpenSSL::Digest.new(manifest_hash_type, ::File.binread(manifest_file)))
|
|
end
|
|
|
|
task :win_prep => [:create_dir, :win_compile, :win_copy, :create_manifest] do
|
|
end
|
|
|
|
task :java_prep => [:create_dir, :java_compile, :java_copy] do
|
|
end
|
|
|
|
task :php_prep => [:create_dir, :php_copy] do
|
|
end
|
|
|
|
task :python_prep => [:create_dir, :python_copy] do
|
|
end
|
|
|
|
task :default => [:python_prep, :php_prep, :java_prep, :create_manifest] do
|
|
end
|
|
|
|
# Override tag_version in bundler-#.#.#/lib/bundler/gem_helper.rb to force signed tags
|
|
module Bundler
|
|
class GemHelper
|
|
def tag_version
|
|
sh "git tag -m \"Version #{version}\" -s #{version_tag}"
|
|
Bundler.ui.confirm "Tagged #{version_tag}."
|
|
yield if block_given?
|
|
rescue
|
|
Bundler.ui.error "Untagging #{version_tag} due to error."
|
|
sh_with_code "git tag -d #{version_tag}"
|
|
raise
|
|
end
|
|
end
|
|
end
|