# Copyright 2020 Huawei Technologies Co., Ltd # # 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. # ============================================================================ """ Profile api. This module provides the interfaces to profile functions. """ import json import os from flask import Blueprint from flask import request from flask import jsonify from marshmallow import ValidationError from mindinsight.conf import settings from mindinsight.datavisual.utils.tools import get_train_id, get_profiler_dir from mindinsight.profiler.analyser.analyser_factory import AnalyserFactory from mindinsight.lineagemgr.common.validator.validate_path import validate_and_normalize_path from mindinsight.profiler.common.util import analyse_device_list_from_profiler_dir from mindinsight.profiler.common.validator.validate import validate_condition from mindinsight.utils.exceptions import ParamValueError BLUEPRINT = Blueprint("profile", __name__, url_prefix=settings.URL_PREFIX) @BLUEPRINT.route("/profile/ops/search", methods=["POST"]) def get_profile_op_info(): """ Get operation profiling info. Returns: str, the operation profiling information. Raises: ParamValueError: If the search condition contains some errors. Examples: >>> POST http://xxxx/v1/mindinsight/profile/ops/search """ profiler_dir = get_profiler_dir(request) train_id = get_train_id(request) if not profiler_dir or not train_id: raise ParamValueError("No profiler_dir or train_id.") search_condition = request.stream.read() try: search_condition = json.loads(search_condition if search_condition else "{}") except Exception: raise ParamValueError("Json data parse failed.") validate_condition(search_condition) device_id = search_condition.get("device_id", "0") profiler_dir_abs = os.path.join(settings.SUMMARY_BASE_DIR, train_id, profiler_dir) try: profiler_dir_abs = validate_and_normalize_path(profiler_dir_abs, "profiler") except ValidationError: raise ParamValueError("Invalid profiler dir") op_type = search_condition.get("op_type") analyser = AnalyserFactory.instance().get_analyser( op_type, profiler_dir_abs, device_id ) op_info = analyser.query(search_condition) return jsonify(op_info) @BLUEPRINT.route("/profile/devices", methods=["GET"]) def get_profile_device_list(): """ Get profile device list. Returns: list, the available device list. Raises: ParamValueError: If the search condition contains some errors. Examples: >>> POST http://xxxx/v1/mindinsight/profile/devices """ profiler_dir = get_profiler_dir(request) train_id = get_train_id(request) if not profiler_dir or not train_id: raise ParamValueError("No profiler_dir or train_id.") profiler_dir_abs = os.path.join(settings.SUMMARY_BASE_DIR, train_id, profiler_dir) try: profiler_dir_abs = validate_and_normalize_path(profiler_dir_abs, "profiler") except ValidationError: raise ParamValueError("Invalid profiler dir") device_list = analyse_device_list_from_profiler_dir(profiler_dir_abs) return jsonify(device_list) def init_module(app): """ Init module entry. Args: app: the application obj. """ app.register_blueprint(BLUEPRINT)