summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2012-11-30 16:35:47 +0000
committerGerrit Code Review <review@openstack.org>2012-11-30 16:35:47 +0000
commitf19fc49b220632a3d4005ed416121c1dfd0c4f8b (patch)
tree2459f3eec43e5b2622bb785b977750263329981a
parentb3d8a823d33a4d4e42e814d4b31cea6e6587745f (diff)
parent0bf27df376ae45a0dd23d37f099afe57ec05ad86 (diff)
downloadnova-f19fc49b220632a3d4005ed416121c1dfd0c4f8b.tar.gz
nova-f19fc49b220632a3d4005ed416121c1dfd0c4f8b.tar.xz
nova-f19fc49b220632a3d4005ed416121c1dfd0c4f8b.zip
Merge "Add vpn ip/port setting support for CloudPipe"
-rw-r--r--doc/api_samples/all_extensions/extensions-get-resp.json8
-rw-r--r--doc/api_samples/all_extensions/extensions-get-resp.xml3
-rw-r--r--doc/api_samples/os-cloudpipe-update/cloud-pipe-update-req.json6
-rw-r--r--doc/api_samples/os-cloudpipe-update/cloud-pipe-update-req.xml5
-rw-r--r--etc/nova/policy.json1
-rw-r--r--nova/api/openstack/compute/contrib/cloudpipe_update.py78
-rw-r--r--nova/tests/api/openstack/compute/contrib/test_cloudpipe_update.py73
-rw-r--r--nova/tests/api/openstack/compute/test_extensions.py1
-rw-r--r--nova/tests/integrated/api_samples/all_extensions/extensions-get-resp.json.tpl8
-rw-r--r--nova/tests/integrated/api_samples/all_extensions/extensions-get-resp.xml.tpl3
-rw-r--r--nova/tests/integrated/api_samples/os-cloudpipe-update/cloud-pipe-update-req.json.tpl6
-rw-r--r--nova/tests/integrated/api_samples/os-cloudpipe-update/cloud-pipe-update-req.xml.tpl5
-rw-r--r--nova/tests/integrated/test_api_samples.py28
-rw-r--r--nova/tests/policy.json1
14 files changed, 226 insertions, 0 deletions
diff --git a/doc/api_samples/all_extensions/extensions-get-resp.json b/doc/api_samples/all_extensions/extensions-get-resp.json
index f34eec0a3..399d937a7 100644
--- a/doc/api_samples/all_extensions/extensions-get-resp.json
+++ b/doc/api_samples/all_extensions/extensions-get-resp.json
@@ -97,6 +97,14 @@
"updated": "2011-12-16T00:00:00+00:00"
},
{
+ "alias": "os-cloudpipe-update",
+ "description": "Adds the ability to set the vpn ip/port for cloudpipe instances.",
+ "links": [],
+ "name": "CloudpipeUpdate",
+ "namespace": "http://docs.openstack.org/compute/ext/cloudpipe-update/api/v2",
+ "updated": "2012-11-14T00:00:00+00:00"
+ },
+ {
"alias": "os-config-drive",
"description": "Config Drive Extension",
"links": [],
diff --git a/doc/api_samples/all_extensions/extensions-get-resp.xml b/doc/api_samples/all_extensions/extensions-get-resp.xml
index 78dd425a7..e4d3b8cc3 100644
--- a/doc/api_samples/all_extensions/extensions-get-resp.xml
+++ b/doc/api_samples/all_extensions/extensions-get-resp.xml
@@ -48,6 +48,9 @@
a SSH Bastion host is forthcoming.
</description>
</extension>
+ <extension alias="os-cloudpipe-update" updated="2012-11-14T00:00:00+00:00" namespace="http://docs.openstack.org/compute/ext/cloudpipe-update/api/v2" name="CloudpipeUpdate">
+ <description>Adds the ability to set the vpn ip/port for cloudpipe instances.</description>
+ </extension>
<extension alias="os-config-drive" updated="2012-07-16T00:00:00+00:00" namespace="http://docs.openstack.org/compute/ext/config_drive/api/v1.1" name="ConfigDrive">
<description>Config Drive Extension</description>
</extension>
diff --git a/doc/api_samples/os-cloudpipe-update/cloud-pipe-update-req.json b/doc/api_samples/os-cloudpipe-update/cloud-pipe-update-req.json
new file mode 100644
index 000000000..7882765b4
--- /dev/null
+++ b/doc/api_samples/os-cloudpipe-update/cloud-pipe-update-req.json
@@ -0,0 +1,6 @@
+{
+ "configure_project": {
+ "vpn_ip": "192.168.1.1",
+ "vpn_port": "2000"
+ }
+} \ No newline at end of file
diff --git a/doc/api_samples/os-cloudpipe-update/cloud-pipe-update-req.xml b/doc/api_samples/os-cloudpipe-update/cloud-pipe-update-req.xml
new file mode 100644
index 000000000..253b0426a
--- /dev/null
+++ b/doc/api_samples/os-cloudpipe-update/cloud-pipe-update-req.xml
@@ -0,0 +1,5 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<configure_project>
+ <vpn_ip>192.168.1.1</vpn_ip>
+ <vpn_port>2000</vpn_port>
+</configure_project> \ No newline at end of file
diff --git a/etc/nova/policy.json b/etc/nova/policy.json
index 857613edc..778203e75 100644
--- a/etc/nova/policy.json
+++ b/etc/nova/policy.json
@@ -30,6 +30,7 @@
"compute_extension:aggregates": "rule:admin_api",
"compute_extension:certificates": "",
"compute_extension:cloudpipe": "rule:admin_api",
+ "compute_extension:cloudpipe_update": "rule:admin_api",
"compute_extension:console_output": "",
"compute_extension:consoles": "",
"compute_extension:createserverext": "",
diff --git a/nova/api/openstack/compute/contrib/cloudpipe_update.py b/nova/api/openstack/compute/contrib/cloudpipe_update.py
new file mode 100644
index 000000000..e4a200c81
--- /dev/null
+++ b/nova/api/openstack/compute/contrib/cloudpipe_update.py
@@ -0,0 +1,78 @@
+# vim: tabstop=4 shiftwidth=4 softtabstop=4
+
+# Copyright 2012 IBM
+# 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.
+
+
+import webob.exc
+
+from nova.api.openstack.compute.contrib import cloudpipe
+from nova.api.openstack import extensions
+from nova.api.openstack import wsgi
+from nova import db
+from nova import exception
+from nova.openstack.common import log as logging
+
+LOG = logging.getLogger(__name__)
+authorize = extensions.extension_authorizer('compute', 'cloudpipe_update')
+
+
+class CloudpipeUpdateController(wsgi.Controller):
+ """Handle updating the vpn ip/port for cloudpipe instances."""
+
+ def __init__(self):
+ super(CloudpipeUpdateController, self).__init__()
+
+ @wsgi.action("update")
+ def update(self, req, id, body):
+ """Configure cloudpipe parameters for the project"""
+
+ context = req.environ['nova.context']
+ authorize(context)
+
+ if id != "configure-project":
+ msg = _("Unknown action %s") % id
+ raise webob.exc.HTTPBadRequest(explanation=msg)
+
+ project_id = context.project_id
+
+ try:
+ params = body['configure_project']
+ vpn_ip = params['vpn_ip']
+ vpn_port = params['vpn_port']
+ except (TypeError, KeyError):
+ raise webob.exc.HTTPUnprocessableEntity()
+
+ networks = db.project_get_networks(context, project_id)
+ for network in networks:
+ db.network_update(context, network['id'],
+ {'vpn_public_address': vpn_ip,
+ 'vpn_public_port': int(vpn_port)})
+ return webob.exc.HTTPAccepted()
+
+
+class Cloudpipe_update(extensions.ExtensionDescriptor):
+ """Adds the ability to set the vpn ip/port for cloudpipe instances."""
+
+ name = "CloudpipeUpdate"
+ alias = "os-cloudpipe-update"
+ namespace = "http://docs.openstack.org/compute/ext/cloudpipe-update/api/v2"
+ updated = "2012-11-14T00:00:00+00:00"
+
+ def get_controller_extensions(self):
+ controller = CloudpipeUpdateController()
+ extension = extensions.ControllerExtension(self, 'os-cloudpipe',
+ controller)
+ return [extension]
diff --git a/nova/tests/api/openstack/compute/contrib/test_cloudpipe_update.py b/nova/tests/api/openstack/compute/contrib/test_cloudpipe_update.py
new file mode 100644
index 000000000..ed2c0869e
--- /dev/null
+++ b/nova/tests/api/openstack/compute/contrib/test_cloudpipe_update.py
@@ -0,0 +1,73 @@
+# Copyright 2012 IBM
+# 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.
+
+import webob
+
+from nova.api.openstack.compute.contrib import cloudpipe_update
+from nova.api.openstack import wsgi
+from nova import db
+from nova import test
+from nova.tests.api.openstack import fakes
+from nova.tests import fake_network
+
+
+fake_networks = [fake_network.fake_network(1),
+ fake_network.fake_network(2)]
+
+
+def fake_project_get_networks(context, project_id, associate=True):
+ return fake_networks
+
+
+def fake_network_update(context, network_id, values):
+ for network in fake_networks:
+ if network['id'] == network_id:
+ for key in values:
+ network[key] = values[key]
+
+
+class CloudpipeUpdateTest(test.TestCase):
+
+ def setUp(self):
+ super(CloudpipeUpdateTest, self).setUp()
+ self.controller = cloudpipe_update.CloudpipeUpdateController()
+ self.stubs.Set(db, "project_get_networks", fake_project_get_networks)
+ self.stubs.Set(db, "network_update", fake_network_update)
+
+ def test_cloudpipe_configure_project(self):
+ req = fakes.HTTPRequest.blank(
+ '/v2/fake/os-cloudpipe/configure-project')
+ body = {"configure_project": {"vpn_ip": "1.2.3.4", "vpn_port": 222}}
+ result = self.controller.update(req, 'configure-project',
+ body=body)
+ self.assertEqual('202 Accepted', result.status)
+ self.assertEqual(fake_networks[0]['vpn_public_address'], "1.2.3.4")
+ self.assertEqual(fake_networks[0]['vpn_public_port'], 222)
+
+ def test_cloudpipe_configure_project_bad_url(self):
+ req = fakes.HTTPRequest.blank(
+ '/v2/fake/os-cloudpipe/configure-projectx')
+ body = {"vpn_ip": "1.2.3.4", "vpn_port": 222}
+ self.assertRaises(webob.exc.HTTPBadRequest,
+ self.controller.update, req,
+ 'configure-projectx', body)
+
+ def test_cloudpipe_configure_project_bad_data(self):
+ req = fakes.HTTPRequest.blank(
+ '/v2/fake/os-cloudpipe/configure-project')
+ body = {"vpn_ipxx": "1.2.3.4", "vpn_port": 222}
+ self.assertRaises(webob.exc.HTTPUnprocessableEntity,
+ self.controller.update, req,
+ 'configure-project', body)
diff --git a/nova/tests/api/openstack/compute/test_extensions.py b/nova/tests/api/openstack/compute/test_extensions.py
index 82278c4fc..eab55f95e 100644
--- a/nova/tests/api/openstack/compute/test_extensions.py
+++ b/nova/tests/api/openstack/compute/test_extensions.py
@@ -160,6 +160,7 @@ class ExtensionControllerTest(ExtensionTestCase):
"AvailabilityZone",
"Certificates",
"Cloudpipe",
+ "CloudpipeUpdate",
"ConsoleOutput",
"Consoles",
"Createserverext",
diff --git a/nova/tests/integrated/api_samples/all_extensions/extensions-get-resp.json.tpl b/nova/tests/integrated/api_samples/all_extensions/extensions-get-resp.json.tpl
index 6ac33b933..65cbb4889 100644
--- a/nova/tests/integrated/api_samples/all_extensions/extensions-get-resp.json.tpl
+++ b/nova/tests/integrated/api_samples/all_extensions/extensions-get-resp.json.tpl
@@ -97,6 +97,14 @@
"updated": "%(timestamp)s"
},
{
+ "alias": "os-cloudpipe-update",
+ "description": "%(text)s",
+ "links": [],
+ "name": "CloudpipeUpdate",
+ "namespace": "http://docs.openstack.org/compute/ext/cloudpipe-update/api/v2",
+ "updated": "%(timestamp)s"
+ },
+ {
"alias": "os-config-drive",
"description": "%(text)s",
"links": [],
diff --git a/nova/tests/integrated/api_samples/all_extensions/extensions-get-resp.xml.tpl b/nova/tests/integrated/api_samples/all_extensions/extensions-get-resp.xml.tpl
index 1fca0eb2c..bdef0266c 100644
--- a/nova/tests/integrated/api_samples/all_extensions/extensions-get-resp.xml.tpl
+++ b/nova/tests/integrated/api_samples/all_extensions/extensions-get-resp.xml.tpl
@@ -36,6 +36,9 @@
<extension alias="os-cloudpipe" updated="%(timestamp)s" namespace="http://docs.openstack.org/compute/ext/cloudpipe/api/v1.1" name="Cloudpipe">
<description>%(text)s</description>
</extension>
+ <extension alias="os-cloudpipe-update" updated="%(timestamp)s" name="CloudpipeUpdate" namespace="http://docs.openstack.org/compute/ext/cloudpipe-update/api/v2">
+ <description>%(text)s</description>
+ </extension>
<extension alias="os-config-drive" updated="%(timestamp)s" namespace="http://docs.openstack.org/compute/ext/config_drive/api/v1.1" name="ConfigDrive">
<description>%(text)s</description>
</extension>
diff --git a/nova/tests/integrated/api_samples/os-cloudpipe-update/cloud-pipe-update-req.json.tpl b/nova/tests/integrated/api_samples/os-cloudpipe-update/cloud-pipe-update-req.json.tpl
new file mode 100644
index 000000000..0ab9141ae
--- /dev/null
+++ b/nova/tests/integrated/api_samples/os-cloudpipe-update/cloud-pipe-update-req.json.tpl
@@ -0,0 +1,6 @@
+{
+ "configure_project": {
+ "vpn_ip": "%(vpn_ip)s",
+ "vpn_port": "%(vpn_port)s"
+ }
+}
diff --git a/nova/tests/integrated/api_samples/os-cloudpipe-update/cloud-pipe-update-req.xml.tpl b/nova/tests/integrated/api_samples/os-cloudpipe-update/cloud-pipe-update-req.xml.tpl
new file mode 100644
index 000000000..34d2be9df
--- /dev/null
+++ b/nova/tests/integrated/api_samples/os-cloudpipe-update/cloud-pipe-update-req.xml.tpl
@@ -0,0 +1,5 @@
+<?xml version='1.0' encoding='UTF-8'?>
+<configure_project>
+ <vpn_ip>%(vpn_ip)s</vpn_ip>
+ <vpn_port>%(vpn_port)s</vpn_port>
+</configure_project>
diff --git a/nova/tests/integrated/test_api_samples.py b/nova/tests/integrated/test_api_samples.py
index a1b71c2d8..841faeb00 100644
--- a/nova/tests/integrated/test_api_samples.py
+++ b/nova/tests/integrated/test_api_samples.py
@@ -1256,6 +1256,34 @@ class CloudPipeSampleXmlTest(CloudPipeSampleJsonTest):
ctype = "xml"
+class CloudPipeUpdateJsonTest(ApiSampleTestBase):
+ extension_name = ("nova.api.openstack.compute.contrib"
+ ".cloudpipe_update.Cloudpipe_update")
+
+ def _get_flags(self):
+ f = super(CloudPipeUpdateJsonTest, self)._get_flags()
+ f['osapi_compute_extension'] = CONF.osapi_compute_extension[:]
+ # Cloudpipe_update also needs cloudpipe to be loaded
+ f['osapi_compute_extension'].append(
+ 'nova.api.openstack.compute.contrib.cloudpipe.Cloudpipe')
+ return f
+
+ def setUp(self):
+ super(CloudPipeUpdateJsonTest, self).setUp()
+
+ def test_cloud_pipe_update(self):
+ subs = {'vpn_ip': '192.168.1.1',
+ 'vpn_port': 2000}
+ response = self._do_put('os-cloudpipe/configure-project',
+ 'cloud-pipe-update-req',
+ subs)
+ self.assertEqual(response.status, 202)
+
+
+class CloudPipeUpdateXmlTest(CloudPipeUpdateJsonTest):
+ ctype = "xml"
+
+
class AggregatesSampleJsonTest(ServersSampleBase):
extension_name = "nova.api.openstack.compute.contrib" + \
".aggregates.Aggregates"
diff --git a/nova/tests/policy.json b/nova/tests/policy.json
index 20bfa3270..517ba2a55 100644
--- a/nova/tests/policy.json
+++ b/nova/tests/policy.json
@@ -87,6 +87,7 @@
"compute_extension:aggregates": "",
"compute_extension:certificates": "",
"compute_extension:cloudpipe": "",
+ "compute_extension:cloudpipe_update": "",
"compute_extension:config_drive": "",
"compute_extension:console_output": "",
"compute_extension:consoles": "",