r509 0.9.2 → 0.10.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (177) hide show
  1. checksums.yaml +7 -0
  2. checksums.yaml.gz.sig +0 -0
  3. data.tar.gz.sig +2 -0
  4. data/CONTRIBUTING.mdown +21 -0
  5. data/LICENSE +13 -0
  6. data/README.mdown +548 -0
  7. data/Rakefile +5 -0
  8. data/bin/r509 +16 -17
  9. data/doc/R509.html +42 -26
  10. data/doc/R509/ASN1.html +22 -16
  11. data/doc/R509/ASN1/GeneralName.html +180 -173
  12. data/doc/R509/ASN1/GeneralNames.html +390 -62
  13. data/doc/R509/CRL.html +9 -7
  14. data/doc/R509/CRL/Administrator.html +208 -623
  15. data/doc/R509/CRL/FileReaderWriter.html +856 -0
  16. data/doc/R509/CRL/ReaderWriter.html +524 -0
  17. data/doc/R509/CRL/SignedList.html +29 -42
  18. data/doc/R509/CSR.html +248 -333
  19. data/doc/R509/Cert.html +364 -491
  20. data/doc/R509/Cert/Extensions.html +134 -43
  21. data/doc/R509/Cert/Extensions/AuthorityInfoAccess.html +335 -65
  22. data/doc/R509/Cert/Extensions/AuthorityKeyIdentifier.html +201 -102
  23. data/doc/R509/Cert/Extensions/BasicConstraints.html +297 -68
  24. data/doc/R509/Cert/Extensions/CRLDistributionPoints.html +690 -77
  25. data/doc/R509/Cert/Extensions/CertificatePolicies.html +293 -43
  26. data/doc/R509/Cert/Extensions/ExtendedKeyUsage.html +321 -173
  27. data/doc/R509/Cert/Extensions/GeneralNamesMixin.html +656 -0
  28. data/doc/R509/Cert/Extensions/InhibitAnyPolicy.html +270 -42
  29. data/doc/R509/Cert/Extensions/KeyUsage.html +334 -184
  30. data/doc/R509/Cert/Extensions/NameConstraints.html +363 -93
  31. data/doc/R509/{ASN1 → Cert/Extensions}/NoticeReference.html +209 -48
  32. data/doc/R509/Cert/Extensions/OCSPNoCheck.html +244 -17
  33. data/doc/R509/Cert/Extensions/PolicyConstraints.html +322 -71
  34. data/doc/R509/{ASN1 → Cert/Extensions}/PolicyInformation.html +204 -43
  35. data/doc/R509/{ASN1 → Cert/Extensions}/PolicyQualifiers.html +205 -48
  36. data/doc/R509/Cert/Extensions/SubjectAlternativeName.html +348 -143
  37. data/doc/R509/Cert/Extensions/SubjectKeyIdentifier.html +165 -13
  38. data/doc/R509/{ASN1 → Cert/Extensions}/UserNotice.html +204 -43
  39. data/doc/R509/Cert/Extensions/ValidationMixin.html +120 -0
  40. data/doc/R509/CertificateAuthority.html +9 -7
  41. data/doc/R509/CertificateAuthority/OptionsBuilder.html +475 -0
  42. data/doc/R509/CertificateAuthority/Signer.html +149 -198
  43. data/doc/R509/Config.html +10 -8
  44. data/doc/R509/Config/CAConfig.html +708 -625
  45. data/doc/R509/Config/CAConfigPool.html +179 -31
  46. data/doc/R509/Config/CertProfile.html +1544 -0
  47. data/doc/R509/Config/SubjectItemPolicy.html +437 -99
  48. data/doc/R509/Engine.html +14 -28
  49. data/doc/R509/Helpers.html +1014 -0
  50. data/doc/R509/MessageDigest.html +73 -25
  51. data/doc/R509/NameSanitizer.html +39 -39
  52. data/doc/R509/OCSP.html +5 -5
  53. data/doc/R509/OCSP/Request.html +5 -5
  54. data/doc/R509/OCSP/Request/Nonce.html +5 -5
  55. data/doc/R509/OCSP/Response.html +7 -7
  56. data/doc/R509/OIDMapper.html +121 -6
  57. data/doc/R509/PrivateKey.html +226 -227
  58. data/doc/R509/R509Error.html +5 -5
  59. data/doc/R509/SPKI.html +244 -342
  60. data/doc/R509/Subject.html +241 -70
  61. data/doc/R509/Validity.html +5 -5
  62. data/doc/R509/Validity/Checker.html +5 -5
  63. data/doc/R509/Validity/DefaultChecker.html +5 -9
  64. data/doc/R509/Validity/DefaultWriter.html +5 -9
  65. data/doc/R509/Validity/Status.html +5 -5
  66. data/doc/R509/Validity/Writer.html +5 -5
  67. data/doc/_index.html +92 -30
  68. data/doc/class_list.html +2 -2
  69. data/doc/file.CONTRIBUTING.html +96 -0
  70. data/doc/file.LICENSE.html +87 -0
  71. data/doc/file.README.html +279 -389
  72. data/doc/file.YAML.html +243 -0
  73. data/doc/file.r509.html +298 -105
  74. data/doc/file_list.html +11 -2
  75. data/doc/frames.html +1 -1
  76. data/doc/index.html +279 -389
  77. data/doc/js/full_list.js +6 -1
  78. data/doc/method_list.html +869 -1139
  79. data/doc/top-level-namespace.html +103 -5
  80. data/lib/r509.rb +7 -2
  81. data/lib/r509/asn1.rb +97 -135
  82. data/lib/r509/cert.rb +17 -106
  83. data/lib/r509/cert/extensions.rb +13 -676
  84. data/lib/r509/cert/extensions/authority_info_access.rb +128 -0
  85. data/lib/r509/cert/extensions/authority_key_identifier.rb +100 -0
  86. data/lib/r509/cert/extensions/base.rb +142 -0
  87. data/lib/r509/cert/extensions/basic_constraints.rb +119 -0
  88. data/lib/r509/cert/extensions/certificate_policies.rb +262 -0
  89. data/lib/r509/cert/extensions/crl_distribution_points.rb +98 -0
  90. data/lib/r509/cert/extensions/extended_key_usage.rb +189 -0
  91. data/lib/r509/cert/extensions/inhibit_any_policy.rb +70 -0
  92. data/lib/r509/cert/extensions/key_usage.rb +209 -0
  93. data/lib/r509/cert/extensions/name_constraints.rb +179 -0
  94. data/lib/r509/cert/extensions/ocsp_no_check.rb +56 -0
  95. data/lib/r509/cert/extensions/policy_constraints.rb +122 -0
  96. data/lib/r509/cert/extensions/subject_alternative_name.rb +88 -0
  97. data/lib/r509/cert/extensions/subject_key_identifier.rb +56 -0
  98. data/lib/r509/cert/extensions/validation_mixin.rb +42 -0
  99. data/lib/r509/certificate_authority/options_builder.rb +142 -0
  100. data/lib/r509/certificate_authority/signer.rb +189 -0
  101. data/lib/r509/config.rb +3 -600
  102. data/lib/r509/config/ca_config.rb +414 -0
  103. data/lib/r509/config/cert_profile.rb +110 -0
  104. data/lib/r509/config/subject_item_policy.rb +118 -0
  105. data/lib/r509/crl/administrator.rb +169 -0
  106. data/lib/r509/crl/reader_writer.rb +109 -0
  107. data/lib/r509/crl/signed_list.rb +135 -0
  108. data/lib/r509/csr.rb +35 -116
  109. data/lib/r509/engine.rb +21 -11
  110. data/lib/r509/helpers.rb +110 -0
  111. data/lib/r509/io_helpers.rb +18 -13
  112. data/lib/r509/message_digest.rb +13 -3
  113. data/lib/r509/oid_mapper.rb +14 -0
  114. data/lib/r509/private_key.rb +74 -50
  115. data/lib/r509/spki.rb +50 -113
  116. data/lib/r509/subject.rb +24 -2
  117. data/lib/r509/trollop.rb +788 -0
  118. data/lib/r509/version.rb +1 -1
  119. data/r509.yaml +289 -96
  120. data/spec/asn1_spec.rb +171 -98
  121. data/spec/cert/extensions/authority_info_access_spec.rb +247 -0
  122. data/spec/cert/extensions/authority_key_identifier_spec.rb +85 -0
  123. data/spec/cert/extensions/base_spec.rb +172 -0
  124. data/spec/cert/extensions/basic_constraints_spec.rb +185 -0
  125. data/spec/cert/extensions/certificate_policies_spec.rb +288 -0
  126. data/spec/cert/extensions/crl_distribution_points_spec.rb +149 -0
  127. data/spec/cert/extensions/extended_key_usage_spec.rb +174 -0
  128. data/spec/cert/extensions/inhibit_any_policy_spec.rb +92 -0
  129. data/spec/cert/extensions/key_usage_spec.rb +172 -0
  130. data/spec/cert/extensions/name_constraints_spec.rb +335 -0
  131. data/spec/cert/extensions/ocsp_no_check_spec.rb +76 -0
  132. data/spec/cert/extensions/policy_constraints_spec.rb +155 -0
  133. data/spec/cert/extensions/subject_alternative_name_spec.rb +354 -0
  134. data/spec/cert/extensions/subject_key_identifier_spec.rb +64 -0
  135. data/spec/cert_spec.rb +11 -9
  136. data/spec/certificate_authority/options_builder_spec.rb +307 -0
  137. data/spec/certificate_authority/signer_spec.rb +278 -0
  138. data/spec/config/ca_config_spec.rb +405 -0
  139. data/spec/config/cert_profile_spec.rb +88 -0
  140. data/spec/config/subject_item_policy_spec.rb +81 -0
  141. data/spec/crl/administrator_spec.rb +199 -0
  142. data/spec/crl/reader_writer_spec.rb +97 -0
  143. data/spec/crl/signed_list_spec.rb +84 -0
  144. data/spec/csr_spec.rb +43 -36
  145. data/spec/engine_spec.rb +51 -0
  146. data/spec/fixtures.rb +40 -40
  147. data/spec/fixtures/cert1.pem +1 -1
  148. data/spec/fixtures/config_pool_test_minimal.yaml +11 -15
  149. data/spec/fixtures/config_test.yaml +96 -59
  150. data/spec/fixtures/config_test_dsa.yaml +29 -35
  151. data/spec/fixtures/config_test_ec.yaml +29 -35
  152. data/spec/fixtures/config_test_engine_key.yaml +7 -7
  153. data/spec/fixtures/config_test_engine_no_key_name.yaml +6 -6
  154. data/spec/fixtures/config_test_minimal.yaml +3 -5
  155. data/spec/fixtures/config_test_password.yaml +4 -6
  156. data/spec/fixtures/config_test_various.yaml +147 -137
  157. data/spec/fixtures/crl_list_file.txt +1 -1
  158. data/spec/fixtures/test_ca_crl.cer +20 -0
  159. data/spec/fixtures/test_ca_crl.key +28 -0
  160. data/spec/fixtures/test_ca_crl.p12 +0 -0
  161. data/spec/message_digest_spec.rb +6 -0
  162. data/spec/oid_mapper_spec.rb +11 -0
  163. data/spec/private_key_spec.rb +19 -18
  164. data/spec/spec_helper.rb +10 -6
  165. data/spec/spki_spec.rb +38 -19
  166. data/spec/subject_spec.rb +16 -0
  167. metadata +108 -59
  168. metadata.gz.sig +0 -0
  169. data/README.md +0 -638
  170. data/doc/R509/Config/CAProfile.html +0 -1015
  171. data/doc/R509/IOHelpers.html +0 -564
  172. data/lib/r509/certificate_authority.rb +0 -407
  173. data/lib/r509/crl.rb +0 -351
  174. data/spec/cert/extensions_spec.rb +0 -1095
  175. data/spec/certificate_authority_spec.rb +0 -681
  176. data/spec/config_spec.rb +0 -562
  177. data/spec/crl_spec.rb +0 -226
