From ff8e858fc5da5de2739da2e1bf425f5c075091ba Mon Sep 17 00:00:00 2001 From: fengxiang <110431245@qq.com> Date: Wed, 09 May 2018 10:21:44 +0800 Subject: [PATCH] mobile app 设备详情 --- src/main/java/com/moral/controller/MobileController.java | 254 +++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 218 insertions(+), 36 deletions(-) diff --git a/src/main/java/com/moral/controller/MobileController.java b/src/main/java/com/moral/controller/MobileController.java index d178bc7..5ce114d 100644 --- a/src/main/java/com/moral/controller/MobileController.java +++ b/src/main/java/com/moral/controller/MobileController.java @@ -1,71 +1,253 @@ package com.moral.controller; +import static com.moral.common.util.WebUtils.getParametersStartingWith; + +import java.util.HashMap; import java.util.List; +import java.util.Map; import javax.annotation.Resource; +import javax.servlet.http.HttpServletRequest; -import org.springframework.web.bind.annotation.CrossOrigin; -import org.springframework.web.bind.annotation.GetMapping; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RestController; +import com.moral.common.util.Crypto; +import com.moral.entity.*; +import com.moral.entity.adapter.EquDeviceAdapter; +import com.moral.service.*; +import com.moral.util.MessageUtils; +import com.taobao.api.ApiException; +import org.apache.commons.lang3.StringUtils; +import org.springframework.cglib.beans.BeanMap; +import org.springframework.web.bind.annotation.*; -import com.github.pagehelper.PageHelper; -import com.moral.common.bean.PageBean; -import com.moral.common.bean.ResultBean; -import com.moral.entity.Device; -import com.moral.entity.OperateUser; -import com.moral.service.DeviceService; -import com.moral.service.OperateUserService; +import com.moral.common.bean.AppData; +/** + * The Class MobileController. + */ @RestController -@RequestMapping(value = "mobile") +@RequestMapping("mobile") @CrossOrigin(origins = "*", maxAge = 3600) public class MobileController { + /** The operate user service. */ @Resource private OperateUserService operateUserService; + /** The device service. */ @Resource private DeviceService deviceService; - // 1������ - @GetMapping(value = "accountlogin") - public ResultBean<OperateUser> mobileLogin(String username, String password) { + /** The organization service. */ + @Resource + private OrganizationService organizationService; + + /** The monitor point service. */ + @Resource + private MonitorPointService monitorPointService; + + @Resource + private ProfessionService professionService; + + /** + * Mobile login.������ + * + * @param username the username + * @param password the password + * @return the result bean + */ + @RequestMapping("accountlogin") + public AppData<OperateUser> mobileLogin(String username, String password) { OperateUser operateUser = operateUserService.mobileLogin(username,password); - return new ResultBean<OperateUser>(operateUser); + return new AppData<OperateUser>(operateUser); } - // 4������������ - @GetMapping(value = "upPassword") - public ResultBean<OperateUser> updatePassword(Integer uid, String password, String newpassword) { + /** + * Update password.������������ + * + * @param uid the uid + * @param password the password + * @param newpassword the newpassword + * @return the result bean + */ + @RequestMapping("upPassword") + public AppData<OperateUser> updatePassword(Integer uid, String password, String newpassword) { OperateUser operateUser = operateUserService.updatePassword(uid,password,newpassword); - return new ResultBean<OperateUser>(operateUser); + return new AppData<OperateUser>(operateUser); + } + /** + * ������ ������id ��������������������� + */ + @RequestMapping("deviceInfo") + public AppData<Device> deviceInfo(Integer id){ + Device device = deviceService.queryById(id); + return new AppData<Device>(device); + } + /** + * + * @param equDeviceAdapter + * @return + */ + @RequestMapping("reportDevice") + public AppData<String> installDevice(EquDeviceAdapter equDeviceAdapter) { + deviceService.saveOrUpdateDevice(equDeviceAdapter.toDevice()); + return new AppData<String>(""); } - // 11������������ - @GetMapping(value = "reportDevice") - public ResultBean<String> installDevice(Device device) { - deviceService.saveOrUpdateDevice(device); - return new ResultBean<String>(""); + /** + * Gets the install devices by operate user.������������ + * + * @param uid the uid + * @param pageIndex the page index + * @param pageSize the page size + * @return the install devices by operate user + */ + @RequestMapping("myRelease") + public AppData<List<Device>> getInstallDevicesByOperateUser(@RequestParam(value="uid", required=true)Integer uid, + @RequestParam(defaultValue="0")Integer pageIndex, @RequestParam(defaultValue="0")Integer pageSize) { + List<Device> devices = deviceService.getInstallDevicesByOperateUser(uid, pageIndex, pageSize); + return new AppData<List<Device>>(devices); } - // 5������������������(������) - @GetMapping(value = "myRelease") - public ResultBean<List<Device>> getInstallDevicesByOperateUser(Integer uid, Integer pageIndex, Integer pageSize) { - List<Device> devices = deviceService.getInstallDevicesByOperateUser(uid,pageIndex,pageSize); - return new ResultBean<List<Device>>(devices); + /** + * Gets the device by mac. + * + * @param mac the mac + * @return the device by mac + */ + @RequestMapping("getEquInfoByMac") + public AppData<Map> getDeviceByMac(@RequestParam(value="mac", required=true)String mac) { + Device device = deviceService.getDeviceByMac(mac,false);//��������������� + if(device!=null){ + Map<String,Object> deviceMap = new HashMap<>(BeanMap.create(device)); + deviceMap.put("monitorpointDetail",deviceMap.get("monitorPoint")); + deviceMap.remove("monitorPoint"); + return new AppData<Map>(deviceMap); + }else{ + return new AppData("mac���������������",AppData.FAIL); + } } - @GetMapping(value = "getEquInfoByMac") - public void getEquInfoByMac(String mac) { + /** + * Gets the monitor points by area name. + * + * @param request the area name + * @return the monitor points by area name + */ + @RequestMapping("getMpointsByAreaName") + public AppData<List<MonitorPoint>> getMonitorPointsByAreaName(HttpServletRequest request) { + Map<String, Object> parameters = getParametersStartingWith(request, null); + List<MonitorPoint> monitorPoints = monitorPointService.getMonitorPointsByAreaName(parameters); + return new AppData<List<MonitorPoint>>(monitorPoints); } - @GetMapping(value = "getMpointsByAreaName") - public void getMpointsByAreaName(String areaName) { + /** + * Gets the organizations by area name. + * + * @param request the area name + * @return the organizations by area name + */ + @RequestMapping("getOrgsByAreaName") + public AppData<List<Organization>> getOrganizationsByAreaName(HttpServletRequest request) { + Map<String, Object> parameters = getParametersStartingWith(request, null); + List<Organization> organizations = organizationService.getOrganizationsByAreaName(parameters); + return new AppData<List<Organization>>(organizations); } - @GetMapping(value = "getOrgsByAreaName") - public void getOrgsByAreaName(String areaName) { + /** + * Send SMS + * + * @param mobile + * @return + */ + @RequestMapping("sendSms") + public AppData<String> sendSms(String mobile) { + AppData apiData = new AppData(); + if (StringUtils.isBlank(mobile)){ + apiData.setErrno(1); + apiData.setMessage("������������������������"); + apiData.setData("{}"); + return apiData; + } + OperateUser user = operateUserService.getOperateUserByMobile(mobile); + if (user==null){ + apiData.setErrno(1); + apiData.setMessage("���������������������������"); + apiData.setData("{}"); + return apiData; + } + //��������������� + int code = (int)((Math.random() * 9 + 1) * 100000); + user.setCode(String.valueOf(code)); + operateUserService.updateOperateUser(user); + + //��������������� + try { + int state = MessageUtils.sendMsg(mobile, String.valueOf(code)); + if(state==0){ + apiData.setErrno(0); + apiData.setMessage("���������������������"); + apiData.setData("{}"); + return apiData; + } + if(state==1){ + apiData.setErrno(1); + apiData.setMessage("���������������������"); + apiData.setData("{}"); + return apiData; + } + } catch (ApiException e) { + e.printStackTrace(); + } + return new AppData<String>(""); + } + + /** + * + * @param username + * @param password + * @param code + * @return + */ + @RequestMapping("password") + public AppData<String> password(String username, String password, String code){ + AppData apiData = new AppData(); + + if (StringUtils.isBlank(code)){ + apiData.setErrno(1); + apiData.setMessage("������������������������������������������"); + apiData.setData("{}"); + return apiData; + } + OperateUser user = operateUserService.getOperateUserByMobile(username); + if (user==null){ + apiData.setErrno(1); + apiData.setMessage("���������������������������"); + apiData.setData("{}"); + return apiData; + } + if (user.getCode().equals(code)){ + user.setPassword(Crypto.md5(password)); + int new_code = (int)((Math.random() * 9 + 1) * 100000); + user.setCode(String.valueOf(new_code)); + operateUserService.updateOperateUser(user); + + apiData.setErrno(0); + apiData.setMessage("������������������"); + apiData.setData("{}"); + return apiData; + } else { + apiData.setErrno(1); + apiData.setMessage("������������������������"); + apiData.setData("{}"); + return apiData; + } + } + + @RequestMapping("profession") + public AppData<List<Profession>> profession(){ + + List<Profession> professions = professionService.getProfessiontList(); + return new AppData<List<Profession>>(professions); } } -- Gitblit v1.8.0