def generate_network_metadata(cls, cluster): nodes = dict() nm = Cluster.get_network_manager(cluster) for n in Cluster.get_nodes_not_for_deletion(cluster): name = Node.get_slave_name(n) node_roles = Node.all_roles(n) # Use permanent identifier as a node key key = Node.permanent_id(n) ip_by_net = { 'fuelweb_admin': None, 'storage': None, 'management': None, 'public': None } networks = nm.get_node_networks(n) for net in ip_by_net: netgroup = nm.get_network_by_netname(net, networks) if netgroup.get('ip'): ip_by_net[net] = netgroup['ip'].split('/')[0] netw_roles = { 'admin/pxe': ip_by_net['fuelweb_admin'], 'fw-admin': ip_by_net['fuelweb_admin'], 'keystone/api': ip_by_net['management'], 'swift/api': ip_by_net['management'], 'sahara/api': ip_by_net['management'], 'ceilometer/api': ip_by_net['management'], 'cinder/api': ip_by_net['management'], 'glance/api': ip_by_net['management'], 'heat/api': ip_by_net['management'], 'nova/api': ip_by_net['management'], 'murano/api': ip_by_net['management'], 'horizon': ip_by_net['management'], 'management': ip_by_net['management'], 'mgmt/database': ip_by_net['management'], 'mgmt/messaging': ip_by_net['management'], 'mgmt/corosync': ip_by_net['management'], 'mgmt/memcache': ip_by_net['management'], 'mgmt/vip': ip_by_net['management'], 'mongo/db': ip_by_net['management'], 'ceph/public': ip_by_net['management'], 'storage': ip_by_net['storage'], 'ceph/replication': ip_by_net['storage'], 'swift/replication': ip_by_net['storage'], 'cinder/iscsi': ip_by_net['storage'], 'ex': ip_by_net['public'], 'public/vip': ip_by_net['public'], 'ceph/radosgw': ip_by_net['public'], } nodes[key] = { "uid": n.uid, "fqdn": Node.get_node_fqdn(n), "name": name, "user_node_name": n.name, "swift_zone": n.uid, "node_roles": node_roles, "network_roles": netw_roles } return dict(nodes=nodes, vips=nm.assign_vips_for_net_groups(cluster))
def generate_network_metadata(cls, cluster): nodes = dict() nm = Cluster.get_network_manager(cluster) for n in Cluster.get_nodes_not_for_deletion(cluster): name = Node.get_slave_name(n) node_roles = Node.all_roles(n) # Use permanent identifier as a node key key = Node.permanent_id(n) ip_by_net = { 'fuelweb_admin': None, 'storage': None, 'management': None, 'public': None } networks = nm.get_node_networks(n) for net in ip_by_net: netgroup = nm.get_network_by_netname(net, networks) if netgroup.get('ip'): ip_by_net[net] = netgroup['ip'].split('/')[0] netw_roles = { 'admin/pxe': ip_by_net['fuelweb_admin'], 'fw-admin': ip_by_net['fuelweb_admin'], 'keystone/api': ip_by_net['management'], 'swift/api': ip_by_net['management'], 'sahara/api': ip_by_net['management'], 'ceilometer/api': ip_by_net['management'], 'cinder/api': ip_by_net['management'], 'glance/api': ip_by_net['management'], 'heat/api': ip_by_net['management'], 'nova/api': ip_by_net['management'], 'murano/api': ip_by_net['management'], 'horizon': ip_by_net['management'], 'management': ip_by_net['management'], 'mgmt/database': ip_by_net['management'], 'mgmt/messaging': ip_by_net['management'], 'mgmt/corosync': ip_by_net['management'], 'mgmt/memcache': ip_by_net['management'], 'mgmt/vip': ip_by_net['management'], 'mongo/db': ip_by_net['management'], 'ceph/public': ip_by_net['management'], 'storage': ip_by_net['storage'], 'ceph/replication': ip_by_net['storage'], 'swift/replication': ip_by_net['storage'], 'cinder/iscsi': ip_by_net['storage'], 'ex': ip_by_net['public'], 'public/vip': ip_by_net['public'], 'ceph/radosgw': ip_by_net['public'], } nodes[key] = { "uid": n.uid, "fqdn": Node.get_node_fqdn(n), "name": name, "user_node_name": n.name, "swift_zone": n.uid, "node_roles": node_roles, "network_roles": netw_roles } return dict( nodes=nodes, vips=nm.assign_vips_for_net_groups(cluster) )