Puppet Function: tinc_keygen
- Defined in:
- lib/puppet/parser/functions/tinc_keygen.rb
- Function type:
- Ruby 3.x API
Overview
Returns an array containing the tinc private and public (in this order) key.
| 19 20 21 22 23 24 25 26 27 28 29 30 31 | # File 'lib/puppet/parser/functions/tinc_keygen.rb', line 19 Puppet::Parser::Functions::newfunction(:tinc_keygen, :type => :rvalue, :doc => "Returns an array containing the tinc private and public (in this order) key.") do |args| raise Puppet::ParseError, "There must be exactly one argument, the directory in which keys are created" if args.to_a.length != 1 dir = args.to_a[0] ::FileUtils.mkdir_p(dir) private_key_path = File.join(dir, "rsa_key.priv") public_key_path = File.join(dir, "rsa_key.pub") if ! File.exists?(private_key_path) || ! File.exists?(public_key_path) output = Puppet::Util::Execution.execute(['/usr/sbin/tincd', '--config', dir, '--generate-keys']) raise Puppet::ParseError, "/usr/sbin/tincd --config #{dir} --generate-keys output does not match the 'Generating .* bits keys' regular expression. #{output}" unless output =~ /Generating .* bits keys/ end [ File.read(private_key_path), File.read(public_key_path) ] end |