package com.java110.web.smo.impl;
import com.alibaba.fastjson.JSONObject;
import com.java110.common.constant.ServiceConstant;
import com.java110.common.exception.SMOException;
import com.java110.common.util.Assert;
import com.java110.common.util.StringUtil;
import com.java110.core.context.IPageData;
import com.java110.web.core.BaseComponentSMO;
import com.java110.web.smo.IFloorServiceSMO;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpMethod;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;
/**
* 小区楼实现类
*
* add by wuxw 2019-04-22
*/
@Service("floorServiceSMOImpl")
public class FloorServiceSMOImpl extends BaseComponentSMO implements IFloorServiceSMO {
private static Logger logger = LoggerFactory.getLogger(FloorServiceSMOImpl.class);
@Autowired
private RestTemplate restTemplate;
/**
* 查询小区楼
*
* @param pd 页面数据封装对象
* @return 返回 ResponseEntity对象包含 http状态 信息 body信息
*/
@Override
public ResponseEntity listFloor(IPageData pd) {
validateListFloor(pd);
JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
int page = Integer.parseInt(paramIn.getString("page"));
int rows = Integer.parseInt(paramIn.getString("rows"));
String floorName = paramIn.getString("floorName");
page = (page - 1) * rows;
ResponseEntity responseEntity = super.getStoreInfo(pd, restTemplate);
if (responseEntity.getStatusCode() != HttpStatus.OK) {
return responseEntity;
}
Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "storeId", "根据用户ID查询商户ID失败,未包含storeId节点");
String storeId = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeId");
if (StringUtil.isEmpty(floorName)) {
responseEntity = this.callCenterService(restTemplate, pd, "",
ServiceConstant.SERVICE_API_URL + "/api/query.staff.infos?rows=" + rows + "&page=" + page + "&storeId=" + storeId, HttpMethod.GET);
} else {
responseEntity = this.callCenterService(restTemplate, pd, "",
ServiceConstant.SERVICE_API_URL + "/api/query.staff.byName?rows=" + rows + "&page=" + page + "&storeId=" + storeId + "&name=" + floorName, HttpMethod.GET);
}
if (responseEntity.getStatusCode() != HttpStatus.OK) {
return responseEntity;
}
JSONObject resultObjs = JSONObject.parseObject(responseEntity.getBody().toString());
resultObjs.put("row", rows);
resultObjs.put("page", page);
return responseEntity;
}
/**
* 校验查询小区楼信息
*
* @param pd 页面封装对象
*/
private void validateListFloor(IPageData pd) {
Assert.jsonObjectHaveKey(pd.getReqData(), "page", "请求报文中未包含page节点");
Assert.jsonObjectHaveKey(pd.getReqData(), "rows", "请求报文中未包含rows节点");
JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
Assert.isInteger(paramIn.getString("page"), "page不是数字");
Assert.isInteger(paramIn.getString("rows"), "rows不是数字");
int rows = Integer.parseInt(paramIn.getString("rows"));
if (rows > 50) {
throw new SMOException(1999, "rows 数量不能大于50");
}
}
public RestTemplate getRestTemplate() {
return restTemplate;
}
public void setRestTemplate(RestTemplate restTemplate) {
this.restTemplate = restTemplate;
}
}