예제 #1
0
 def get(self, request, team_name, group_id, *args, **kwargs):
     """
     查询是否有未确认分享订单记录
     ---
     parameter:
         - name: team_name
           description: 团队名
           required: true
           type: string
           paramType: path
         - name: group_id
           description: 应用组id
           required: true
           type: string
           paramType: path
     """
     share_record = share_repo.get_service_share_record_by_groupid(
         group_id=group_id)
     if share_record:
         if share_record.step == 2:
             result = general_message(
                 200,
                 "the current application does not confirm sharing",
                 "当前应用未确认分享",
                 bean=share_record.to_dict())
             return Response(result, status=200)
     result = general_message(
         200,
         "the current application is not Shared or Shared",
         "当前应用未分享或已分享",
         bean=share_record.to_dict())
     return Response(result, status=200)
예제 #2
0
 def get(self, request, team_name, group_id, *args, **kwargs):
     """
     查询是否有未完成分享订单记录
     ---
     parameter:
         - name: team_name
           description: 团队名
           required: true
           type: string
           paramType: path
         - name: group_id
           description: 应用组id
           required: true
           type: string
           paramType: path
     """
     share_record = share_repo.get_service_share_record_by_groupid(
         group_id=group_id)
     if share_record:
         if not share_record.is_success and share_record.step < 3:
             result = general_message(20021,
                                      "share record not complete",
                                      "分享流程未完成",
                                      bean=share_record.to_dict())
             return Response(result, status=200)
     return Response(data=general_message(
         200, "not found not completed share record", "无未完成分享流程"),
                     status=200)
예제 #3
0
    def get(self, request, team_name, plugin_id, *args, **kwargs):
        """
        查询插件分享记录
        :param request:
        :param team_name:
        :param plugin_id:
        :param args:
        :param kwargs:
        :return:
        """
        share_record = share_repo.get_service_share_record_by_groupid(plugin_id)
        if share_record:
            if not share_record.is_success and share_record.step < 3:
                result = general_message(
                    20021, "share record not complete", "分享流程未完成", bean=share_record.to_dict())
                return Response(result, status=200)

        result = general_message(200, "not found uncomplete share record", "无未完成分享流程")
        return Response(data=result, status=200)
예제 #4
0
 def get_service_share_record_by_group_id(self, group_id):
     return share_repo.get_service_share_record_by_groupid(
         group_id=group_id)
예제 #5
0
    def get(self, request, *args, **kwargs):
        """
        总览 团队信息
        ---
        parameters:
            - name: team_name
              description: 团队名
              required: true
              type: string
              paramType: path
        """
        try:
            overview_detail = dict()
            users = team_services.get_team_users(self.team)
            if users:
                user_nums = len(users)
                overview_detail["user_nums"] = user_nums
                team_service_num = service_repo.get_team_service_num_by_team_id(
                    team_id=self.team.tenant_id,
                    region_name=self.response_region)
                source = common_services.get_current_region_used_resource(
                    self.team, self.response_region)
                # 获取tcp和http策略数量
                region = region_repo.get_region_by_region_name(
                    self.response_region)
                total_tcp_domain = tcp_domain.get_all_domain_count_by_tenant_and_region(
                    self.team.tenant_id, region.region_id)
                overview_detail["total_tcp_domain"] = total_tcp_domain

                total_http_domain = domain_repo.get_all_domain_count_by_tenant_and_region_id(
                    self.team.tenant_id, region.region_id)
                overview_detail["total_http_domain"] = total_http_domain

                # 获取分享应用数量
                groups = group_repo.get_tenant_region_groups(
                    self.team.tenant_id, region.region_name)
                share_app_num = 0
                if groups:
                    for group in groups:
                        share_record = share_repo.get_service_share_record_by_groupid(
                            group_id=group.ID)
                        if share_record:
                            share_app_num += 1
                overview_detail["share_app_num"] = share_app_num

                if source:
                    team_app_num = group_repo.get_tenant_region_groups_count(
                        self.team.tenant_id, self.response_region)
                    overview_detail["team_app_num"] = team_app_num
                    overview_detail["team_service_num"] = team_service_num
                    overview_detail["team_service_memory_count"] = int(
                        source["memory"])
                    overview_detail["team_service_total_disk"] = int(
                        source["disk"])
                    overview_detail["team_service_total_cpu"] = int(
                        source["limit_cpu"])
                    overview_detail["team_service_total_memory"] = int(
                        source["limit_memory"])
                    overview_detail["team_service_use_cpu"] = int(
                        source["cpu"])
                    cpu_usage = 0
                    memory_usage = 0
                    if int(source["limit_cpu"]) != 0:
                        cpu_usage = float(int(source["cpu"])) / float(
                            int(source["limit_cpu"])) * 100
                    if int(source["limit_memory"]) != 0:
                        memory_usage = float(int(source["memory"])) / float(
                            int(source["limit_memory"])) * 100
                    overview_detail["cpu_usage"] = round(cpu_usage, 2)
                    overview_detail["memory_usage"] = round(memory_usage, 2)

                return Response(
                    general_message(200,
                                    "success",
                                    "查询成功",
                                    bean=overview_detail))
            else:
                data = {
                    "user_nums": 1,
                    "team_service_num": 0,
                    "total_memory": 0
                }
                result = general_message(200,
                                         "success",
                                         "团队信息总览获取成功",
                                         bean=data)
                return Response(result, status=200)
        except Exception as e:
            logger.exception(e)
            result = error_message(e.message)
            return Response(result, status=500)
