
This patch rehomes neutron.common.utils.is_port_trusted into neutron_lib.utils.net. UTs and a release note included as well. Change-Id: I0a32ccb3b80809f1df0a07aa0b4546bca16e1c2c
55 lines
1.6 KiB
Python
55 lines
1.6 KiB
Python
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
|
|
# implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
import random
|
|
import socket
|
|
|
|
from neutron_lib import constants
|
|
|
|
|
|
def get_hostname():
|
|
"""Get the hostname of the system.
|
|
|
|
:returns: The hostname of the system.
|
|
"""
|
|
return socket.gethostname()
|
|
|
|
|
|
def get_random_mac(base_mac):
|
|
"""Get a random MAC address string of the specified base format.
|
|
|
|
Any part that is '00' will be randomized
|
|
|
|
:param base_mac: Base MAC address represented by an array of 6 strings/int
|
|
:returns: The MAC address string.
|
|
"""
|
|
|
|
return ':'.join(
|
|
"{:02x}".format(random.randint(0x00, 0xff))if p == '00' else p
|
|
for p in base_mac
|
|
)
|
|
|
|
|
|
def is_port_trusted(port):
|
|
"""Used to determine if port can be trusted not to attack network.
|
|
|
|
Trust is currently based on the device_owner field starting with 'network:'
|
|
since we restrict who can use that in the default policy.json file.
|
|
|
|
:param port: The port dict to inspect the 'device_owner' for.
|
|
:returns: True if the port dict's 'device_owner' value starts with the
|
|
networking prefix. False otherwise.
|
|
"""
|
|
return port['device_owner'].startswith(
|
|
constants.DEVICE_OWNER_NETWORK_PREFIX)
|