Top Level Namespace

Defined Under Namespace

Modules: Terrafying Classes: Hash

Constant Summary collapse

IN4MASK =
0xffffffff
PORT_NAMES =
{
  22 => "ssh",
  80 => "http",
  443 => "https",
  1194 => "openvpn",
}

Instance Method Summary collapse

Instance Method Details

#cidr_to_split_address(raw_cidr) ⇒ Object



11
12
13
14
15
16
17
18
19
20
21
22
# File 'lib/terrafying/components/vpn.rb', line 11

def cidr_to_split_address(raw_cidr)
  cidr = NetAddr::CIDR.create(raw_cidr)

  masklen = 32 - cidr.bits
  maskaddr = ((IN4MASK >> masklen) << masklen)

  maskip = (0..3).map { |i|
    (maskaddr >> (24 - 8 * i)) & 0xff
  }.join('.')

  return "#{cidr.first} #{maskip}"
end

#enrich_ports(ports) ⇒ Object



9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
# File 'lib/terrafying/components/ports.rb', line 9

def enrich_ports(ports)
  ports.map { |port|
    if port.is_a?(Numeric)
      port = { upstream_port: port, downstream_port: port }
    end

    if port.has_key?(:number)
      port[:upstream_port] = port[:number]
      port[:downstream_port] = port[:number]
    end

    port = {
      type: "tcp",
      name: PORT_NAMES.fetch(port[:upstream_port], port[:upstream_port].to_s),
    }.merge(port)

    port
  }
end

#from_port(port) ⇒ Object



29
30
31
32
# File 'lib/terrafying/components/ports.rb', line 29

def from_port(port)
  return port unless port_range?(port)
  port.split('-').first.to_i
end

#is_l4_port(port) ⇒ Object



43
44
45
# File 'lib/terrafying/components/ports.rb', line 43

def is_l4_port(port)
  port[:type] == "tcp" || port[:type] == "udp"
end

#is_l7_port(port) ⇒ Object



47
48
49
# File 'lib/terrafying/components/ports.rb', line 47

def is_l7_port(port)
  port[:type] == "http" || port[:type] == "https"
end

#port_range?(port) ⇒ Boolean

Returns:

  • (Boolean)


39
40
41
# File 'lib/terrafying/components/ports.rb', line 39

def port_range?(port)
  port.is_a?(String) && port.match(/[0-9]+-[0-9]+/)
end

#to_port(port) ⇒ Object



34
35
36
37
# File 'lib/terrafying/components/ports.rb', line 34

def to_port(port)
  return port unless port_range?(port)
  port.split('-').last.to_i
end