This file is indexed.

/usr/share/pyshared/juju/state/placement.py is in juju-0.7 0.7-0ubuntu2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

 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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
"""Various unit placement strategies for use in deploy and add-unit.

The API used by the `place_unit` method is:

machine_state = yield placement_strategy(zk_client,
                                         machine_state_manager,
                                         unit_state)

The placement strategy is passed the machine manager for the
deployment and the unit_state it is attempting to place. According to
its policy it should yield back the machine_state for where it placed
the unit.
"""

from twisted.internet.defer import inlineCallbacks, returnValue

from juju.state.errors import NoUnusedMachines
from juju.errors import InvalidPlacementPolicy, JujuError
from juju.state.machine import MachineStateManager

LOCAL_POLICY = "local"
UNASSIGNED_POLICY = "unassigned"


@inlineCallbacks
def _local_placement(client, machine_state_manager, unit_state):
    """Assigns unit to the machine/0, aka the bootstrap node.

    Primary use is intended for local development.
    """
    machine = yield machine_state_manager.get_machine_state(0)
    yield unit_state.assign_to_machine(machine)
    returnValue(machine)


@inlineCallbacks
def _unassigned_placement(client, machine_state_manager, unit_state):
    """Assigns unit on a machine, without any units, which satisfies
    unit_state's constraints.

    If no such machine is found, a new machine is created, and the
    unit assigned to it.
    """
    try:
        machine = yield unit_state.assign_to_unused_machine()
    except NoUnusedMachines:
        constraints = yield unit_state.get_constraints()
        machine = yield machine_state_manager.add_machine_state(constraints)
        yield unit_state.assign_to_machine(machine)
    returnValue(machine)


_PLACEMENT_LOOKUP = {
    LOCAL_POLICY: _local_placement,
    UNASSIGNED_POLICY: _unassigned_placement,
    }


def pick_policy(preference, provider):
    policies = provider.get_placement_policies()
    if not preference:
        return policies[0]
    if preference not in policies:
        raise InvalidPlacementPolicy(
            preference, provider.provider_type, policies)
    return preference


def place_unit(client, policy_name, unit_state):
    """Return machine state of unit_states assignment.

    :param client: A connected zookeeper client.
    :param policy_name: The name of the unit placement policy.
    :param unit_state: The unit to be assigned.
    :param provider_type: The type of the machine environment provider.
    """

    machine_state_manager = MachineStateManager(client)

    # default policy handling
    if policy_name is None:
        placement = _unassigned_placement
    else:
        placement = _PLACEMENT_LOOKUP.get(policy_name)
        if placement is None:
            # We should never get here, pick policy should always pick valid.
            raise JujuError("Invalid policy:%r for provider" % policy_name)

    return placement(client, machine_state_manager, unit_state)