Completed
Pull Request — master (#460)
by Manas
02:32
created

get_managed_entity()   B

Complexity

Conditions 6

Size

Total Lines 8

Duplication

Lines 0
Ratio 0 %
Metric Value
cc 6
dl 0
loc 8
rs 8
1
from pyVmomi import vim
2
3
4
def get_managed_entity(content, vimtype, moid=None, name=None):
5
    container = content.viewManager.CreateContainerView(content.rootFolder, [vimtype], True)
6
    for entity in container.view:
7
        # verify if this works.
8
        if moid and entity._moId == moid:
0 ignored issues
show
Coding Style Best Practice introduced by
It seems like _moId was declared protected and should not be accessed from this context.

Prefixing a member variable _ is usually regarded as the equivalent of declaring it with protected visibility that exists in other languages. Consequentially, such a member should only be accessed from the same class or a child class:

class MyParent:
    def __init__(self):
        self._x = 1;
        self.y = 2;

class MyChild(MyParent):
    def some_method(self):
        return self._x    # Ok, since accessed from a child class

class AnotherClass:
    def some_method(self, instance_of_my_child):
        return instance_of_my_child._x   # Would be flagged as AnotherClass is not
                                         # a child class of MyParent
Loading history...
9
            return entity
10
        elif name and entity.name == name:
11
            return entity
12
13
14
def get_datacenter(content, moid=None, name=None):
15
    return get_managed_entity(content, vim.Datacenter, moid=moid, name=name)
16
17
18
def get_folder(content, moid=None, name=None):
19
    return get_managed_entity(content, vim.Folder, moid=moid, name=name)
20
21
22
def get_resource_pool(content, moid=None, name=None):
23
    return get_managed_entity(content, vim.ResourcePool, moid=moid, name=name)
24
25
26
def get_datastore(content, moid=None, name=None):
27
    return get_managed_entity(content, vim.Datastore, moid=moid, name=name)
28
29
30
def get_network(content, moid=None, name=None):
31
    return get_managed_entity(content, vim.Network, moid=moid, name=name)
32
33
34
def get_virtualmachine(content, moid=None, name=None):
35
    return get_managed_entity(content, vim.VirtualMachine, moid=moid, name=name)
36
37
38
def get_task(content, moid=None):
39
    return get_managed_entity(content, vim.Task, moid=moid, name=None)
40