summaryrefslogtreecommitdiff
path: root/lib/leap_cli/macros/secrets.rb
blob: 8d1feb55ef5bf33049924b6b3a9ac93554b9728d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# encoding: utf-8

require 'base32'

module LeapCli
  module Macro

    #
    # inserts a named secret, generating it if needed.
    #
    # manager.export_secrets should be called later to capture any newly generated secrets.
    #
    # +length+ is the character length of the generated password.
    #
    def secret(name, length=32)
      manager.secrets.set(name, @node.environment) { Util::Secret.generate(length) }
    end

    # inserts a base32 encoded secret
    def base32_secret(name, length=20)
      manager.secrets.set(name, @node.environment) { Base32.encode(Util::Secret.generate(length)) }
    end

    # Picks a random obfsproxy port from given range
    def rand_range(name, range)
      manager.secrets.set(name, @node.environment) { rand(range) }
    end

    #
    # inserts an hexidecimal secret string, generating it if needed.
    #
    # +bit_length+ is the bits in the secret, (ie length of resulting hex string will be bit_length/4)
    #
    def hex_secret(name, bit_length=128)
      manager.secrets.set(name, @node.environment) { Util::Secret.generate_hex(bit_length) }
    end

  end
end