""" (c) Copyright 2014,2015 Hewlett-Packard Development Company, L.P. 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 __future__ import print_function import falcon import sys from keystonemiddleware import auth_token from oslo_config import cfg from oslo_log import log from wsgiref import simple_server from freezer_api.api.common import middleware from freezer_api.api import v1 from freezer_api.api import versions from freezer_api.common import _i18n from freezer_api.common import config from freezer_api.common import exceptions as freezer_api_exc from freezer_api.storage import driver CONF = cfg.CONF _LOG = log.getLogger(__name__) def get_application(db): config.parse_args() config.setup_logging() app = falcon.API() for exception_class in freezer_api_exc.exception_handlers_catalog: app.add_error_handler(exception_class, exception_class.handle) endpoint_catalog = [ ('/v1', v1.public_endpoints(db)), ('/', [('', versions.Resource())]) ] for version_path, endpoints in endpoint_catalog: for route, resource in endpoints: app.add_route(version_path + route, resource) # pylint: disable=no-value-for-parameter app = middleware.json_translator(app) if 'keystone_authtoken' in config.CONF: app = auth_token.AuthProtocol(app, {}) else: _LOG.warning(_i18n._LW("keystone authentication disabled")) app = middleware.HealthApp(app=app, path='/v1/health') return app def main(): try: db = driver.get_db() application = get_application(db) except Exception as err: message = _i18n._('Unable to start server: %s ') % err print(message) _LOG.error(message) sys.exit(1) # quick simple server for testing purposes or simple scenarios ip = CONF.get('bind_host', '0.0.0.0') port = CONF.get('bind_port', 9090) httpd = simple_server.make_server(ip, int(port), application) message = _i18n._('Server listening on %(ip)s:%(port)s' % {'ip': ip, 'port': port}) print(message) _LOG.info(message) try: httpd.serve_forever() except KeyboardInterrupt: print(_i18n._("\nThanks, Bye")) sys.exit(0) if __name__ == '__main__': main()