# Copyright 2012 Hewlett-Packard Development Company, L.P. # Copyright 2013 OpenStack Foundation # # 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 logging import threading from paste import httpserver from webob import Request class WebApp(threading.Thread): log = logging.getLogger("zuul.WebApp") def __init__(self, scheduler, port=8001): threading.Thread.__init__(self) self.scheduler = scheduler self.port = port self.daemon = True self.server = httpserver.serve(self.app, host='0.0.0.0', port=self.port, start_loop=False) def run(self): self.server.serve_forever() def stop(self): self.server.server_close() def app(self, environ, start_response): request = Request(environ) if request.path == '/status.json': try: ret = self.scheduler.formatStatusJSON() except: self.log.exception("Exception formatting status:") raise start_response('200 OK', [('content-type', 'application/json'), ('Access-Control-Allow-Origin', '*')]) return [ret] else: start_response('404 Not Found', [('content-type', 'text/plain')]) return ['Not found.']