ApiLogManagerImpl.java 8.76 KB
/*
 * @(#)ApiLogManagerImpl.java
 *
 * Copyright (c) 2014-2017  xiniunet 版权所有
 * xiniunet. All rights reserved.
 *
 * This software is the confidential and proprietary
 * information of  xiniunet.
 * ("Confidential Information"). You shall not disclose
 * such Confidential Information and shall use it only
 * in accordance with the terms of the contract agreement
 * you entered into with xiniunet.
 */
package com.xiniunet.service.railway.biz;

import com.xiniunet.foundation.service.FoundationService;
import com.xiniunet.framework.base.BaseManagerImpl;
import com.xiniunet.framework.base.BaseResponse;
import com.xiniunet.framework.exception.ErrorType;
import com.xiniunet.framework.security.Passport;
import com.xiniunet.railway.domain.ApiLog;
import com.xiniunet.railway.request.*;
import com.xiniunet.railway.response.*;
import com.xiniunet.service.railway.Message;
import com.xiniunet.service.railway.dal.ApiLogMapper;
import com.xiniunet.service.railway.po.ApiLogPO;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;

import java.util.ArrayList;
import java.util.List;

/**
 * 远程调用日志的管理方法实现.
 *
 * @author xiniunet
 */
@Transactional
@Service("RailwayApiLogManager")
public class ApiLogManagerImpl extends BaseManagerImpl implements ApiLogManager {

    @Autowired
    private FoundationService foundationService;

    @Autowired
    private ApiLogMapper apiLogMapper;

    /**
     * 根据Id获取远程调用日志
     *
     * @param request  获取远程调用日志请求
     * @param passport 用户护照
     * @return 获取远程调用日志应答
     */
    @Override
    @Transactional(propagation = Propagation.NOT_SUPPORTED, readOnly = true)
    public ApiLogGetResponse get(ApiLogGetRequest request, Passport passport) {
        ApiLogGetResponse response = new ApiLogGetResponse();
        ApiLogPO entity = apiLogMapper.getById(request.getId(), passport);
        if (entity != null) {
            ApiLog apiLog = this.getMapper().map(entity, ApiLog.class);
            response.setApiLog(apiLog);
        } else {
            response.addError(ErrorType.EXPECTATION_NULL, Message.COMMON_GET_FAILURE);
        }
        return response;
    }
    /**
     * 根据Id获取远程调用日志
     *
     * @param request  获取远程调用日志请求
     * @param passport 用户护照
     * @return 获取远程调用日志应答
     */
    @Override
    @Transactional(propagation = Propagation.NOT_SUPPORTED, readOnly = true)
    public ApiLogGetResponse getByObjectId(ApiLogGetRequest request, Passport passport) {
        ApiLogGetResponse response = new ApiLogGetResponse();
        ApiLogPO entity = apiLogMapper.getByObjectId(request.getId(), passport);
        if (entity != null) {
            ApiLog apiLog = this.getMapper().map(entity, ApiLog.class);
            response.setApiLog(apiLog);
        } else {
            response.addError(ErrorType.EXPECTATION_NULL, Message.COMMON_GET_FAILURE);
        }
        return response;
    }


    /**
     * 模糊查询远程调用日志
     *
     * @param request  模糊查询远程调用日志请求
     * @param passport 用户护照
     * @return 模糊查询远程调用日志应答
     */
    @Override
    @Transactional(propagation = Propagation.NOT_SUPPORTED, readOnly = true)
    public ApiLogSearchResponse search(ApiLogSearchRequest request, Passport passport) {
        ApiLogSearchResponse response = new ApiLogSearchResponse();
        List<ApiLog> modelList = new ArrayList<>();
        Long count = apiLogMapper.searchCount(request, passport);

        if (count > 0) {
            // 处理分页参数
            if (request.getPageSize() > 0) {
                //如果输入的页码大于实际的分页数,将页码设置为最后一页的页码
                int lastPageNumber = (int) ((count - 1) / request.getPageSize() + 1);
                if (request.getPageNumber() > lastPageNumber) {
                    request.setPageNumber(lastPageNumber);
                }
            }

            //通过关键字查询出用户集合
            List<ApiLogPO> entityList = apiLogMapper.search(request, passport);

            for (ApiLogPO entity : entityList) {
                ApiLog apiLog = this.getMapper().map(entity, ApiLog.class);
                modelList.add(apiLog);
            }
        }

        response.setTotalCount(count);
        response.setResult(modelList);
        return response;
    }

