tlspretense 0.6.1

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.
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