package com.yeshi.makemoney.app.service.impl.goldcorn;
|
|
import java.lang.Exception;
|
import javax.annotation.Resource;
|
|
import com.yeshi.makemoney.app.exception.goldcorn.GoldCornTaskTypeInfoException;
|
import org.springframework.data.domain.Sort;
|
import org.springframework.stereotype.Service;
|
|
import java.util.Arrays;
|
import java.util.Date;
|
|
import org.yeshi.utils.StringUtil;
|
import org.yeshi.utils.bean.BeanUtil;
|
|
import java.util.List;
|
|
import com.yeshi.makemoney.app.dao.goldcorn.GoldCornTaskTypeInfoDao;
|
import com.yeshi.makemoney.app.entity.goldcorn.GoldCornTaskTypeInfo;
|
import com.yeshi.makemoney.app.service.inter.goldcorn.GoldCornTaskTypeInfoService;
|
import com.yeshi.makemoney.app.service.query.goldcorn.GoldCornTaskTypeInfoQuery;
|
import com.yeshi.makemoney.app.dao.goldcorn.GoldCornTaskTypeInfoDao.DaoQuery;
|
|
import org.springframework.data.mongodb.core.query.Criteria;
|
import org.springframework.data.mongodb.core.query.Query;
|
|
@Service
|
public class GoldCornTaskTypeInfoServiceImpl implements GoldCornTaskTypeInfoService {
|
|
@Resource
|
private GoldCornTaskTypeInfoDao goldCornTaskTypeInfoDao;
|
|
|
private DaoQuery createDaoQuery(GoldCornTaskTypeInfoQuery goldCornTaskTypeInfoQuery) {
|
DaoQuery daoQuery = new DaoQuery();
|
daoQuery.system = goldCornTaskTypeInfoQuery.getSystem();
|
daoQuery.type = goldCornTaskTypeInfoQuery.getType();
|
daoQuery.show = goldCornTaskTypeInfoQuery.getShow();
|
daoQuery.showTime = goldCornTaskTypeInfoQuery.getShowTime();
|
return daoQuery;
|
}
|
|
@Override
|
public List<GoldCornTaskTypeInfo> list(GoldCornTaskTypeInfoQuery goldCornTaskTypeInfoQuery, int page, int pageSize) {
|
DaoQuery daoQuery = createDaoQuery(goldCornTaskTypeInfoQuery);
|
daoQuery.start = (page - 1) * pageSize;
|
daoQuery.count = pageSize;
|
daoQuery.sortList = Arrays.asList(new Sort.Order[]{Sort.Order.asc("order")});
|
return goldCornTaskTypeInfoDao.list(daoQuery);
|
}
|
|
@Override
|
public long count(GoldCornTaskTypeInfoQuery goldCornTaskTypeInfoQuery) {
|
DaoQuery daoQuery = createDaoQuery(goldCornTaskTypeInfoQuery);
|
return goldCornTaskTypeInfoDao.count(daoQuery);
|
}
|
|
@Override
|
public GoldCornTaskTypeInfo get(String id) {
|
Query query = new Query();
|
query.addCriteria(Criteria.where("_id").is(id));
|
return goldCornTaskTypeInfoDao.findOne(query);
|
}
|
|
@Override
|
public void add(GoldCornTaskTypeInfo goldCornTaskTypeInfo) throws GoldCornTaskTypeInfoException {
|
|
if (goldCornTaskTypeInfo == null || goldCornTaskTypeInfo.getType() == null || goldCornTaskTypeInfo.getSystem() == null) {
|
throw new GoldCornTaskTypeInfoException(GoldCornTaskTypeInfoException.CODE_PARAMS_NOT_ENOUGH, "参数不完整");
|
}
|
|
if (goldCornTaskTypeInfo.getId() == null) {
|
goldCornTaskTypeInfo.setId(goldCornTaskTypeInfo.toId());
|
}
|
|
//查询主键ID是否存在
|
if (goldCornTaskTypeInfoDao.get(goldCornTaskTypeInfo.getId()) != null) {
|
throw new GoldCornTaskTypeInfoException(GoldCornTaskTypeInfoException.CODE_EXIST, "已存在");
|
}
|
|
if (StringUtil.isNullOrEmpty(goldCornTaskTypeInfo.getName())) {
|
goldCornTaskTypeInfo.setName(goldCornTaskTypeInfo.getType().getName());
|
}
|
|
if (goldCornTaskTypeInfo.getCreateTime() == null) {
|
goldCornTaskTypeInfo.setCreateTime(new Date());
|
}
|
//保存
|
goldCornTaskTypeInfoDao.save(goldCornTaskTypeInfo);
|
}
|
|
@Override
|
public void update(GoldCornTaskTypeInfo goldCornTaskTypeInfo) {
|
if (goldCornTaskTypeInfo.getUpdateTime() == null) {
|
goldCornTaskTypeInfo.setUpdateTime(new Date());
|
}
|
//更新
|
goldCornTaskTypeInfoDao.updateSelective(goldCornTaskTypeInfo);
|
}
|
|
@Override
|
public void delete(List<String> idList) {
|
for (String id : idList) {
|
goldCornTaskTypeInfoDao.delete(id);
|
}
|
}
|
|
|
}
|