    /**
     * 高级查询远程调用日志
     *
     * @param request  高级查询远程调用日志请求
     * @param passport 用户护照
     * @return 高级查询远程调用日志应答
     */
    @Override
    @Transactional(propagation = Propagation.NOT_SUPPORTED, readOnly = true)
    public ApiLogFindResponse find(ApiLogFindRequest request, Passport passport) {
        ApiLogFindResponse response = new ApiLogFindResponse();
        List<ApiLog> modelList = new ArrayList<>();
        Long count = apiLogMapper.findCount(request, passport);
        if (count > 0) {
            // 处理分页参数
            if (request.getPageSize() > 0) {
                //如果输入的页码大于实际的分页数,将页码设置为最后一页的页码
                int lastPageNumber = (int) ((count - 1) / request.getPageSize() + 1);
                if (request.getPageNumber() > lastPageNumber) {
                    request.setPageNumber(lastPageNumber);
                }
            }

            List<ApiLogPO> entityList = apiLogMapper.find(request, passport);
            for (ApiLogPO entity : entityList) {
                ApiLog apiLog = this.getMapper().map(entity, ApiLog.class);
                modelList.add(apiLog);
            }
        }

        response.setTotalCount(count);
        response.setResult(modelList);
        return response;
    }

    /**
     * 创建远程调用日志
     *
     * @param request  创建远程调用日志请求
     * @param passport 用户护照
     * @return 创建远程调用日志应答
     */
    @Override
    public ApiLogCreateResponse create(ApiLogCreateRequest request, Passport passport) {
        ApiLogCreateResponse response = new ApiLogCreateResponse();

        ApiLogPO entity = this.getMapper().map(request, ApiLogPO.class);
        if (entity.getId() == null) {
            long id = foundationService.getNewId();
            entity.setId(id);
        }

        // 先检查关键数据是否有重复,在检查通过后才能做插入操作
        checkValidate(entity, passport, response);
        if (response.hasError()) {
            return response;
        }
        if(entity.getResponse() != null && !"".equals(entity.getResponse()) && entity.getResponse().length() > 1000){
            entity.setResponse(entity.getResponse().substring(0,1000));
        }
        if (apiLogMapper.insert(entity, passport) == 0) {
            response.addError(ErrorType.EXPECTATION_NULL, Message.COMMON_CREATE_FAILURE);
            return response;
        }

        response.setId(entity.getId());
        return response;
    }

    /**
     * 更新远程调用日志
     *
     * @param request  更新远程调用日志请求
     * @param passport 用户护照
     * @return 更新远程调用日志应答
     */
    @Override
    public ApiLogUpdateResponse update(ApiLogUpdateRequest request, Passport passport) {
        ApiLogUpdateResponse response = new ApiLogUpdateResponse();

        ApiLogPO entity = this.getMapper().map(request, ApiLogPO.class);
        // 先检查关键数据是否有重复,在检查通过后才能做插入操作
        checkValidate(entity, passport, response);
        if (response.hasError()) {
            return response;
        }

        Long result = apiLogMapper.update(entity, passport);
        if (result != 1) {
            response.addError(ErrorType.BUSINESS_ERROR, Message.COMMON_UPDATE_FAILURE);
            return response;
        }
        response.setResult(result);
        return response;
    }

    /**
     * 删除远程调用日志
     *
     * @param request  删除远程调用日志请求
     * @param passport 用户护照
     * @return 删除远程调用日志应答
     */
    @Override
    public ApiLogDeleteResponse delete(ApiLogDeleteRequest request, Passport passport) {
        ApiLogDeleteResponse response = new ApiLogDeleteResponse();
        Long result = apiLogMapper.delete(request.getId(), passport);
        response.setResult(result);
        return response;
    }


    /**
     * 验证对象
     *
     * @param apiLog   远程调用日志
     * @param passport 用户护照
     */
    private void checkValidate(ApiLogPO apiLog, Passport passport, BaseResponse response) {
        // TODO
    }
}