예제 #6
0
    def get(self, request, *args, **kwargs):
        """
        总览 团队信息
        ---
        parameters:
            - name: team_name
              description: 团队名
              required: true
              type: string
              paramType: path
        """
        overview_detail = dict()
        users = team_services.get_team_users(self.team)
        if users:
            user_nums = len(users)
            overview_detail["user_nums"] = user_nums
            team_service_num = service_repo.get_team_service_num_by_team_id(
                team_id=self.team.tenant_id, region_name=self.response_region)
            source = common_services.get_current_region_used_resource(self.team, self.response_region)
            # 获取tcp和http策略数量
            region = region_repo.get_region_by_region_name(self.response_region)
            if not region:
                overview_detail["region_health"] = False
                return Response(general_message(200, "success", "查询成功", bean=overview_detail))
            total_tcp_domain = tcp_domain.get_all_domain_count_by_tenant_and_region(self.team.tenant_id, region.region_id)
            overview_detail["total_tcp_domain"] = total_tcp_domain

            total_http_domain = domain_repo.get_all_domain_count_by_tenant_and_region_id(self.team.tenant_id, region.region_id)
            overview_detail["total_http_domain"] = total_http_domain

            # 获取分享应用数量
            groups = group_repo.get_tenant_region_groups(self.team.tenant_id, region.region_name)
            share_app_num = 0

            batch_create_app_body = []
            if groups:
                for group in groups:
                    share_record = share_repo.get_service_share_record_by_groupid(group_id=group.ID)
                    if share_record and share_record.step == 3:
                        share_app_num += 1

                    try:
                        region_app_repo.get_region_app_id(region.region_name, group.ID)
                    except RegionApp.DoesNotExist:
                        create_app_body = dict()
                        group_services = base_service.get_group_services_list(self.team.tenant_id, region.region_name, group.ID)
                        service_ids = []
                        if group_services:
                            service_ids = [service["service_id"] for service in group_services]
                        create_app_body["app_name"] = group.group_name
                        create_app_body["console_app_id"] = group.ID
                        create_app_body["service_ids"] = service_ids
                        batch_create_app_body.append(create_app_body)

            if len(batch_create_app_body) > 0:
                try:
                    body = {"apps_info": batch_create_app_body}
                    applist = region_api.batch_create_application(region.region_name, self.tenant_name, body)
                    app_list = []
                    if applist:
                        for app in applist:
                            data = RegionApp(
                                app_id=app["app_id"], region_app_id=app["region_app_id"], region_name=region.region_name)
                            app_list.append(data)
                    RegionApp.objects.bulk_create(app_list)
                except Exception as e:
                    logger.exception(e)

            team_app_num = group_repo.get_tenant_region_groups_count(self.team.tenant_id, self.response_region)
            overview_detail["share_app_num"] = share_app_num
            overview_detail["team_app_num"] = team_app_num
            overview_detail["team_service_num"] = team_service_num
            overview_detail["eid"] = self.team.enterprise_id
            overview_detail["team_service_memory_count"] = 0
            overview_detail["team_service_total_disk"] = 0
            overview_detail["team_service_total_cpu"] = 0
            overview_detail["team_service_total_memory"] = 0
            overview_detail["team_service_use_cpu"] = 0
            overview_detail["cpu_usage"] = 0
            overview_detail["memory_usage"] = 0
            if source:
                try:
                    overview_detail["region_health"] = True
                    overview_detail["team_service_memory_count"] = int(source["memory"])
                    overview_detail["team_service_total_disk"] = int(source["disk"])
                    overview_detail["team_service_total_cpu"] = int(source["limit_cpu"])
                    overview_detail["team_service_total_memory"] = int(source["limit_memory"])
                    overview_detail["team_service_use_cpu"] = int(source["cpu"])
                    cpu_usage = 0
                    memory_usage = 0
                    if int(source["limit_cpu"]) != 0:
                        cpu_usage = float(int(source["cpu"])) / float(int(source["limit_cpu"])) * 100
                    if int(source["limit_memory"]) != 0:
                        memory_usage = float(int(source["memory"])) / float(int(source["limit_memory"])) * 100
                    overview_detail["cpu_usage"] = round(cpu_usage, 2)
                    overview_detail["memory_usage"] = round(memory_usage, 2)
                except Exception as e:
                    logger.debug(source)
                    logger.exception(e)
            else:
                overview_detail["region_health"] = False
            return Response(general_message(200, "success", "查询成功", bean=overview_detail))
        else:
            data = {"user_nums": 1, "team_service_num": 0, "total_memory": 0, "eid": self.team.enterprise_id}
            result = general_message(200, "success", "团队信息总览获取成功", bean=data)
            return Response(result, status=200)