tlspretense 0.6.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (81) hide show
  1. data/.document +6 -0
  2. data/.gitignore +7 -0
  3. data/.rspec +1 -0
  4. data/Gemfile +2 -0
  5. data/Gemfile.lock +41 -0
  6. data/LICENSE.txt +20 -0
  7. data/README.rdoc +231 -0
  8. data/Rakefile +44 -0
  9. data/bin/makeder.sh +6 -0
  10. data/bin/tlspretense +7 -0
  11. data/bin/view.sh +3 -0
  12. data/doc/general_setup.rdoc +288 -0
  13. data/doc/linux_setup.rdoc +64 -0
  14. data/lib/certmaker.rb +61 -0
  15. data/lib/certmaker/certificate_factory.rb +106 -0
  16. data/lib/certmaker/certificate_suite_generator.rb +120 -0
  17. data/lib/certmaker/ext_core/hash_indifferent_fetch.rb +12 -0
  18. data/lib/certmaker/runner.rb +27 -0
  19. data/lib/certmaker/tasks.rb +20 -0
  20. data/lib/packetthief.rb +167 -0
  21. data/lib/packetthief/handlers.rb +14 -0
  22. data/lib/packetthief/handlers/abstract_ssl_handler.rb +249 -0
  23. data/lib/packetthief/handlers/proxy_redirector.rb +26 -0
  24. data/lib/packetthief/handlers/ssl_client.rb +87 -0
  25. data/lib/packetthief/handlers/ssl_server.rb +174 -0
  26. data/lib/packetthief/handlers/ssl_smart_proxy.rb +143 -0
  27. data/lib/packetthief/handlers/ssl_transparent_proxy.rb +225 -0
  28. data/lib/packetthief/handlers/transparent_proxy.rb +183 -0
  29. data/lib/packetthief/impl.rb +11 -0
  30. data/lib/packetthief/impl/ipfw.rb +140 -0
  31. data/lib/packetthief/impl/manual.rb +54 -0
  32. data/lib/packetthief/impl/netfilter.rb +109 -0
  33. data/lib/packetthief/impl/pf_divert.rb +168 -0
  34. data/lib/packetthief/impl/pf_rdr.rb +192 -0
  35. data/lib/packetthief/logging.rb +49 -0
  36. data/lib/packetthief/redirect_rule.rb +29 -0
  37. data/lib/packetthief/util.rb +36 -0
  38. data/lib/ssl_test.rb +21 -0
  39. data/lib/ssl_test/app_context.rb +17 -0
  40. data/lib/ssl_test/certificate_manager.rb +33 -0
  41. data/lib/ssl_test/config.rb +79 -0
  42. data/lib/ssl_test/ext_core/io_raw_input.rb +31 -0
  43. data/lib/ssl_test/input_handler.rb +35 -0
  44. data/lib/ssl_test/runner.rb +110 -0
  45. data/lib/ssl_test/runner_options.rb +68 -0
  46. data/lib/ssl_test/ssl_test_case.rb +46 -0
  47. data/lib/ssl_test/ssl_test_report.rb +24 -0
  48. data/lib/ssl_test/ssl_test_result.rb +30 -0
  49. data/lib/ssl_test/test_listener.rb +140 -0
  50. data/lib/ssl_test/test_manager.rb +116 -0
  51. data/lib/tlspretense.rb +13 -0
  52. data/lib/tlspretense/app.rb +52 -0
  53. data/lib/tlspretense/init_runner.rb +115 -0
  54. data/lib/tlspretense/skel/ca/goodcacert.pem +19 -0
  55. data/lib/tlspretense/skel/ca/goodcakey.pem +27 -0
  56. data/lib/tlspretense/skel/config.yml +523 -0
  57. data/lib/tlspretense/version.rb +3 -0
  58. data/packetthief_examples/em_ssl_test.rb +73 -0
  59. data/packetthief_examples/redirector.rb +29 -0
  60. data/packetthief_examples/setup_iptables.sh +24 -0
  61. data/packetthief_examples/ssl_client_simple.rb +27 -0
  62. data/packetthief_examples/ssl_server_simple.rb +44 -0
  63. data/packetthief_examples/ssl_smart_proxy.rb +115 -0
  64. data/packetthief_examples/ssl_transparent_proxy.rb +97 -0
  65. data/packetthief_examples/transparent_proxy.rb +56 -0
  66. data/spec/packetthief/impl/ipfw_spec.rb +98 -0
  67. data/spec/packetthief/impl/manual_spec.rb +65 -0
  68. data/spec/packetthief/impl/netfilter_spec.rb +66 -0
  69. data/spec/packetthief/impl/pf_divert_spec.rb +82 -0
  70. data/spec/packetthief/impl/pf_rdr_spec.rb +133 -0
  71. data/spec/packetthief/logging_spec.rb +78 -0
  72. data/spec/packetthief_spec.rb +47 -0
  73. data/spec/spec_helper.rb +53 -0
  74. data/spec/ssl_test/certificate_manager_spec.rb +222 -0
  75. data/spec/ssl_test/config_spec.rb +76 -0
  76. data/spec/ssl_test/runner_spec.rb +360 -0
  77. data/spec/ssl_test/ssl_test_case_spec.rb +113 -0
  78. data/spec/ssl_test/test_listener_spec.rb +199 -0
  79. data/spec/ssl_test/test_manager_spec.rb +324 -0
  80. data/tlspretense.gemspec +35 -0
  81. metadata +262 -0