@@ -0,0 +1,354 @@
1
+ require 'spec_helper'
2
+
3
+ include R509::Cert::Extensions
4
+
5
+ shared_examples_for "a correct R509 SubjectAlternativeName object" do |critical|
6
+ before :all do
7
+ extension_name = "subjectAltName"
8
+ klass = SubjectAlternativeName
9
+ ef = OpenSSL::X509::ExtensionFactory.new
10
+ ef.config = OpenSSL::Config.parse(@conf)
11
+ openssl_ext = ef.create_extension( extension_name, @extension_value , critical )
12
+ @r509_ext = klass.new( openssl_ext )
13
+ end
14
+
15
+ it "dns_names should be correct critical:#{critical}" do
16
+ @r509_ext.dns_names.should == @dns_names
17
+ end
18
+
19
+ it "ip_addresses should be correct critical:#{critical}" do
20
+ @r509_ext.ip_addresses.should == @ip_addresses
21
+ end
22
+
23
+ it "rfc_822names should be correct critical:#{critical}" do
24
+ @r509_ext.rfc_822_names.should == @rfc_822_names
25
+ end
26
+
27
+ it "uris should be correct critical:#{critical}" do
28
+ @r509_ext.uris.should == @uris
29
+ end
30
+
31
+ it "dirNames should be correct critical:#{critical}" do
32
+ @r509_ext.directory_names.size.should == @directory_names.size
33
+ end
34
+
35
+ it "ordered should be correct critical:#{critical}" do
36
+ @r509_ext.names.size.should == @dns_names.size + @ip_addresses.size + @rfc_822_names.size + @uris.size + @directory_names.size
37
+ end
38
+
39
+ it "reports #critical? properly" do
40
+ @r509_ext.critical?.should == critical
41
+ end
42
+ end
43
+
44
+ describe R509::Cert::Extensions::SubjectAlternativeName do
45
+ include R509::Cert::Extensions
46
+
47
+
48
+ context "validation" do
49
+ it "errors when not supplying a hash" do
50
+ expect {
51
+ R509::Cert::Extensions::SubjectAlternativeName.new("create")
52
+ }.to raise_error(ArgumentError,"You must supply a hash with a :value")
53
+ end
54
+
55
+ it "errors when not supplying :value" do
56
+ expect {
57
+ R509::Cert::Extensions::SubjectAlternativeName.new({})
58
+ }.to raise_error(ArgumentError,"You must supply a hash with a :value")
59
+ end
60
+ end
61
+ context "SubjectAlternativeName" do
62
+ context "creation & yaml generation" do
63
+
64
+ context "GeneralNames object" do
65
+ before :all do
66
+ gns = R509::ASN1::GeneralNames.new
67
+ gns.create_item(:type => "rfc822Name", :value => "random string")
68
+ @san = R509::Cert::Extensions::SubjectAlternativeName.new(:value => gns)
69
+ end
70
+
71
+ it "creates extension" do
72
+ @san.rfc_822_names.should == ['random string']
73
+ end
74
+
75
+ it "builds yaml" do
76
+ YAML.load(@san.to_yaml).should == {:critical=>false, :value=>[{:type=>"email", :value=>"random string"}]}
77
+ end
78
+ end
79
+
80
+ context "single name" do
81
+ before :all do
82
+ @args = { :value => [{:type => "DNS", :value => 'domain.com' }], :critical => false }
83
+ @san = R509::Cert::Extensions::SubjectAlternativeName.new(@args)
84
+ end
85
+
86
+ it "creates extension" do
87
+ @san.dns_names.should == ['domain.com']
88
+ end
89
+
90
+ it "builds yaml" do
91
+ @san.to_h.should == @args
92
+ end
93
+ end
94
+
95
+ context "multiple names" do
96
+ before :all do
97
+ @args = { :value => [{:type => 'DNS', :value => 'domain.com' },{ :type => 'IP', :value => '127.0.0.1' }], :critical => false }
98
+ @san = R509::Cert::Extensions::SubjectAlternativeName.new(@args)
99
+ end
100
+ it "creates extension" do
101
+ @san.dns_names.should == ['domain.com']
102
+ @san.ip_addresses.should == ['127.0.0.1']
103
+ end
104
+
105
+ it "builds yaml" do
106
+ @san.to_h.should == @args
107
+ end
108
+ end
109
+
110
+ context "default criticality" do
111
+ before :all do
112
+ @args = { :value => [{:type => "DNS", :value => 'domain.com' }] }
113
+ @san = R509::Cert::Extensions::SubjectAlternativeName.new(@args)
114
+ end
115
+
116
+ it "creates extension" do
117
+ @san.critical?.should be_false
118
+ end
119
+
120
+ it "builds yaml" do
121
+ @san.to_h.should == @args.merge(:critical => false)
122
+ end
123
+ end
124
+
125
+ context "creates with non-default criticality" do
126
+ before :all do
127
+ @args = { :value => [{:type => "DNS", :value => 'domain.com' }], :critical => true }
128
+ @san = R509::Cert::Extensions::SubjectAlternativeName.new(@args)
129
+ end
130
+
131
+ it "creates extension" do
132
+ @san.critical?.should be_true
133
+ end
134
+
135
+ it "builds yaml" do
136
+ @san.to_h.should == @args
137
+ end
138
+ end
139
+
140
+ end
141
+
142
+ context "with an unimplemented GeneralName type" do
143
+ it "errors as expected" do
144
+ ef = OpenSSL::X509::ExtensionFactory.new
145
+ ext = ef.create_extension("subjectAltName","otherName:1.2.3.4;IA5STRING:Hello World")
146
+ expect { R509::Cert::Extensions::SubjectAlternativeName.new ext }.to raise_error(R509::R509Error, 'Unimplemented GeneralName tag: 0. At this time R509 does not support GeneralName types other than rfc822Name, dNSName, uniformResourceIdentifier, iPAddress, and directoryName')
147
+ end
148
+ end
149
+ context "with a DNS alternative name only" do
150
+ before :all do
151
+ @dns_names = ["www.test.local"]
152
+ @ip_addresses = []
153
+ @uris = []
154
+ @rfc_822_names = []
155
+ @directory_names = []
156
+ total = [@dns_names,@ip_addresses,@uris,@rfc_822_names,@directory_names].flatten(1)
157
+ gns = R509::ASN1.general_name_parser(total)
158
+ serialized = gns.serialize_names
159
+ @conf = serialized[:conf]
160
+ @extension_value = serialized[:extension_string]
161
+ end
162
+
163
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", false
164
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", true
165
+ end
166
+
167
+ context "with multiple DNS alternative names only" do
168
+ before :all do
169
+ @dns_names = ["www.test.local", "www2.test.local"]
170
+ @ip_addresses = []
171
+ @uris = []
172
+ @rfc_822_names = []
173
+ @directory_names = []
174
+ total = [@dns_names,@ip_addresses,@uris,@rfc_822_names,@directory_names].flatten(1)
175
+ gns = R509::ASN1.general_name_parser(total)
176
+ serialized = gns.serialize_names
177
+ @conf = serialized[:conf]
178
+ @extension_value = serialized[:extension_string]
179
+ end
180
+
181
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", false
182
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", true
183
+ end
184
+
185
+ context "with an IP address alternative name only" do
186
+ before :all do
187
+ @dns_names = []
188
+ @ip_addresses = ["203.1.2.3"]
189
+ @rfc_822_names = []
190
+ @uris = []
191
+ @directory_names = []
192
+ total = [@dns_names,@ip_addresses,@uris,@rfc_822_names,@directory_names].flatten(1)
193
+ gns = R509::ASN1.general_name_parser(total)
194
+ serialized = gns.serialize_names
195
+ @conf = serialized[:conf]
196
+ @extension_value = serialized[:extension_string]
197
+ end
198
+
199
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", false
200
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", true
201
+ end
202
+
203
+ context "with multiple IP address alternative names only" do
204
+ before :all do
205
+ @dns_names = []
206
+ @ip_addresses = ["10.1.2.3", "10.1.2.4"]
207
+ @uris = []
208
+ @rfc_822_names = []
209
+ @directory_names = []
210
+ total = [@dns_names,@ip_addresses,@uris,@rfc_822_names,@directory_names].flatten(1)
211
+ gns = R509::ASN1.general_name_parser(total)
212
+ serialized = gns.serialize_names
213
+ @conf = serialized[:conf]
214
+ @extension_value = serialized[:extension_string]
215
+ end
216
+
217
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", false
218
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", true
219
+ end
220
+
221
+ context "with an rfc822Name alternative name only" do
222
+ before :all do
223
+ @dns_names = []
224
+ @ip_addresses = []
225
+ @rfc_822_names = ["some@guy.com"]
226
+ @uris = []
227
+ @directory_names = []
228
+ total = [@dns_names,@ip_addresses,@uris,@rfc_822_names,@directory_names].flatten(1)
229
+ gns = R509::ASN1.general_name_parser(total)
230
+ serialized = gns.serialize_names
231
+ @conf = serialized[:conf]
232
+ @extension_value = serialized[:extension_string]
233
+ end
234
+
235
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", false
236
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", true
237
+ end
238
+
239
+ context "with multiple rfc822Name alternative names only" do
240
+ before :all do
241
+ @dns_names = []
242
+ @ip_addresses = []
243
+ @rfc_822_names = ["some@guy.com","other@guy.com"]
244
+ @uris = []
245
+ @directory_names = []
246
+ total = [@dns_names,@ip_addresses,@uris,@rfc_822_names,@directory_names].flatten(1)
247
+ gns = R509::ASN1.general_name_parser(total)
248
+ serialized = gns.serialize_names
249
+ @conf = serialized[:conf]
250
+ @extension_value = serialized[:extension_string]
251
+ end
252
+
253
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", false
254
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", true
255
+ end
256
+
257
+ context "with a URI alternative name only" do
258
+ before :all do
259
+ @dns_names = []
260
+ @ip_addresses = []
261
+ @rfc_822_names = []
262
+ @uris = ["http://www.test.local"]
263
+ @directory_names = []
264
+ total = [@dns_names,@ip_addresses,@uris,@rfc_822_names,@directory_names].flatten(1)
265
+ gns = R509::ASN1.general_name_parser(total)
266
+ serialized = gns.serialize_names
267
+ @conf = serialized[:conf]
268
+ @extension_value = serialized[:extension_string]
269
+ end
270
+
271
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", false
272
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", true
273
+ end
274
+
275
+ context "with multiple URI alternative names only" do
276
+ before :all do
277
+ @dns_names = []
278
+ @ip_addresses = []
279
+ @rfc_822_names = []
280
+ @uris = ["http://www.test.local","http://www2.test.local"]
281
+ @directory_names = []
282
+ total = [@dns_names,@ip_addresses,@uris,@rfc_822_names,@directory_names].flatten(1)
283
+ gns = R509::ASN1.general_name_parser(total)
284
+ serialized = gns.serialize_names
285
+ @conf = serialized[:conf]
286
+ @extension_value = serialized[:extension_string]
287
+ end
288
+
289
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", false
290
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", true
291
+ end
292
+
293
+ context "with a directoryName alternative name only" do
294
+ before :all do
295
+ @dns_names = []
296
+ @ip_addresses = []
297
+ @rfc_822_names = []
298
+ @uris = []
299
+ @directory_names = [
300
+ [['CN','langui.sh'],['O','org'],['L','locality']]
301
+ ]
302
+ total = [@dns_names,@ip_addresses,@uris,@rfc_822_names,@directory_names].flatten(1)
303
+ gns = R509::ASN1.general_name_parser(total)
304
+ serialized = gns.serialize_names
305
+ @conf = serialized[:conf]
306
+ @extension_value = serialized[:extension_string]
307
+ end
308
+
309
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", false
310
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", true
311
+ end
312
+
313
+ context "with multiple directoryName alternative names only" do
314
+ before :all do
315
+ @dns_names = []
316
+ @ip_addresses = []
317
+ @rfc_822_names = []
318
+ @uris = []
319
+ @directory_names = [
320
+ [['CN','langui.sh'],['O','org'],['L','locality']],
321
+ [['CN','otherdomain.com'],['O','org-like']]
322
+ ]
323
+ total = [@dns_names,@ip_addresses,@uris,@rfc_822_names,@directory_names].flatten(1)
324
+ gns = R509::ASN1.general_name_parser(total)
325
+ serialized = gns.serialize_names
326
+ @conf = serialized[:conf]
327
+ @extension_value = serialized[:extension_string]
328
+ end
329
+
330
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", false
331
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", true
332
+ end
333
+
334
+ context "with multiple different alternative names" do
335
+ before :all do
336
+ @dns_names = ["www.test.local"]
337
+ @ip_addresses = ["10.1.2.3"]
338
+ @rfc_822_names = ["myemail@email.com"]
339
+ @uris = ["http://www.test.local"]
340
+ @directory_names = [
341
+ [['CN','langui.sh'],['O','org'],['L','locality']]
342
+ ]
343
+ total = [@dns_names,@ip_addresses,@uris,@rfc_822_names,@directory_names].flatten(1)
344
+ gns = R509::ASN1.general_name_parser(total)
345
+ serialized = gns.serialize_names
346
+ @conf = serialized[:conf]
347
+ @extension_value = serialized[:extension_string]
348
+ end
349
+
350
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", false
351
+ it_should_behave_like "a correct R509 SubjectAlternativeName object", true
352
+ end
353
+ end
354
+ end
@@ -0,0 +1,64 @@
1
+ require 'spec_helper'
2
+
3
+ include R509::Cert::Extensions
4
+
5
+ shared_examples_for "a correct R509 SubjectKeyIdentifier object" do
6
+ before :all do
7
+ extension_name = "subjectKeyIdentifier"
8
+ klass = SubjectKeyIdentifier
9
+ openssl_ext = OpenSSL::X509::Extension.new( extension_name, @extension_value )
10
+ @r509_ext = klass.new( openssl_ext )
11
+ end
12
+
13
+ it "key should be correct" do
14
+ @r509_ext.key.should == @key
15
+ end
16
+ end
17
+
18
+ describe R509::Cert::Extensions::SubjectKeyIdentifier do
19
+ include R509::Cert::Extensions
20
+
21
+ context "SubjectKeyIdentifier" do
22
+ before :all do
23
+ @extension_value = "00:11:22:33:44:55:66:77:88:99:00:AA:BB:CC:DD:EE:FF:00:11:22"
24
+ @key = @extension_value
25
+ end
26
+
27
+ context "creation" do
28
+ before :all do
29
+ @pk = R509::PrivateKey.new(:bit_strength => 768)
30
+ end
31
+
32
+ it "errors when not supplying a public key" do
33
+ expect {
34
+ R509::Cert::Extensions::SubjectKeyIdentifier.new({})
35
+ }.to raise_error(ArgumentError,"You must supply a hash with a :public_key")
36
+ end
37
+
38
+ it "errors when supplying a non-hash" do
39
+ expect {
40
+ R509::Cert::Extensions::SubjectKeyIdentifier.new("junk!!!")
41
+ }.to raise_error(ArgumentError,"You must supply a hash with a :public_key")
42
+ end
43
+
44
+ it "creates successfully" do
45
+ ski = R509::Cert::Extensions::SubjectKeyIdentifier.new(:public_key => @pk.public_key)
46
+ ski.key.should_not be_nil
47
+ end
48
+
49
+ it "creates with default criticality" do
50
+ ski = R509::Cert::Extensions::SubjectKeyIdentifier.new(:public_key => @pk.public_key)
51
+ ski.critical?.should be_false
52
+ end
53
+
54
+ it "creates with non-default criticality" do
55
+ ski = R509::Cert::Extensions::SubjectKeyIdentifier.new(:public_key => @pk.public_key, :critical => true)
56
+ ski.critical?.should be_true
57
+ end
58
+
59
+ end
60
+
61
+ it_should_behave_like "a correct R509 SubjectKeyIdentifier object"
62
+ end
63
+
64
+ end
@@ -97,11 +97,11 @@ describe R509::Cert do
97
97
  end
