怎樣寫 OpenStack Neutron 的 Extension (四)


上文說到需要在 /neutronclient/v2_0/myextension/extension.py 中分別定義五個 class:List/Show/Create/Delete/UpdateExtension。具體形式如下:

import argparse
import logging

from neutronclient.neutron import v2_0 as neutronV20
from neutronclient.openstack.common.gettextutils import _

RESOURCE = 'myextension'
class ListExtension(neutronV20.ListCommand): """List extensions""" resource = RESOURCE log = logging.getLogger(__name__ + '.ListExtension') list_columns = ['id', 'name'] class ShowExtension(neutronV20.ShowCommand): """Show information of a given extension.""" resource = RESOURCE log = logging.getLogger(__name__ + '.ShowExtension') class CreatePhysicalGateway(neutronV20.CreateCommand): """Create an extension.""" resource = RESOURCE log = logging.getLogger(__name__ + '.CreateExtension') def add_known_arguments(self, parser): parser.add_argument( 'name', metavar='NAME', help=_('Name of extension to create')) def args2body(self, parsed_args): body = {self.resource: { 'name': parsed_args.name}} return body

class UpdateExtension(neutronV20.UpdateCommand):
    """update a given extension.""" resource = RESOURCE log = logging.getLogger(__name__ + '.UpdateExtension') 
class DeleteExtension(neutronV20.DeleteCommand):
    """Delete a given extension."""

    resource = RESOURCE
    log = logging.getLogger(__name__ + '.DeleteExtension')       

這些 class 處在接受 CLI 命令的第一線,負責將命令轉化成 API call。需要特別注意的是 CreateExtension 這個類,它有兩個方法 add_known_arguments 和 args2body。前者定義了 CLI 命令接受哪些參數,后者規定如何將收到的參數打包起來。

這些參數打包之后就會發給 neutron 后台中我們自己定義的 plugin controller,但是如何發送這些參數還需要我們去 /neutronclient/v2_0/client.py 的 Client 類中設置:

首先是 uri 路徑:

    myextensions_path = "/myextensions"
    myextension_path = "/myextensions/%s"

然后是每個操作所對應的傳遞方法:

   @APIParamsCall
    def list_myextensions(self, retrieve_all=True, **_params):
        """Fetches a list of all myextensions for a tenant."""
        return self.list('myextensions', self.myextensions_path, retrieve_all,
                         **_params)
                         
    @APIParamsCall
    def show_myextension(self, myextension, **_params):
        """Fetches information of a certain entry in myextension."""
        return self.get(self.myextension_path % (myextension), params=_params)
        
    @APIParamsCall
    def create_myextension(self, body=None):
        """Creates a new myextension entry."""
        return self.post(self.myextensions_path, body=body)
        
    @APIParamsCall
    def delete_myextension(self, myextension):
        """Deletes the specified myextension."""
        return self.delete(self.myextension_path % (myextension))

   @APIParamsCall
    def update_myextension(self, myextension, body=None):
        """Updates a myextension."""
        return self.put(self.myextension_path % (myextension), body=body)

如此一來,我們自己實現的 neutron plugin 就能夠收到 CLI 發送過來的命令啦。

下一章再來說說怎么修改 OpenStack 的 Dashboard 來顯示我們在 extension 中添加的新元素。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM