aboutsummaryrefslogtreecommitdiffstats
path: root/network/ports/storage_from_pool_v6.yaml
blob: 966d96ae4653d46348fb301639d4138a3e337412 (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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
heat_template_version: 2015-04-30

description: >
  Returns an IP from a network mapped list of IPs. This version is for IPv6
  addresses. The ip_address_uri output will have brackets for use in URLs.

parameters:
  StorageNetName:
    description: Name of the storage network
    default: storage
    type: string
  PortName:
    description: Name of the port
    default: ''
    type: string
  ControlPlaneIP: # Here for compatability with noop.yaml
    description: IP address on the control plane
    default: ''
    type: string
  IPPool:
    default: {}
    description: A network mapped list of IPs
    type: json
  NodeIndex:
    default: 0
    description: Index of the IP to get from Pool
    type: number
  StorageNetCidr:
    default: 'fd00:fd00:fd00:3000::/64'
    description: Cidr for the storage network.
    type: string

outputs:
  ip_address:
    description: storage network IP
    value: {get_param: [IPPool, {get_param: StorageNetName}, {get_param: NodeIndex}]}
  ip_address_uri:
    description: storage network IP (for compatibility with storage_v6.yaml)
    value:
          list_join:
          - ''
          - - '['
            - {get_param: [IPPool, {get_param: StorageNetName}, {get_param: NodeIndex}]}
            - ']'
  ip_subnet:
    # FIXME: this assumes a 2 digit subnet CIDR (need more heat functions?)
    description: IP/Subnet CIDR for the storage network IP
    value:
      list_join:
      - ''
      - - {get_param: [IPPool, {get_param: StorageNetName}, {get_param: NodeIndex}]}
        - '/'
        - {get_param: [StorageNetCidr, -2]}
        - {get_param: [StorageNetCidr, -1]}