SafeMessageManagerImpl.java 8.25 KB
/*
 * @(#)SafeMessageManagerImpl.java
 *
 * Copyright (c) 2014-2017   版权所有
 * 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.alibaba.dubbo.common.utils.StringUtils;
import com.xiniunet.framework.base.BaseManagerImpl;
import com.xiniunet.framework.base.BaseResponse;
import com.xiniunet.framework.security.Passport;
import com.xiniunet.railway.request.*;
import com.xiniunet.railway.response.*;
import com.xiniunet.railway.domain.*;
import com.xiniunet.foundation.service.FoundationService;
import com.xiniunet.service.railway.dal.SafeMessageMapper;
import com.xiniunet.service.railway.po.SafeMessagePO;
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 com.xiniunet.framework.exception.ErrorType;


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

/**
 * 的管理方法实现.
 * @author
 */
@Transactional
@Service("RailwaySafeMessageManager")
public class SafeMessageManagerImpl extends BaseManagerImpl implements SafeMessageManager {

    @Autowired
    private FoundationService foundationService;

    @Autowired
    private SafeMessageMapper safeMessageMapper;

    /**
     * 根据Id获取
     *
     * @param request 获取请求
     * @param passport 用户护照
     * @return 获取应答
     */
    @Override
    @Transactional(propagation = Propagation.NOT_SUPPORTED, readOnly = true)
    public SafeMessageGetResponse get(SafeMessageGetRequest request, Passport passport) {
        SafeMessageGetResponse response = new SafeMessageGetResponse();
        SafeMessagePO entity = safeMessageMapper.getById(request.getId(), passport);
        if (entity != null) {
            SafeMessage safeMessage = this.getMapper().map(entity, SafeMessage.class);
            response.setSafeMessage(safeMessage );
        } else {
            response.addError(ErrorType.EXPECTATION_NULL, "获取失败");
        }
        return response;
    }


    /**
     * 模糊查询
     *
     * @param request 模糊查询请求
     * @param passport 用户护照
     * @return 模糊查询应答
     */
    @Override
    @Transactional(propagation = Propagation.NOT_SUPPORTED, readOnly = true)
    public SafeMessageSearchResponse search(SafeMessageSearchRequest request, Passport passport) {
        SafeMessageSearchResponse response = new SafeMessageSearchResponse();
        List<SafeMessage> modelList = new ArrayList<>();
        Long count = safeMessageMapper.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<SafeMessagePO> entityList = safeMessageMapper.search(request, passport);

            for (SafeMessagePO entity : entityList) {
                SafeMessage safeMessage = this.getMapper().map(entity, SafeMessage.class);
                modelList.add(safeMessage);
            }
        }

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

    /**
     * 高级查询
     *
     * @param request 高级查询请求
     * @param passport 用户护照
     * @return 高级查询应答
     */
    @Override
    @Transactional(propagation = Propagation.NOT_SUPPORTED, readOnly = true)
    public SafeMessageFindResponse find(SafeMessageFindRequest request, Passport passport) {
        SafeMessageFindResponse response = new SafeMessageFindResponse();
        List<SafeMessage> modelList = new ArrayList<>();
        Long count = safeMessageMapper.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<SafeMessagePO> entityList = safeMessageMapper.find(request, passport);
            for (SafeMessagePO entity : entityList) {
                SafeMessage safeMessage = this.getMapper().map(entity, SafeMessage.class);
                modelList.add(safeMessage);
            }
        }

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


    /**
     * 创建
     *
     * @param request 创建请求
     * @param passport 用户护照
     * @return 创建应答
     */
    @Override
    public SafeMessageCreateResponse create(SafeMessageCreateRequest request, Passport passport) {
        SafeMessageCreateResponse response = new SafeMessageCreateResponse();

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

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

        if (safeMessageMapper.insert(entity, passport) == 0) {
            response.addError(ErrorType.EXPECTATION_NULL, "创建失败");
            return response;
        }

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

    /**
     * 更新
     *
     * @param request 更新请求
     * @param passport 用户护照
     * @return 更新应答
     */
    @Override
    public SafeMessageUpdateResponse update(SafeMessageUpdateRequest request, Passport passport) {
        SafeMessageUpdateResponse response = new SafeMessageUpdateResponse();

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

        Long result=safeMessageMapper.update(entity, passport);
        if (result != 1) {
            response.addError(ErrorType.BUSINESS_ERROR, "更新失败");
            return response;
        }
        response.setResult(result);
        return response;
    }

    /**
     * 删除
     *
     * @param request 删除请求
     * @param passport 用户护照
     * @return 删除应答
     */
    @Override
    public SafeMessageDeleteResponse delete(SafeMessageDeleteRequest request, Passport passport) {
        SafeMessageDeleteResponse response = new SafeMessageDeleteResponse();
        Long result= safeMessageMapper.delete(request.getId(), passport);
        response.setResult(result);
        return response;
    }

    @Override
    public RailwayLineFindResponse railwayLineFind(RailwayLineFindRequest request, Passport passport) {
        RailwayLineFindResponse response = new RailwayLineFindResponse();
        if(request!=null && StringUtils.isNotEmpty(request.getLineName())){
            request.setLineName(request.getLineName().replace("地铁站",""));
            request.setLineName(request.getLineName().replace("站",""));
        }
        List<RailwayInfo> objectList = safeMessageMapper.railwayLineFind(request,passport);
        response.setResult(objectList);
        return response;
    }


    /**
     * 验证对象
     * @param safeMessage
     * @param passport 用户护照
     */
    private void checkValidate(SafeMessagePO safeMessage, Passport passport, BaseResponse response) {
        // TODO
    }
}