0.0
No commit activity in last 3 years
No release in over 3 years
Certificate authority that can be configured to make decisions about whether to autosign certificate signing requests for clients. This gem provides the protocol-agnostic library, which is expected to be used within something like an HTTP REST service.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.5
~> 10.4
~> 3.1
 Project Readme

Certmeister

Certmeister is a conditionally autosigning Certificate Authority. It was developed for use with the Puppet infrastructure at Hetzner PTY Ltd.

The service will autosign a certificate request when the configurable access policy permits. The reference access policy in use by Hetzner PTY Ltd is:

  • the Common Name (CN) of the certificate is in the host-h.net domain,
  • the service has no record of already having signed a certificate for that CN, and
  • the requesting client IP address has forward confirmed reverse DNS that matches the CN.
  • Requests to fetch certificates are always allowed.
  • Requests to delete certificates are only allowed when they originate from a secure operator network.

This allows us the convenience of Puppet's autosign feature, without the horrendous security implications.

This repository currently builds one gem:

  • certmeister - the CA, some off-the-shelf policy modules and an in-memory cert store

A rack application to provide an HTTP interface to the CA is available as a separate gem:

Only an in-memory store is provided. Others are available as separate gems:

An example, using redis and rack and enforcing Hetzner PTY Ltd's policy, is available in the contrib subdirectory of the certmeister-rack source.

Testing

rake spec

Releasing

If you work at Hetzner and need to release new versions of the gems, do this (obviously only after making sure the tests run and you have no uncommitted changes):

# edit lib/certmeister/version.rb
bundle
git commit \
  -m "Bump version to v$(bundle exec ruby -Ilib -rcertmeister -e 'puts Certmeister::VERSION')" \
  Gemfile.lock lib/certmeister/version.rb
bundle exec rake release