Add output spec

bug/bundler_fix
Meatballs 2014-05-05 14:48:18 +01:00
parent 589d235a80
commit 162b6a8ab9
No known key found for this signature in database
GPG Key ID: 5380EAF01F2F8B38
2 changed files with 131 additions and 10 deletions

View File

@ -35,7 +35,8 @@ module Powershell
code.split(/\r\n|\n/).each_with_index do |line,idx|
numbered << "#{idx}: #{line}"
end
return numbered
numbered
end
#
@ -119,14 +120,10 @@ module Powershell
#
# @param eof [String] End of file identifier to append to code
# @param gzip [Boolean] Whether to use gzip compression or deflate
# @param in_place [Boolean] Whether to update the current script
# code or just return the output.
#
# @return [String] Compressed code wrapped in decompression stub
def compress_code(eof = nil, gzip = true, in_place = true)
code = gzip ? gzip_code(eof) : deflate_code(eof)
@code = code if in_place
return code
def compress_code(eof = nil, gzip = true)
@code = gzip ? gzip_code(eof) : deflate_code(eof)
end
#
@ -138,9 +135,18 @@ module Powershell
# Extract substring with payload
encoded_stream = @code.scan(/FromBase64String\('(.*)'/).flatten.first
# Decode and decompress the string
@code = ( Rex::Text.ungzip( Rex::Text.decode_base64(encoded_stream) ) ||
Rex::Text.zlib_inflate( Rex::Text.decode_base64(encoded_stream)) )
return code
unencoded = Rex::Text.decode_base64(encoded_stream)
begin
@code = Rex::Text.ungzip(unencoded) || Rex::Text.zlib_inflate(unencoded)
rescue Zlib::GzipFile::Error
begin
@code = Rex::Text.zlib_inflate(unencoded)
rescue Zlib::DataError => e
raise RuntimeError, "Invalid compression"
end
end
@code
end
end

View File

@ -0,0 +1,115 @@
# -*- coding:binary -*-
require 'spec_helper'
require 'rex/exploitation/powershell'
describe Rex::Exploitation::Powershell::Output do
let(:example_script) do
Rex::Text.rand_text_alpha(400)
end
let(:subject) do
Rex::Exploitation::Powershell::Script.new(example_script)
end
let(:eof) do
Rex::Text.rand_text_alpha(10)
end
describe "::to_s" do
it 'should print the script' do
subject.to_s.should eq example_script
end
end
describe "::size" do
it 'should return the size of the script' do
subject.size.should eq example_script.size
end
end
describe "::to_s_lineno" do
it 'should print the script with line numbers' do
subject.to_s_lineno.should eq "0: #{example_script}"
end
end
describe "::deflate_code" do
it 'should zlib the code and wrap in powershell in uncompression stub' do
compressed = subject.deflate_code
compressed.include?('IO.Compression.DeflateStream').should be_true
compressed =~ /FromBase64String\('([A-Za-z0-9\/+=]+)'\)/
$1.size.should be < Rex::Text.encode_base64(example_script).size
compressed.should eq subject.code
end
it 'should append an eof marker if specified' do
compressed = subject.deflate_code(eof)
compressed.include?("echo '#{eof}';").should be_true
end
end
describe "::encode_code" do
it 'should base64 encode the code' do
encoded = subject.encode_code
encoded.should eq subject.code
encoded =~ /^([A-Za-z0-9\/+=]+)$/
$1.size.should eq encoded.size
end
end
describe "::gzip_code" do
it 'should gzip the code and wrap in powershell in uncompression stub' do
compressed = subject.gzip_code
compressed.include?('IO.Compression.GzipStream').should be_true
compressed =~ /FromBase64String\('([A-Za-z0-9\/+=]+)'\)/
$1.size.should be < Rex::Text.encode_base64(example_script).size
compressed.should eq subject.code
end
it 'should append an eof marker if specified' do
compressed = subject.gzip_code(eof)
compressed.include?("echo '#{eof}';").should be_true
end
end
describe "::compress_code" do
it 'should gzip by default' do
compressed = subject.compress_code
compressed.include?('IO.Compression.GzipStream').should be_true
end
it 'should deflate if gzip is false' do
compressed = subject.compress_code(nil,false)
compressed.include?('IO.Compression.DeflateStream').should be_true
end
it 'should append an eof' do
compressed = subject.compress_code(eof)
compressed.include?("echo '#{eof}';").should be_true
end
end
describe "::decompress_code" do
it 'should locate the base64 string and decompress it when deflate is used' do
compressed = subject.compress_code(nil, false)
decompressed = subject.decompress_code
decompressed.should eq example_script
end
it 'should locate the base64 string and decompress it when gzip is used' do
compressed = subject.compress_code
decompressed = subject.decompress_code
decompressed.should eq example_script
end
it 'should raise a RuntimeException if the Base64 string is not compressed/corrupted' do
corrupted = "FromBase64String('parp')"
subject.code = corrupted
expect { subject.decompress_code }.to raise_error(RuntimeError)
subject.code.should eq corrupted
end
end
end