summaryrefslogtreecommitdiffstats
path: root/bin/nova-api-paste
blob: 6ee833a18b967a43338574042f21b12fe565842b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#!/usr/bin/env python
# pylint: disable-msg=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 API."""

import gettext
import logging
import os
import sys

from paste import deploy

# 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 flags
from nova import wsgi

LOG = logging.getLogger('nova.api')
LOG.setLevel(logging.DEBUG)
LOG.addHandler(logging.StreamHandler())

FLAGS = flags.FLAGS

API_ENDPOINTS = ['ec2', 'openstack']


def load_configuration(paste_config):
    """Load the paste configuration from the config file and return it."""
    config = None
    # Try each known name to get the global DEFAULTS, which will give ports
    for name in API_ENDPOINTS:
        try:
            config = deploy.appconfig("config:%s" % paste_config, name=name)
        except LookupError:
            pass
        if config:
            verbose = config.get('verbose', None)
            if verbose:
                FLAGS.verbose = int(verbose) == 1
                if FLAGS.verbose:
                    logging.getLogger().setLevel(logging.DEBUG)
            return config
    LOG.debug(_("Paste config at %s has no secion for known apis"),
              paste_config)
    print _("Paste config at %s has no secion for any known apis") % \
          paste_config
    os.exit(1)


def launch_api(paste_config_file, section, server, port, host):
    """Launch an api server from the specified port and IP."""
    LOG.debug(_("Launching %s api on %s:%s"), section, host, port)
    app = deploy.loadapp('config:%s' % paste_config_file, name=section)
    server.start(app, int(port), host)


def run_app(paste_config_file):
    LOG.debug(_("Using paste.deploy config at: %s"), configfile)
    config = load_configuration(paste_config_file)
    LOG.debug(_("Configuration: %r"), config)
    server = wsgi.Server()
    ip = config.get('host', '0.0.0.0')
    for api in API_ENDPOINTS:
        port = config.get("%s_port" % api, None)
        if not port:
            continue
        host = config.get("%s_host" % api, ip)
        launch_api(configfile, api, server, port, host)
    LOG.debug(_("All api servers launched, now waiting"))
    server.wait()


if __name__ == '__main__':
    FLAGS(sys.argv)
    configfiles = ['/etc/nova/nova-api.conf']
    if os.path.exists(os.path.join(possible_topdir, 'nova', '__init__.py')):
        configfiles.insert(0,
                       os.path.join(possible_topdir, 'etc', 'nova-api.conf'))
    for configfile in configfiles:
        if os.path.exists(configfile):
            run_app(configfile)
            break
        else:
            LOG.debug(_("Skipping missing configuration: %s"), configfile)