diff options
| author | luke <luke@980ebf18-57e1-0310-9a29-db15c13687c0> | 2007-06-18 19:33:15 +0000 |
|---|---|---|
| committer | luke <luke@980ebf18-57e1-0310-9a29-db15c13687c0> | 2007-06-18 19:33:15 +0000 |
| commit | 6e16d9feb1468aae964115833a223cd07c37036e (patch) | |
| tree | f81634c66f8e8ec2ab576fccdd51fd1c75ec88bb | |
| parent | bf5d5d569457b788cb1db4ed497b94469cc91f0a (diff) | |
Fixing #578 -- Invalid certs are no longer written to disk.
git-svn-id: https://reductivelabs.com/svn/puppet/trunk@2611 980ebf18-57e1-0310-9a29-db15c13687c0
| -rw-r--r-- | CHANGELOG | 2 | ||||
| -rw-r--r-- | lib/puppet/network/client/ca.rb | 9 | ||||
| -rwxr-xr-x | test/network/client/ca.rb | 24 |
3 files changed, 32 insertions, 3 deletions
@@ -1,3 +1,5 @@ + Invalid certificates are no longer written to disk (#578). + Added a package provider (appdmg) able to install .app packages on .dmg files on OS X (#641). diff --git a/lib/puppet/network/client/ca.rb b/lib/puppet/network/client/ca.rb index 50d761ccf..412c9c59f 100644 --- a/lib/puppet/network/client/ca.rb +++ b/lib/puppet/network/client/ca.rb @@ -34,8 +34,6 @@ class Puppet::Network::Client::CA < Puppet::Network::Client if cert.nil? or cert == "" return nil end - Puppet.config.write(:hostcert) do |f| f.print cert end - Puppet.config.write(:localcacert) do |f| f.print cacert end begin @cert = OpenSSL::X509::Certificate.new(cert) @@ -47,8 +45,13 @@ class Puppet::Network::Client::CA < Puppet::Network::Client end unless @cert.check_private_key(key) - raise InvalidCertificate, "Certificate does not match private key" + raise InvalidCertificate, "Certificate does not match private key. Try 'puppetca --clean %s' on the server." % Facter.value(:fqdn) end + + # Only write the cert out if it passes validating. + Puppet.config.write(:hostcert) do |f| f.print cert end + Puppet.config.write(:localcacert) do |f| f.print cacert end + return @cert end end diff --git a/test/network/client/ca.rb b/test/network/client/ca.rb index bdae140ef..0fdbda537 100755 --- a/test/network/client/ca.rb +++ b/test/network/client/ca.rb @@ -33,6 +33,30 @@ class TestClientCA < Test::Unit::TestCase client = Puppet::Network::Client.ca.new end end + + # #578 + def test_invalid_certs_are_not_written + # Run the get once, which should be valid + + assert_nothing_raised("Could not get a certificate") do + @client.request_cert + end + + # Now remove the cert and keys, so we get a broken cert + File.unlink(Puppet[:hostcert]) + File.unlink(Puppet[:localcacert]) + File.unlink(Puppet[:hostprivkey]) + + @client = Puppet::Network::Client.ca.new :CA => @ca + # Now make sure it fails, since we'll get the old cert but have new keys + assert_raise(Puppet::Network::Client::CA::InvalidCertificate, "Did not fail on invalid cert") do + @client.request_cert + end + + # And then make sure the cert isn't written to disk + assert(! FileTest.exists?(Puppet[:hostcert]), + "Invalid cert got written to disk") + end end # $Id$ |
