102 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env python
 | |
| # pylint: disable=C0103
 | |
| # vim: tabstop=4 shiftwidth=4 softtabstop=4
 | |
| 
 | |
| # Copyright 2010 United States Government as represented by the
 | |
| # Administrator of the National Aeronautics and Space Administration.
 | |
| # 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.
 | |
| 
 | |
| """Starter script for Nova Direct API."""
 | |
| 
 | |
| import gettext
 | |
| import os
 | |
| import sys
 | |
| 
 | |
| # If ../nova/__init__.py exists, add ../ to Python search path, so that
 | |
| # it will override what happens to be installed in /usr/(local/)lib/python...
 | |
| possible_topdir = os.path.normpath(os.path.join(os.path.abspath(sys.argv[0]),
 | |
|                                    os.pardir,
 | |
|                                    os.pardir))
 | |
| if os.path.exists(os.path.join(possible_topdir, 'nova', '__init__.py')):
 | |
|     sys.path.insert(0, possible_topdir)
 | |
| 
 | |
| gettext.install('nova', unicode=1)
 | |
| 
 | |
| from nova import compute
 | |
| from nova import flags
 | |
| from nova import log as logging
 | |
| from nova import network
 | |
| from nova import utils
 | |
| from nova import volume
 | |
| from nova import wsgi
 | |
| from nova.api import direct
 | |
| 
 | |
| 
 | |
| FLAGS = flags.FLAGS
 | |
| flags.DEFINE_integer('direct_port', 8001, 'Direct API port')
 | |
| flags.DEFINE_string('direct_host', '0.0.0.0', 'Direct API host')
 | |
| flags.DEFINE_flag(flags.HelpFlag())
 | |
| flags.DEFINE_flag(flags.HelpshortFlag())
 | |
| flags.DEFINE_flag(flags.HelpXMLFlag())
 | |
| 
 | |
| 
 | |
| # An example of an API that only exposes read-only methods.
 | |
| # In this case we're just limiting which methods are exposed.
 | |
| class ReadOnlyCompute(direct.Limited):
 | |
|     """Read-only Compute API."""
 | |
| 
 | |
|     _allowed = ['get', 'get_all', 'get_console_output']
 | |
| 
 | |
| 
 | |
| # An example of an API that provides a backwards compatibility layer.
 | |
| # In this case we're overwriting the implementation to ensure
 | |
| # compatibility with an older version. In reality we would want the
 | |
| # "description=None" to be part of the actual API so that code
 | |
| # like this isn't even necessary, but this example shows what one can
 | |
| # do if that isn't the situation.
 | |
| class VolumeVersionOne(direct.Limited):
 | |
|     _allowed = ['create', 'delete', 'update', 'get']
 | |
| 
 | |
|     def create(self, context, size, name):
 | |
|         self.proxy.create(context, size, name, description=None)
 | |
| 
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     utils.default_flagfile()
 | |
|     FLAGS(sys.argv)
 | |
|     logging.setup()
 | |
| 
 | |
|     direct.register_service('compute', compute.API())
 | |
|     direct.register_service('volume', volume.API())
 | |
|     direct.register_service('network', network.API())
 | |
|     direct.register_service('reflect', direct.Reflection())
 | |
| 
 | |
|     # Here is how we could expose the code in the examples above.
 | |
|     #direct.register_service('compute-readonly',
 | |
|     #                        ReadOnlyCompute(compute.API()))
 | |
|     #direct.register_service('volume-v1', VolumeVersionOne(volume.API()))
 | |
| 
 | |
|     router = direct.Router()
 | |
|     with_json = direct.JsonParamsMiddleware(router)
 | |
|     with_req = direct.PostParamsMiddleware(with_json)
 | |
|     with_auth = direct.DelegatedAuthMiddleware(with_req)
 | |
| 
 | |
|     server = wsgi.Server("Direct API",
 | |
|                          with_auth,
 | |
|                          host=FLAGS.direct_host,
 | |
|                          port=FLAGS.direct_port)
 | |
|     server.start()
 | |
|     server.wait()
 | 
