e5b9078f4c
Fixing files 93/93 files fixed Change-Id: Ia30f2e2253806fa5f447d44208d13d2c0beba9cd
111 lines
3.6 KiB
Python
111 lines
3.6 KiB
Python
# vim: tabstop=4 shiftwidth=4 softtabstop=4
|
|
|
|
# Copyright 2011 OpenStack LLC.
|
|
# All Rights Reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
|
|
from abc import abstractmethod
|
|
|
|
from quantum.extensions import extensions
|
|
from quantum.openstack.common import jsonutils
|
|
from quantum import wsgi
|
|
|
|
|
|
class FoxInSocksController(wsgi.Controller):
|
|
|
|
def index(self, request):
|
|
return "Try to say this Mr. Knox, sir..."
|
|
|
|
|
|
class FoxInSocksPluginInterface(extensions.PluginInterface):
|
|
|
|
@abstractmethod
|
|
def method_to_support_foxnsox_extension(self):
|
|
pass
|
|
|
|
|
|
class Foxinsocks(object):
|
|
|
|
def __init__(self):
|
|
pass
|
|
|
|
def get_plugin_interface(self):
|
|
return FoxInSocksPluginInterface
|
|
|
|
def get_name(self):
|
|
return "Fox In Socks"
|
|
|
|
def get_alias(self):
|
|
return "FOXNSOX"
|
|
|
|
def get_description(self):
|
|
return "The Fox In Socks Extension"
|
|
|
|
def get_namespace(self):
|
|
return "http://www.fox.in.socks/api/ext/pie/v1.0"
|
|
|
|
def get_updated(self):
|
|
return "2011-01-22T13:25:27-06:00"
|
|
|
|
def get_resources(self):
|
|
resources = []
|
|
resource = extensions.ResourceExtension('foxnsocks',
|
|
FoxInSocksController())
|
|
resources.append(resource)
|
|
return resources
|
|
|
|
def get_actions(self):
|
|
return [extensions.ActionExtension('dummy_resources',
|
|
'FOXNSOX:add_tweedle',
|
|
self._add_tweedle_handler),
|
|
extensions.ActionExtension('dummy_resources',
|
|
'FOXNSOX:delete_tweedle',
|
|
self._delete_tweedle_handler)]
|
|
|
|
def get_request_extensions(self):
|
|
request_exts = []
|
|
|
|
def _goose_handler(req, res):
|
|
#NOTE: This only handles JSON responses.
|
|
# You can use content type header to test for XML.
|
|
data = jsonutils.loads(res.body)
|
|
data['FOXNSOX:googoose'] = req.GET.get('chewing')
|
|
res.body = jsonutils.dumps(data)
|
|
return res
|
|
|
|
req_ext1 = extensions.RequestExtension('GET', '/dummy_resources/:(id)',
|
|
_goose_handler)
|
|
request_exts.append(req_ext1)
|
|
|
|
def _bands_handler(req, res):
|
|
#NOTE: This only handles JSON responses.
|
|
# You can use content type header to test for XML.
|
|
data = jsonutils.loads(res.body)
|
|
data['FOXNSOX:big_bands'] = 'Pig Bands!'
|
|
res.body = jsonutils.dumps(data)
|
|
return res
|
|
|
|
req_ext2 = extensions.RequestExtension('GET', '/dummy_resources/:(id)',
|
|
_bands_handler)
|
|
request_exts.append(req_ext2)
|
|
return request_exts
|
|
|
|
def _add_tweedle_handler(self, input_dict, req, id):
|
|
return "Tweedle {0} Added.".format(
|
|
input_dict['FOXNSOX:add_tweedle']['name'])
|
|
|
|
def _delete_tweedle_handler(self, input_dict, req, id):
|
|
return "Tweedle {0} Deleted.".format(
|
|
input_dict['FOXNSOX:delete_tweedle']['name'])
|