Repository URL to install this package:
| 
      
        
        
        Version: 
        
         
          
          4.0.116  ▾
        
         | 
ó
±EYc           @   s   d  Z  d d l m Z d d l Z d d l m Z d d l m Z e j j	 Z	 d e j
 f d     YZ
 d e j e
 f d	     YZ d S(
   sX  Base Manager class.
Managers are responsible for a certain aspect of the system.  It is a logical
grouping of code relating to a portion of the system.  In general other
components should be using the manager to make changes to the components that
it is responsible for.
For example, other components that need to deal with volumes in some way,
should do so by calling methods on the VolumeManager instead of directly
changing fields in the database.  This allows us to keep all of the code
relating to volumes in the same place.
We have adopted a basic strategy of Smart managers and dumb data, which means
rather than attaching methods to data objects, components should call manager
methods that act on the data.
Methods on managers that can be executed locally should be called directly. If
a particular method must execute on a remote host, this should be done via rpc
to the service that wraps the manager
Managers should be responsible for most of the db access, and
non-implementation specific data.  Anything implementation specific that can't
be generalized should be done by the Driver.
In general, we prefer to have one manager with multiple drivers for different
implementations, but sometimes it makes sense to have multiple managers.  You
can think of it this way: Abstract different overall strategies at the manager
level(FlatNetwork vs VlanNetwork), and different implementations at the driver
level(LinuxNetDriver vs CiscoNetDriver).
Managers will often provide methods for initial setup of a host or periodic
tasks to a wrapping service.
This module provides Manager, a base class for managers.
iÿÿÿÿ(   t
   periodic_taskN(   t   base(   t   rpct
   PeriodicTasksc           B   s   e  Z d    Z RS(   c         C   s   t  t |   j t  d  S(   N(   t   superR   t   __init__t   CONF(   t   self(    (    sA   /home/tvault/.virtenv/lib/python2.7/site-packages/nova/manager.pyR   A   s    (   t   __name__t
   __module__R   (    (    (    sA   /home/tvault/.virtenv/lib/python2.7/site-packages/nova/manager.pyR   @   s   t   Managerc           B   sS   e  Z d d d  d  Z e d  Z d   Z d   Z d   Z d   Z	 d   Z
 RS(	   t	   undefinedc         C   sk   | s t  j } n  | |  _ d  |  _ | |  _ t j |  j |  j  |  _ g  |  _ t	 t
 |   j |  d  S(   N(   R   t   hostt   Nonet
   backdoor_portt   service_nameR   t   get_notifiert   notifiert   additional_endpointsR   R
   R   (   R   R   t	   db_driverR   (    (    sA   /home/tvault/.virtenv/lib/python2.7/site-packages/nova/manager.pyR   G   s    				c         C   s   |  j  | d | S(   s'   Tasks to be run at a periodic interval.t   raise_on_error(   t   run_periodic_tasks(   R   t   contextR   (    (    sA   /home/tvault/.virtenv/lib/python2.7/site-packages/nova/manager.pyt   periodic_tasksQ   s    c         C   s   d S(   sÙ   Hook to do additional manager initialization when one requests
        the service be started.  This is called before any service record
        is created.
        Child classes should override this method.
        N(    (   R   (    (    sA   /home/tvault/.virtenv/lib/python2.7/site-packages/nova/manager.pyt	   init_hostU   s    c         C   s   d S(   sq   Hook to do cleanup work when the service shuts down.
        Child classes should override this method.
        N(    (   R   (    (    sA   /home/tvault/.virtenv/lib/python2.7/site-packages/nova/manager.pyt   cleanup_host^   s    c         C   s   d S(   s!  Hook to provide the manager the ability to do additional
        start-up work before any RPC queues/consumers are created. This is
        called after other initialization has succeeded and a service
        record is created.
        Child classes should override this method.
        N(    (   R   (    (    sA   /home/tvault/.virtenv/lib/python2.7/site-packages/nova/manager.pyt   pre_start_hooke   s    c         C   s   d S(   sÛ   Hook to provide the manager the ability to do additional
        start-up work immediately after a service creates RPC consumers
        and starts 'running'.
        Child classes should override this method.
        N(    (   R   (    (    sA   /home/tvault/.virtenv/lib/python2.7/site-packages/nova/manager.pyt   post_start_hooko   s    c         C   s   d S(   s   Hook called on SIGHUP to signal the manager to re-read any
        dynamic configuration or do any reconfiguration tasks.
        N(    (   R   (    (    sA   /home/tvault/.virtenv/lib/python2.7/site-packages/nova/manager.pyt   resetx   s    N(   R   R	   R
   R   t   FalseR   R   R   R   R   R   (    (    (    sA   /home/tvault/.virtenv/lib/python2.7/site-packages/nova/manager.pyR
   E   s   
				
		(
   t   __doc__t   oslo_serviceR    t	   nova.conft   novat   nova.dbR   R   t   confR   R   t   BaseR
   (    (    (    sA   /home/tvault/.virtenv/lib/python2.7/site-packages/nova/manager.pyt   <module>4   s