Hey,

I've been battling this all day so I hop some people over here have some 
good ideas. I'm trying to set up a multi-master puppet environment with a 
single CA.

This is what I've done so far:
* node 1, the CA:
  * install puppetmaster
  * stop it
  * wipe `vardir/ssl`
  * configure certname and dns_alt_names
  * start it up

* node 2, an actual master that will handle requests but no CA:
  * install puppetmaster
  * stop it
  * wipe `vardir/ssl`
  * configure certname, dns_alt_names and ca_server to point to node1, set 
ca=false in the [master] block and point server to itself
  * do a puppet agent -t
  * sign the CSR on node1
  * get acknowledgement that node2 grabbed its cert from node1

Now I want to actually make the Puppet master on node2 usable. My Puppet 
masters run in Passenger Standalone with an nginx in front of them proxying 
the requests on port 8140 to them.

The complete SSL configuration in nginx now looks like this:
ssl                             on;
ssl_certificate            ssl/puppetmaster/node2.pem; # this is 
`vardir/ssl/certs/node2.pem`
ssl_certificate_key     ssl/puppetmaster/node2.key;  # this is 
`vardir/ssl/private_keys/node2.pem`
ssl_client_certificate  ssl/puppetmaster/ca.pem;       # this is 
`vardir/ssl/certs/ca.pem`
ssl_crl                        ssl/puppetmaster/crl.pem;       # this was 
copied from the master at `vardir/ssl/crl.pem`
ssl_verify_client        on;                                            # 
since we do only master, no CA we can require a client certificate

location / {
        [..] bunch of other proxy_set_header directives [..]
        proxy_set_header    X-Client-Verify  $ssl_client_verify;
proxy_set_header    X-Client-DN      $ssl_client_s_dn;
        proxy_set_header    X-SSL-Subject  $ssl_client_s_dn;
        proxy_set_header    X-SSL-Issuer    $ssl_client_i_dn;
}

I started the Puppet master and reloaded the nginx for the configuration to 
take effect.

First I tried to connect with openssl s_client:
root@node2 # openssl s_client -connect localhost:8140 -cert 
/var/lib/puppet/ssl/certs/node2.pem -key 
/var/lib/puppet/ssl/private_keys/node2.pem
CONNECTED(00000003)
depth=1 CN = Puppet CA: node1
verify error:num=19:self signed certificate in certificate chain
verify return:0
---
Certificate chain
 0 s:/CN=node2
   i:/CN=Puppet CA: node1
 1 s:/CN=Puppet CA: node1
   i:/CN=Puppet CA: node1
---
[..]
subject=/CN=node2
issuer=/CN=Puppet CA: node1
---
Acceptable client certificate CA names
/CN=Puppet CA: node1
---
SSL handshake has read 5314 bytes and written 2445 bytes
---
New, TLSv1/SSLv3, Cipher is ECDHE-RSA-AES128-GCM-SHA256
Server public key is 4096 bit
Secure Renegotiation IS supported
Compression: NONE
Expansion: NONE
SSL-Session:
    Protocol  : TLSv1.2
    Cipher    : ECDHE-RSA-AES128-GCM-SHA256
[..]
 Start Time: 1382622609
    Timeout   : 300 (sec)
    Verify return code: 19 (self signed certificate in certificate chain)
---
GET /production/node/node2
Forbidden request: node2l(10.120.12.73) access to /node/node2 [find] at 
:115closed

This looks fine, It complains about the self-signed certificate in the 
chain but other than that verify return = 0 which as far as I'm aware means 
success. Once the handshake is complete I can actually do a GET for that 
node but that seems to fail because of something in auth.conf, which is 
slightly odd since the authentication succeeded so the ACL shouldn't trip 
over it but that's step two (I'm probably forgetting to proxy/set a header).

Now, running `puppet agent -t` however gives me this:
Warning: Unable to fetch my node definition, but the agent run will 
continue:
Warning: SSL_connect returned=1 errno=0 state=SSLv3 read server certificate 
B: certificate verify failed: [certificate signature failure for /CN=node1]

At this point I'm lost. Ntpd's are running, nodes are within far less than 
a second in sync of each other. Certificate is valid from yesterday to 
yesterday in 2018 so I doubt that's an issue either. If it were the 
`openssl s_client -connect` should have failed too but it's obviously 
perfectly happy with it.

What am I missing here? I fear it's staring me in the face but I'm just not 
seeing it.

-- 
Daniele Sluijters

-- 
You received this message because you are subscribed to the Google Groups 
"Puppet Users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to puppet-users+unsubscr...@googlegroups.com.
To post to this group, send email to puppet-users@googlegroups.com.
Visit this group at http://groups.google.com/group/puppet-users.
For more options, visit https://groups.google.com/groups/opt_out.

Reply via email to