@@ -0,0 +1,35 @@
1
+ require './lib/tlspretense/version'
2
+
3
+ Gem::Specification.new do |s|
4
+ s.name = "tlspretense"
5
+ s.version = TLSPretense::VERSION
6
+ s.authors = ["William (B.J.) Snow Orvis"]
7
+ s.email = "bjorvis@isecpartners.com"
8
+ s.date = Time.now.utc.strftime("%Y-%m-%d")
9
+ s.homepage = "https://github.com/iSECPartners/tlspretense"
10
+ s.licenses = ["MIT"]
11
+
12
+ s.summary = "SSL/TLS client testing framework"
13
+ s.description = <<-QUOTE
14
+ TLSPretense provides a set of tools to test SSL/TLS certificate validation.
15
+ It includes a library for generating certificates and a test framework for
16
+ running tests against a client by intercepting client network traffic."
17
+ QUOTE
18
+ s.executables = ["tlspretense"]
19
+ s.files = `git ls-files`.split("\n")
20
+ s.test_files = `git ls-files spec`.split("\n")
21
+ s.require_paths = ["lib"]
22
+ s.extra_rdoc_files = [
23
+ "LICENSE.txt",
24
+ "README.rdoc",
25
+ ] + `git ls-files doc`.split("\n")
26
+
27
+ s.add_runtime_dependency("eventmachine", [">= 1.0.0"])
28
+ s.add_runtime_dependency("ruby-termios", [">= 0.9.6"])
29
+ s.add_development_dependency("rake", [">= 0.8.7"])
30
+ s.add_development_dependency("rspec", ["~> 2.8.0"])
31
+ s.add_development_dependency("rdoc", ["~> 3.12"])
32
+ s.add_development_dependency("bundler", ["~> 1.0"])
33
+ s.add_development_dependency("simplecov", ["~> 0.7"])
34
+ end
35
+
metadata ADDED
@@ -0,0 +1,262 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: tlspretense
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.6.1
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - William (B.J.) Snow Orvis
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2012-12-20 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: eventmachine
16
+ requirement: !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ! '>='
20
+ - !ruby/object:Gem::Version
21
+ version: 1.0.0
22
+ type: :runtime
23
+ prerelease: false
24
+ version_requirements: !ruby/object:Gem::Requirement
25
+ none: false
26
+ requirements:
27
+ - - ! '>='
28
+ - !ruby/object:Gem::Version
29
+ version: 1.0.0
30
+ - !ruby/object:Gem::Dependency
31
+ name: ruby-termios
32
+ requirement: !ruby/object:Gem::Requirement
33
+ none: false
34
+ requirements:
35
+ - - ! '>='
36
+ - !ruby/object:Gem::Version
37
+ version: 0.9.6
38
+ type: :runtime
39
+ prerelease: false
40
+ version_requirements: !ruby/object:Gem::Requirement
41
+ none: false
42
+ requirements:
43
+ - - ! '>='
44
+ - !ruby/object:Gem::Version
45
+ version: 0.9.6
46
+ - !ruby/object:Gem::Dependency
47
+ name: rake
48
+ requirement: !ruby/object:Gem::Requirement
49
+ none: false
50
+ requirements:
51
+ - - ! '>='
52
+ - !ruby/object:Gem::Version
53
+ version: 0.8.7
54
+ type: :development
55
+ prerelease: false
56
+ version_requirements: !ruby/object:Gem::Requirement
57
+ none: false
58
+ requirements:
59
+ - - ! '>='
60
+ - !ruby/object:Gem::Version
61
+ version: 0.8.7
62
+ - !ruby/object:Gem::Dependency
63
+ name: rspec
64
+ requirement: !ruby/object:Gem::Requirement
65
+ none: false
66
+ requirements:
67
+ - - ~>
68
+ - !ruby/object:Gem::Version
69
+ version: 2.8.0
70
+ type: :development
71
+ prerelease: false
72
+ version_requirements: !ruby/object:Gem::Requirement
73
+ none: false
74
+ requirements:
75
+ - - ~>
76
+ - !ruby/object:Gem::Version
77
+ version: 2.8.0
78
+ - !ruby/object:Gem::Dependency
79
+ name: rdoc
80
+ requirement: !ruby/object:Gem::Requirement
81
+ none: false
82
+ requirements:
83
+ - - ~>
84
+ - !ruby/object:Gem::Version
85
+ version: '3.12'
86
+ type: :development
87
+ prerelease: false
88
+ version_requirements: !ruby/object:Gem::Requirement
89
+ none: false
90
+ requirements:
91
+ - - ~>
92
+ - !ruby/object:Gem::Version
93
+ version: '3.12'
94
+ - !ruby/object:Gem::Dependency
95
+ name: bundler
96
+ requirement: !ruby/object:Gem::Requirement
97
+ none: false
98
+ requirements:
99
+ - - ~>
100
+ - !ruby/object:Gem::Version
101
+ version: '1.0'
102
+ type: :development
103
+ prerelease: false
104
+ version_requirements: !ruby/object:Gem::Requirement
105
+ none: false
106
+ requirements:
107
+ - - ~>
108
+ - !ruby/object:Gem::Version
109
+ version: '1.0'
110
+ - !ruby/object:Gem::Dependency
111
+ name: simplecov
112
+ requirement: !ruby/object:Gem::Requirement
113
+ none: false
114
+ requirements:
115
+ - - ~>
116
+ - !ruby/object:Gem::Version
117
+ version: '0.7'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ none: false
122
+ requirements:
123
+ - - ~>
124
+ - !ruby/object:Gem::Version
125
+ version: '0.7'
126
+ description: ! " TLSPretense provides a set of tools to test SSL/TLS certificate
127
+ validation.\n It includes a library for generating certificates and a test framework
128
+ for\n running tests against a client by intercepting client network traffic.\"\n"
129
+ email: bjorvis@isecpartners.com
130
+ executables:
131
+ - tlspretense
132
+ extensions: []
133
+ extra_rdoc_files:
134
+ - LICENSE.txt
135
+ - README.rdoc
136
+ - doc/general_setup.rdoc
137
+ - doc/linux_setup.rdoc
138
+ files:
139
+ - .document
140
+ - .gitignore
141
+ - .rspec
142
+ - Gemfile
143
+ - Gemfile.lock
144
+ - LICENSE.txt
145
+ - README.rdoc
146
+ - Rakefile
147
+ - bin/makeder.sh
148
+ - bin/tlspretense
149
+ - bin/view.sh
150
+ - doc/general_setup.rdoc
151
+ - doc/linux_setup.rdoc
152
+ - lib/certmaker.rb
153
+ - lib/certmaker/certificate_factory.rb
154
+ - lib/certmaker/certificate_suite_generator.rb
155
+ - lib/certmaker/ext_core/hash_indifferent_fetch.rb
156
+ - lib/certmaker/runner.rb
157
+ - lib/certmaker/tasks.rb
158
+ - lib/packetthief.rb
159
+ - lib/packetthief/handlers.rb
160
+ - lib/packetthief/handlers/abstract_ssl_handler.rb
161
+ - lib/packetthief/handlers/proxy_redirector.rb
162
+ - lib/packetthief/handlers/ssl_client.rb
163
+ - lib/packetthief/handlers/ssl_server.rb
164
+ - lib/packetthief/handlers/ssl_smart_proxy.rb
165
+ - lib/packetthief/handlers/ssl_transparent_proxy.rb
166
+ - lib/packetthief/handlers/transparent_proxy.rb
167
+ - lib/packetthief/impl.rb
168
+ - lib/packetthief/impl/ipfw.rb
169
+ - lib/packetthief/impl/manual.rb
170
+ - lib/packetthief/impl/netfilter.rb
171
+ - lib/packetthief/impl/pf_divert.rb
172
+ - lib/packetthief/impl/pf_rdr.rb
173
+ - lib/packetthief/logging.rb
174
+ - lib/packetthief/redirect_rule.rb
175
+ - lib/packetthief/util.rb
176
+ - lib/ssl_test.rb
177
+ - lib/ssl_test/app_context.rb
178
+ - lib/ssl_test/certificate_manager.rb
179
+ - lib/ssl_test/config.rb
180
+ - lib/ssl_test/ext_core/io_raw_input.rb
181
+ - lib/ssl_test/input_handler.rb
182
+ - lib/ssl_test/runner.rb
183
+ - lib/ssl_test/runner_options.rb
184
+ - lib/ssl_test/ssl_test_case.rb
185
+ - lib/ssl_test/ssl_test_report.rb
186
+ - lib/ssl_test/ssl_test_result.rb
187
+ - lib/ssl_test/test_listener.rb
188
+ - lib/ssl_test/test_manager.rb
189
+ - lib/tlspretense.rb
190
+ - lib/tlspretense/app.rb
191
+ - lib/tlspretense/init_runner.rb
192
+ - lib/tlspretense/skel/ca/goodcacert.pem
193
+ - lib/tlspretense/skel/ca/goodcakey.pem
194
+ - lib/tlspretense/skel/config.yml
195
+ - lib/tlspretense/version.rb
196
+ - packetthief_examples/certs/cacert.pem
197
+ - packetthief_examples/certs/cakey.pem
198
+ - packetthief_examples/certs/samplechain.pem
199
+ - packetthief_examples/certs/samplekey.pem
200
+ - packetthief_examples/em_ssl_test.rb
201
+ - packetthief_examples/redirector.rb
202
+ - packetthief_examples/setup_iptables.sh
203
+ - packetthief_examples/ssl_client_simple.rb
204
+ - packetthief_examples/ssl_server_simple.rb
205
+ - packetthief_examples/ssl_smart_proxy.rb
206
+ - packetthief_examples/ssl_transparent_proxy.rb
207
+ - packetthief_examples/transparent_proxy.rb
208
+ - spec/packetthief/impl/ipfw_spec.rb
209
+ - spec/packetthief/impl/manual_spec.rb
210
+ - spec/packetthief/impl/netfilter_spec.rb
211
+ - spec/packetthief/impl/pf_divert_spec.rb
212
+ - spec/packetthief/impl/pf_rdr_spec.rb
213
+ - spec/packetthief/logging_spec.rb
214
+ - spec/packetthief_spec.rb
215
+ - spec/spec_helper.rb
216
+ - spec/ssl_test/certificate_manager_spec.rb
217
+ - spec/ssl_test/config_spec.rb
218
+ - spec/ssl_test/runner_spec.rb
219
+ - spec/ssl_test/ssl_test_case_spec.rb
220
+ - spec/ssl_test/test_listener_spec.rb
221
+ - spec/ssl_test/test_manager_spec.rb
222
+ - tlspretense.gemspec
223
+ homepage: https://github.com/iSECPartners/tlspretense
224
+ licenses:
225
+ - MIT
226
+ post_install_message:
227
+ rdoc_options: []
228
+ require_paths:
229
+ - lib
230
+ required_ruby_version: !ruby/object:Gem::Requirement
231
+ none: false
232
+ requirements:
233
+ - - ! '>='
234
+ - !ruby/object:Gem::Version
235
+ version: '0'
236
+ required_rubygems_version: !ruby/object:Gem::Requirement
237
+ none: false
238
+ requirements:
239
+ - - ! '>='
240
+ - !ruby/object:Gem::Version
241
+ version: '0'
242
+ requirements: []
243
+ rubyforge_project:
244
+ rubygems_version: 1.8.24
245
+ signing_key:
246
+ specification_version: 3
247
+ summary: SSL/TLS client testing framework
248
+ test_files:
249
+ - spec/packetthief/impl/ipfw_spec.rb
250
+ - spec/packetthief/impl/manual_spec.rb
251
+ - spec/packetthief/impl/netfilter_spec.rb
252
+ - spec/packetthief/impl/pf_divert_spec.rb
253
+ - spec/packetthief/impl/pf_rdr_spec.rb
254
+ - spec/packetthief/logging_spec.rb
255
+ - spec/packetthief_spec.rb
256
+ - spec/spec_helper.rb
257
+ - spec/ssl_test/certificate_manager_spec.rb
258
+ - spec/ssl_test/config_spec.rb
259
+ - spec/ssl_test/runner_spec.rb
260
+ - spec/ssl_test/ssl_test_case_spec.rb
261
+ - spec/ssl_test/test_listener_spec.rb
262
+ - spec/ssl_test/test_manager_spec.rb