98
98
  it "returns the RSA key algorithm" do
99
99
  cert = R509::Cert.new(:cert => @cert)
100
- cert.key_algorithm.should == :rsa
100
+ cert.key_algorithm.should == "RSA"
101
101
  end
102
102
  it "returns the DSA key algorithm" do
103
103
  cert = R509::Cert.new(:cert => @cert6)
104
- cert.key_algorithm.should == :dsa
104
+ cert.key_algorithm.should == "DSA"
105
105
  end
106
106
  it "returns list of san names when it is a san cert" do
107
107
  cert = R509::Cert.new(:cert => @cert_san)
@@ -145,7 +145,7 @@ describe R509::Cert do
145
145
  sio = StringIO.new
146
146
  sio.set_encoding("BINARY") if sio.respond_to?(:set_encoding)
147
147
  cert.write_pem(sio)
148
- sio.string.should == @cert + "\n"
148
+ sio.string.should == @cert
149
149
  end
150
150
  it "writes to der" do
151
151
  cert = R509::Cert.new(:cert => @cert)
@@ -269,7 +269,7 @@ describe R509::Cert do
269
269
  end
270
270
  it "returns an error for curve_name for DSA/RSA" do
271
271
  cert = R509::Cert.new(:cert => @cert)
272
- expect { cert.curve_name }.to raise_error(R509::R509Error, 'Curve name is only available with EC certs')
272
+ expect { cert.curve_name }.to raise_error(R509::R509Error, 'Curve name is only available with EC')
273
273
  end
