82049af90e
The next obvious step in porting to cfg is to define all options using cfg schemas directly rather than using the flags.DEFINE_* helpers. This is a large change, but it is almost entirely pure refactoring and does not result in any functional changes. The only change to note is that the default values for glance_host, glance_api_servers and default_publisher_id options are now using opt value interpolation i.e. -glance_host=_get_my_ip() +glance_host='$my_ip' -glance_api_servers=['%s:%d' % (FLAGS.glance_host, FLAGS.glance_port)] +glance_api_servers=['$glance_host:$glance_port'] -default_publisher_id=FLAGS.host +default_publisher_id='$host' Also note that the lower_bound check on the {report,periodic}_interval options are no more, but this has been true since cfg was first added. Change-Id: Ia58c8f0aaf61628bb55b1b8485118a2a9852ed17
111 lines
3.6 KiB
Python
Executable File
111 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 eventlet
|
|
eventlet.monkey_patch()
|
|
|
|
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)
|
|
|
|
|
|
from nova.common import cfg
|
|
from nova import compute
|
|
from nova import flags
|
|
from nova import log as logging
|
|
from nova import network
|
|
from nova import service
|
|
from nova import utils
|
|
from nova import volume
|
|
from nova import wsgi
|
|
from nova.api import direct
|
|
|
|
|
|
direct_api_opts = [
|
|
cfg.IntOpt('direct_port',
|
|
default=8001,
|
|
help='Direct API port'),
|
|
cfg.StrOpt('direct_host',
|
|
default='0.0.0.0',
|
|
help='Direct API host'),
|
|
]
|
|
|
|
FLAGS = flags.FLAGS
|
|
FLAGS.add_options(direct_api_opts)
|
|
|
|
|
|
# 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)
|
|
|
|
service.serve(server)
|
|
service.wait()
|