diff options
Diffstat (limited to 'moon_wrapper/moon_wrapper')
-rw-r--r-- | moon_wrapper/moon_wrapper/__init__.py | 6 | ||||
-rw-r--r-- | moon_wrapper/moon_wrapper/__main__.py | 4 | ||||
-rw-r--r-- | moon_wrapper/moon_wrapper/api/__init__.py | 0 | ||||
-rw-r--r-- | moon_wrapper/moon_wrapper/api/generic.py | 134 | ||||
-rw-r--r-- | moon_wrapper/moon_wrapper/api/oslowrapper.py | 127 | ||||
-rw-r--r-- | moon_wrapper/moon_wrapper/api/slaveupdate.py | 87 | ||||
-rw-r--r-- | moon_wrapper/moon_wrapper/http_server.py | 144 | ||||
-rw-r--r-- | moon_wrapper/moon_wrapper/server.py | 32 |
8 files changed, 0 insertions, 534 deletions
diff --git a/moon_wrapper/moon_wrapper/__init__.py b/moon_wrapper/moon_wrapper/__init__.py deleted file mode 100644 index f0887748..00000000 --- a/moon_wrapper/moon_wrapper/__init__.py +++ /dev/null @@ -1,6 +0,0 @@ -# Copyright 2015 Open Platform for NFV Project, Inc. and its contributors -# This software is distributed under the terms and conditions of the 'Apache-2.0' -# license which can be found in the file 'LICENSE' in this package distribution -# or at 'http://www.apache.org/licenses/LICENSE-2.0'. - -__version__ = "4.6.0" diff --git a/moon_wrapper/moon_wrapper/__main__.py b/moon_wrapper/moon_wrapper/__main__.py deleted file mode 100644 index 3a403293..00000000 --- a/moon_wrapper/moon_wrapper/__main__.py +++ /dev/null @@ -1,4 +0,0 @@ -from moon_wrapper.server import main - -SERVER = main() -SERVER.run() diff --git a/moon_wrapper/moon_wrapper/api/__init__.py b/moon_wrapper/moon_wrapper/api/__init__.py deleted file mode 100644 index e69de29b..00000000 --- a/moon_wrapper/moon_wrapper/api/__init__.py +++ /dev/null diff --git a/moon_wrapper/moon_wrapper/api/generic.py b/moon_wrapper/moon_wrapper/api/generic.py deleted file mode 100644 index e492b327..00000000 --- a/moon_wrapper/moon_wrapper/api/generic.py +++ /dev/null @@ -1,134 +0,0 @@ -# Copyright 2015 Open Platform for NFV Project, Inc. and its contributors -# This software is distributed under the terms and conditions of the 'Apache-2.0' -# license which can be found in the file 'LICENSE' in this package distribution -# or at 'http://www.apache.org/licenses/LICENSE-2.0'. -""" -Those API are helping API used to manage the Moon platform. -""" - -import logging -from flask_restful import Resource, request -import moon_wrapper.api -from python_moonutilities.security_functions import check_auth - -__version__ = "0.1.0" - -LOGGER = logging.getLogger("moon.manager.api." + __name__) - - -class Status(Resource): - """ - Endpoint for status requests - """ - - __urls__ = ("/status", "/status/", "/status/<string:component_id>") - - def get(self, component_id=None): - """Retrieve status of all components - - :return: { - "orchestrator": { - "status": "Running" - }, - "security_router": { - "status": "Running" - } - } - """ - raise NotImplementedError - - -class Logs(Resource): - """ - Endpoint for logs requests - """ - - __urls__ = ("/logs", "/logs/", "/logs/<string:component_id>") - - def get(self, component_id=None): - """Get logs from the Moon platform - - :param component_id: the ID of the component your are looking for (optional) - :return: [ - "2015-04-15-13:45:20 - "2015-04-15-13:45:21 - "2015-04-15-13:45:22 - "2015-04-15-13:45:23 - ] - """ - filter_str = request.args.get('filter', '') - from_str = request.args.get('from', '') - to_str = request.args.get('to', '') - event_number = request.args.get('event_number', '') - try: - event_number = int(event_number) - except ValueError: - event_number = None - args = dict() - args["filter"] = filter_str - args["from"] = from_str - args["to"] = to_str - args["event_number"] = event_number - - raise NotImplementedError - - -class API(Resource): - """ - Endpoint for API requests - """ - - __urls__ = ( - "/api", - "/api/", - "/api/<string:group_id>", - "/api/<string:group_id>/", - "/api/<string:group_id>/<string:endpoint_id>") - - @check_auth - def get(self, group_id="", endpoint_id="", user_id=""): - """Retrieve all API endpoints or a specific endpoint if endpoint_id is given - - :param group_id: the name of one existing group (ie generic, ...) - :param endpoint_id: the name of one existing component (ie Logs, Status, ...) - :return: { - "group_name": { - "endpoint_name": { - "description": "a description", - "methods": { - "get": "description of the HTTP method" - }, - "urls": ('/api', '/api/', '/api/<string:endpoint_id>') - } - } - """ - __methods = ("get", "post", "put", "delete", "options", "patch") - api_list = filter(lambda x: "__" not in x, dir(moon_wrapper.api)) - api_desc = dict() - for api_name in api_list: - api_desc[api_name] = {} - group_api_obj = eval("moon_interface.api.{}".format(api_name)) - api_desc[api_name]["description"] = group_api_obj.__doc__ - if "__version__" in dir(group_api_obj): - api_desc[api_name]["version"] = group_api_obj.__version__ - object_list = list(filter(lambda x: "__" not in x, dir(group_api_obj))) - for obj in map(lambda x: eval("moon_interface.api.{}.{}".format(api_name, x)), - object_list): - if "__urls__" in dir(obj): - api_desc[api_name][obj.__name__] = dict() - api_desc[api_name][obj.__name__]["urls"] = obj.__urls__ - api_desc[api_name][obj.__name__]["methods"] = dict() - for _method in filter(lambda x: x in __methods, dir(obj)): - docstring = eval( - "moon_interface.api.{}.{}.{}.__doc__".format(api_name, obj.__name__, - _method)) - api_desc[api_name][obj.__name__]["methods"][_method] = docstring - api_desc[api_name][obj.__name__]["description"] = str(obj.__doc__) - if group_id in api_desc: - if endpoint_id in api_desc[group_id]: - return {group_id: {endpoint_id: api_desc[group_id][endpoint_id]}} - elif len(endpoint_id) > 0: - LOGGER.error("Unknown endpoint_id {}".format(endpoint_id)) - return {"error": "Unknown endpoint_id {}".format(endpoint_id)} - return {group_id: api_desc[group_id]} - return api_desc diff --git a/moon_wrapper/moon_wrapper/api/oslowrapper.py b/moon_wrapper/moon_wrapper/api/oslowrapper.py deleted file mode 100644 index 39128621..00000000 --- a/moon_wrapper/moon_wrapper/api/oslowrapper.py +++ /dev/null @@ -1,127 +0,0 @@ -# Copyright 2015 Open Platform for NFV Project, Inc. and its contributors -# This software is distributed under the terms and conditions of the 'Apache-2.0' -# license which can be found in the file 'LICENSE' in this package distribution -# or at 'http://www.apache.org/licenses/LICENSE-2.0'. -""" -Authz is the endpoint to get authorization response -""" - -import logging -import json -import flask -from flask import request -from flask_restful import Resource -import requests -from python_moonutilities import exceptions - -__version__ = "0.1.0" - -LOGGER = logging.getLogger("moon.wrapper.api." + __name__) - - -class OsloWrapper(Resource): - """ - Endpoint for authz requests - """ - - __urls__ = ( - "/authz/oslo", - "/authz/oslo/", - ) - - def __init__(self, **kwargs): - self.port = kwargs.get("port") - self.CACHE = kwargs.get("cache", {}) - self.TIMEOUT = 5 - - def post(self): - LOGGER.debug("POST {}".format(request.form)) - response = flask.make_response("False") - try: - if self.manage_data(): - response = flask.make_response("True") - except exceptions.AuthzException as exception: - LOGGER.error(exception, exc_info=True) - except Exception as exception: - LOGGER.error(exception, exc_info=True) - - response.headers['content-type'] = 'application/octet-stream' - return response - - @staticmethod - def __get_subject(target, credentials): - _subject = target.get("user_id", "") - if not _subject: - _subject = credentials.get("user_id", "none") - return _subject - - @staticmethod - def __get_object(target, credentials): - try: - # note: case of Glance - return target['target']['name'] - except KeyError: - pass - - # note: default case - return "none" - - @staticmethod - def __get_project_id(target, credentials): - project_id = target.get("project_id", None) - if not project_id: - project_id = credentials.get("project_id", None) - return project_id - - def get_interface_url(self, project_id): - LOGGER.debug("project_id {}".format(project_id)) - for containers in self.CACHE.containers.values(): - LOGGER.info("containers {}".format(containers)) - for container in containers: - if container.get("keystone_project_id") == project_id: - if "pipeline" in container['name']: - return "http://{}:{}".format( - container['name'], - container['port']) - self.CACHE.update() - # Note (asteroide): test an other time after the update - for containers in self.CACHE.containers.values(): - for container in containers: - if container.get("keystone_project_id") == project_id: - if "pipeline" in container['name']: - return "http://{}:{}".format( - container['name'], - container['port']) - raise exceptions.AuthzException("Keystone Project " - "ID ({}) is unknown or not mapped " - "to a PDP.".format(project_id)) - - def manage_data(self): - data = request.form - if not dict(request.form): - data = json.loads(request.data.decode("utf-8")) - target = json.loads(data.get('target', {})) - credentials = json.loads(data.get('credentials', {})) - rule = data.get('rule', "").strip('"').strip("'") - _subject = self.__get_subject(target, credentials) - _object = self.__get_object(target, credentials) - _action = rule - LOGGER.info("authz {} {} {}".format(_subject, _object, _action)) - _project_id = self.__get_project_id(target, credentials) - _pdp_id = self.CACHE.get_pdp_from_keystone_project(_project_id) - interface_url = self.get_interface_url(_project_id) - LOGGER.debug("interface_url={}".format(interface_url)) - req = requests.get("{}/authz/{}/{}/{}/{}".format( - interface_url, - _pdp_id, - _subject, - _object, - _action - )) - - LOGGER.debug("Get interface {}".format(req.text)) - if req.status_code == 200: - if req.json().get("result", False): - return True - - raise exceptions.AuthzException("error in authz request") diff --git a/moon_wrapper/moon_wrapper/api/slaveupdate.py b/moon_wrapper/moon_wrapper/api/slaveupdate.py deleted file mode 100644 index b2ce22f0..00000000 --- a/moon_wrapper/moon_wrapper/api/slaveupdate.py +++ /dev/null @@ -1,87 +0,0 @@ -# Copyright 2015 Open Platform for NFV Project, Inc. and its contributors -# This software is distributed under the terms and conditions of the 'Apache-2.0' -# license which can be found in the file 'LICENSE' in this package distribution -# or at 'http://www.apache.org/licenses/LICENSE-2.0'. -""" -Authz is the endpoint to get authorization response -""" - -import logging -import json -import flask -from flask import request -from flask_restful import Resource -import requests -from python_moonutilities import exceptions - -__version__ = "0.1.0" - -LOGGER = logging.getLogger("moon.wrapper.api." + __name__) - - -class SlaveUpdate(Resource): - """ - Endpoint for authz requests - """ - - __urls__ = ( - "/update", - "/update/", - ) - - def __init__(self, **kwargs): - self.port = kwargs.get("port") - self.CACHE = kwargs.get("cache", {}) - self.TIMEOUT = 5 - - def put(self): - LOGGER.warning("PUT {}".format(request.form)) - response = flask.make_response("False") - try: - if self.update_slave(): - response = flask.make_response("True") - except Exception as exception: - LOGGER.error(exception, exc_info=True) - - response.headers['content-type'] = 'application/octet-stream' - return response - - def get_interface_url(self, pdp_id): - LOGGER.debug("pdp_id {}".format(pdp_id)) - for containers in self.CACHE.containers.values(): - LOGGER.info("containers0 {}".format(containers)) - for container in containers: - if container.get("pdp_id") == pdp_id: - if "pipeline" in container['name']: - yield "http://{}:{}".format( - container['name'], - container['port']) - self.CACHE.update() - # Note (asteroide): test an other time after the update - for containers in self.CACHE.containers.values(): - LOGGER.info("containers1 {}".format(containers)) - for container in containers: - if container.get("pdp_id") == pdp_id: - if "pipeline" in container['name']: - yield "http://{}:{}".format( - container['name'], - container['port']) - - def update_slave(self): - result = {} - result_list = [] - for _pdp_id in self.CACHE.pdp: - result[_pdp_id] = {} - for interface_url in self.get_interface_url(_pdp_id): - - req = requests.put("{}/update".format(interface_url), request.form) - - if req.status_code == 200: - if req.json().get("result", False): - result[_pdp_id][interface_url] = True - result_list.append(True) - continue - LOGGER.warning("Error in {} {}: {}".format(_pdp_id, interface_url, req.text)) - result[_pdp_id][interface_url] = False - result_list.append(False) - return all(result_list) diff --git a/moon_wrapper/moon_wrapper/http_server.py b/moon_wrapper/moon_wrapper/http_server.py deleted file mode 100644 index 015bb285..00000000 --- a/moon_wrapper/moon_wrapper/http_server.py +++ /dev/null @@ -1,144 +0,0 @@ -# Copyright 2015 Open Platform for NFV Project, Inc. and its contributors -# This software is distributed under the terms and conditions of the 'Apache-2.0' -# license which can be found in the file 'LICENSE' in this package distribution -# or at 'http://www.apache.org/licenses/LICENSE-2.0'. - -import flask -from flask import Flask, jsonify -from flask_restful import Resource, Api -import logging -from moon_wrapper import __version__ -from moon_wrapper.api.generic import Status, Logs, API -from moon_wrapper.api.oslowrapper import OsloWrapper -from moon_wrapper.api.slaveupdate import SlaveUpdate -from python_moonutilities.cache import Cache -from python_moonutilities import configuration, exceptions - -LOGGER = logging.getLogger("moon.wrapper.http_server") - -CACHE = Cache() - -__API__ = ( - Status, Logs, API -) - - -class Server: - """Base class for HTTP server""" - - def __init__(self, host="localhost", port=80, api=None, **kwargs): - """Run a server - - :param host: hostname of the server - :param port: port for the running server - :param kwargs: optional parameters - :return: a running server - """ - self._host = host - self._port = port - self._api = api - self._extra = kwargs - - @property - def host(self): - return self._host - - @host.setter - def host(self, name): - self._host = name - - @host.deleter - def host(self): - self._host = "" - - @property - def port(self): - return self._port - - @port.setter - def port(self, number): - self._port = number - - @port.deleter - def port(self): - self._port = 80 - - def run(self): - raise NotImplementedError() - - -class Root(Resource): - """ - The root of the web service - """ - __urls__ = ("/",) - __methods = ("get", "post", "put", "delete", "options") - - def get(self): - tree = {"/": {"methods": ("get",), - "description": "List all methods for that service."}} - for item in __API__: - tree[item.__name__] = {"urls": item.__urls__} - _methods = [] - for _method in self.__methods: - if _method in dir(item): - _methods.append(_method) - tree[item.__name__]["methods"] = _methods - tree[item.__name__]["description"] = item.__doc__.strip() - return { - "version": __version__, - "tree": tree - } - - -class HTTPServer(Server): - - def __init__(self, host="localhost", port=80, **kwargs): - super(HTTPServer, self).__init__(host=host, port=port, **kwargs) - self.app = Flask(__name__) - self.port = port - conf = configuration.get_configuration("components/orchestrator") - _hostname = conf["components/orchestrator"].get("hostname", - "orchestrator") - _port = conf["components/orchestrator"].get("port", 80) - _protocol = conf["components/orchestrator"].get("protocol", "http") - self.orchestrator_url = "{}://{}:{}".format( - _protocol, _hostname, _port) - # Todo : specify only few urls instead of * - # CORS(self.app) - self.api = Api(self.app) - self.__set_route() - self.__hook_errors() - - def __hook_errors(self): - def get_404_json(e): - return flask.make_response("False") - - self.app.register_error_handler(404, get_404_json) - - def get_400_json(e): - return flask.make_response("False") - - self.app.register_error_handler(400, lambda e: get_400_json) - self.app.register_error_handler(403, exceptions.AuthException) - - def __set_route(self): - self.api.add_resource(Root, '/') - - for api in __API__: - self.api.add_resource(api, *api.__urls__) - self.api.add_resource(OsloWrapper, *OsloWrapper.__urls__, - resource_class_kwargs={ - "orchestrator_url": self.orchestrator_url, - "cache": CACHE, - } - ) - self.api.add_resource(SlaveUpdate, *SlaveUpdate.__urls__, - resource_class_kwargs={ - "orchestrator_url": self.orchestrator_url, - "cache": CACHE, - } - ) - - def run(self): - self.app.run(host=self._host, port=self._port, threaded=True) # nosec diff --git a/moon_wrapper/moon_wrapper/server.py b/moon_wrapper/moon_wrapper/server.py deleted file mode 100644 index 77def174..00000000 --- a/moon_wrapper/moon_wrapper/server.py +++ /dev/null @@ -1,32 +0,0 @@ -# Copyright 2015 Open Platform for NFV Project, Inc. and its contributors -# This software is distributed under the terms and conditions of the 'Apache-2.0' -# license which can be found in the file 'LICENSE' in this package distribution -# or at 'http://www.apache.org/licenses/LICENSE-2.0'. - -import logging -from python_moonutilities import configuration, exceptions -from moon_wrapper.http_server import HTTPServer - -LOG = logging.getLogger("moon.wrapper.server") - - -def main(): - configuration.init_logging() - try: - conf = configuration.get_configuration("components/wrapper") - LOG.debug("wrapper.conf={}".format(conf)) - hostname = conf["components/wrapper"].get("hostname", "wrapper") - port = conf["components/wrapper"].get("port", 80) - bind = conf["components/wrapper"].get("bind", "127.0.0.1") - except exceptions.ConsulComponentNotFound: - hostname = "wrapper" - bind = "127.0.0.1" - port = 80 - configuration.add_component(uuid="wrapper", name=hostname, port=port, bind=bind) - LOG.info("Starting server with IP {} on port {} bind to {}".format(hostname, port, bind)) - return HTTPServer(host=bind, port=port) - - -if __name__ == '__main__': - SERVER = main() - SERVER.run() |