274
274
  it "checks dsa?" do
275
275
  cert = R509::Cert.new(:cert => @cert6)
@@ -312,12 +312,14 @@ describe R509::Cert do
312
312
  cert = R509::Cert.new(:cert => @cert3)
313
313
  crl_admin = R509::CRL::Administrator.new(TestFixtures.test_ca_config)
314
314
  crl_admin.revoke_cert(1425751142578902223005775172931960716533532010870)
315
- cert.is_revoked_by_crl?(crl_admin.crl).should == true
315
+ crl = crl_admin.generate_crl
316
+ cert.is_revoked_by_crl?(crl).should == true
316
317
  end
317
318
  it "is not revoked by crl" do
318
319
  cert = R509::Cert.new(:cert => @cert3)
319
320
  crl_admin = R509::CRL::Administrator.new(TestFixtures.test_ca_config)
320
- cert.is_revoked_by_crl?(crl_admin.crl).should == false
321
+ crl = crl_admin.generate_crl
322
+ cert.is_revoked_by_crl?(crl).should == false
321
323
  end
322
324
  it "loads a cert with load_from_file" do
323
325
  path = File.dirname(__FILE__) + '/fixtures/cert1.pem'
@@ -350,7 +352,7 @@ describe R509::Cert do
350
352
  end
351
353
  it "raises error on bit strength" do
352
354
  cert = R509::Cert.new(:cert => @cert_ec)
353
- expect { cert.bit_strength }.to raise_error(R509::R509Error,'Bit strength is not available for EC at this time.')
355
+ expect { cert.bit_strength }.to raise_error(R509::R509Error,'Bit length is not available for EC at this time.')
354
356
  end
355
357
  it "returns curve name" do
356
358
  cert = R509::Cert.new(:cert => @cert_ec)
@@ -369,7 +371,7 @@ describe R509::Cert do
369
371
  end
370
372
  it "returns the key algorithm" do
371
373
  cert = R509::Cert.new(:cert => @cert_ec)
372
- cert.key_algorithm.should == :ec
374
+ cert.key_algorithm.should == "EC"
373
375
  end
374
376
  end
375
377
 
@@ -390,7 +392,7 @@ describe R509::Cert do
390
392
  end
391
393
  it "returns RSA key algorithm for RSA CSR" do
392
394
  cert = R509::Cert.new(:cert => @cert)
393
- cert.key_algorithm.should == :rsa
395
+ cert.key_algorithm.should == "RSA"
394
396
  end
395
397
  end
396
398
  end