Statistics
| Branch: | Tag: | Revision:

root / ncclient / operations / lock.py @ 9667bcb2

History | View | Annotate | Download (2 kB)

1 179b00d4 Shikhar Bhushan
# Copyright 2h009 Shikhar Bhushan
2 3043ae4a Shikhar Bhushan
#
3 3043ae4a Shikhar Bhushan
# Licensed under the Apache License, Version 2.0 (the "License");
4 3043ae4a Shikhar Bhushan
# you may not use this file except in compliance with the License.
5 3043ae4a Shikhar Bhushan
# You may obtain a copy of the License at
6 3043ae4a Shikhar Bhushan
#
7 3043ae4a Shikhar Bhushan
#    http://www.apache.org/licenses/LICENSE-2.0
8 3043ae4a Shikhar Bhushan
#
9 3043ae4a Shikhar Bhushan
# Unless required by applicable law or agreed to in writing, software
10 3043ae4a Shikhar Bhushan
# distributed under the License is distributed on an "AS IS" BASIS,
11 3043ae4a Shikhar Bhushan
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 3043ae4a Shikhar Bhushan
# See the License for the specific language governing permissions and
13 3043ae4a Shikhar Bhushan
# limitations under the License.
14 3043ae4a Shikhar Bhushan
15 3043ae4a Shikhar Bhushan
'Locking-related NETCONF operations'
16 3043ae4a Shikhar Bhushan
17 9667bcb2 Shikhar Bhushan
from ncclient.xml_ import *
18 ce5fb329 Shikhar Bhushan
19 dd225c7a Shikhar Bhushan
from rpc import RPC
20 6a2dfeb4 Shikhar Bhushan
21 dd225c7a Shikhar Bhushan
# TODO:
22 9667bcb2 Shikhar Bhushan
# should have some way to parse session-id from a lock-denied error, and raise
23 9667bcb2 Shikhar Bhushan
# a tailored exception
24 94803aaf Shikhar Bhushan
25 a6c00291 Shikhar Bhushan
class Lock(RPC):
26 a7cb58ce Shikhar Bhushan
27 216bb34c Shikhar Bhushan
    "*<lock>* RPC"
28 9667bcb2 Shikhar Bhushan
    
29 216bb34c Shikhar Bhushan
    def request(self, target):
30 216bb34c Shikhar Bhushan
        """
31 216bb34c Shikhar Bhushan
        :arg target: see :ref:`source_target`
32 216bb34c Shikhar Bhushan
        :type target: string
33 216bb34c Shikhar Bhushan

34 216bb34c Shikhar Bhushan
        :rtype: :ref:`return`
35 216bb34c Shikhar Bhushan
        """
36 9667bcb2 Shikhar Bhushan
        node = new_ele("lock")
37 9667bcb2 Shikhar Bhushan
        sub_ele(sub_ele(node, "target"), "running")
38 9667bcb2 Shikhar Bhushan
        return self._request(node)
39 6c1f8a66 Shikhar Bhushan
40 6625258b Shikhar Bhushan
41 a6c00291 Shikhar Bhushan
class Unlock(RPC):
42 a7cb58ce Shikhar Bhushan
43 216bb34c Shikhar Bhushan
    "*<unlock>* RPC"
44 9667bcb2 Shikhar Bhushan
    
45 216bb34c Shikhar Bhushan
    def request(self, target):
46 216bb34c Shikhar Bhushan
        """
47 216bb34c Shikhar Bhushan
        :arg target: see :ref:`source_target`
48 216bb34c Shikhar Bhushan
        :type target: string
49 216bb34c Shikhar Bhushan

50 216bb34c Shikhar Bhushan
        :rtype: :ref:`return`
51 216bb34c Shikhar Bhushan
        """
52 9667bcb2 Shikhar Bhushan
        node = new_ele("lock")
53 9667bcb2 Shikhar Bhushan
        sub_ele(sub_ele(node, "target"), "running")
54 9667bcb2 Shikhar Bhushan
        return self._request(node)
55 d6688264 Shikhar Bhushan
56 d6688264 Shikhar Bhushan
57 d6688264 Shikhar Bhushan
class LockContext:
58 a7cb58ce Shikhar Bhushan
59 216bb34c Shikhar Bhushan
    """
60 216bb34c Shikhar Bhushan
    A context manager for the :class:`Lock` / :class:`Unlock` pair of RPC's.
61 0304f041 Shikhar Bhushan
    
62 0304f041 Shikhar Bhushan
    RPC errors are always raised as exceptions.
63 0304f041 Shikhar Bhushan
    
64 216bb34c Shikhar Bhushan
    Initialise with session instance (:class:`Session
65 216bb34c Shikhar Bhushan
    <ncclient.transport.Session>`) and lock target (:ref:`source_target`)
66 216bb34c Shikhar Bhushan
    """
67 216bb34c Shikhar Bhushan
68 179b00d4 Shikhar Bhushan
    def __init__(self, session, target):
69 d6688264 Shikhar Bhushan
        self.session = session
70 d6688264 Shikhar Bhushan
        self.target = target
71 a7cb58ce Shikhar Bhushan
72 d6688264 Shikhar Bhushan
    def __enter__(self):
73 9667bcb2 Shikhar Bhushan
        Lock(self.session).request(self.target)
74 9667bcb2 Shikhar Bhushan
        return self
75 a7cb58ce Shikhar Bhushan
76 179b00d4 Shikhar Bhushan
    def __exit__(self, *args):
77 9667bcb2 Shikhar Bhushan
        Unlock(self.session).request(self.target)
78 d6688264 Shikhar Bhushan
        return False