Merge branch 'dev-V0.5.0' into V0.5.x

V0.5.x
tangfudong 2024-03-27 11:23:30 +08:00
commit fd4427b991
2 changed files with 25 additions and 4 deletions

View File

@ -19,11 +19,14 @@ import cc.iotkit.common.utils.JsonUtils;
import cc.iotkit.data.manager.ICategoryData; import cc.iotkit.data.manager.ICategoryData;
import cc.iotkit.data.manager.IDeviceInfoData; import cc.iotkit.data.manager.IDeviceInfoData;
import cc.iotkit.data.manager.IUserInfoData; import cc.iotkit.data.manager.IUserInfoData;
import cc.iotkit.manager.dto.bo.device.ServiceInvokeBo;
import cc.iotkit.manager.dto.bo.device.SetDeviceServicePorpertyBo;
import cc.iotkit.manager.dto.vo.product.ProductVo; import cc.iotkit.manager.dto.vo.product.ProductVo;
import cc.iotkit.manager.dto.vo.thingmodel.ThingModelVo; import cc.iotkit.manager.dto.vo.thingmodel.ThingModelVo;
import cc.iotkit.manager.model.vo.FindDeviceVo; import cc.iotkit.manager.model.vo.FindDeviceVo;
import cc.iotkit.manager.model.vo.SpaceDeviceVo; import cc.iotkit.manager.model.vo.SpaceDeviceVo;
import cc.iotkit.manager.service.*; import cc.iotkit.manager.service.*;
import cc.iotkit.model.InvokeResult;
import cc.iotkit.model.UserInfo; import cc.iotkit.model.UserInfo;
import cc.iotkit.model.device.DeviceInfo; import cc.iotkit.model.device.DeviceInfo;
import cc.iotkit.model.product.Category; import cc.iotkit.model.product.Category;
@ -70,6 +73,9 @@ public class SpaceDeviceController {
private IUserInfoData userInfoData; private IUserInfoData userInfoData;
@Autowired @Autowired
private IDeviceManagerService deviceServiceImpl; private IDeviceManagerService deviceServiceImpl;
//赋予应用端设备的服务和属性设置,关于应用的接口及相关权限设计后续完善,先打通链路
@Autowired
private DeviceCtrlService deviceCtrlService;
/** /**
* 使 * 使
@ -223,6 +229,18 @@ public class SpaceDeviceController {
return deviceServiceImpl.getDetail(request.getData()); return deviceServiceImpl.getDetail(request.getData());
} }
@ApiOperation("调用设备服务")
@PostMapping("/invokeService")
public InvokeResult invokeService(@RequestBody @Validated Request<ServiceInvokeBo> request) {
return new InvokeResult(deviceCtrlService.invokeService(request.getData().getDeviceId(), request.getData().getService(), request.getData().getArgs()));
}
@ApiOperation(value = "设备属性设置")
@PostMapping("/setProperty")
public InvokeResult setProperty(@RequestBody @Validated Request<SetDeviceServicePorpertyBo> request) {
return new InvokeResult(deviceCtrlService.setProperty(request.getData().getDeviceId(), request.getData().getArgs()));
}
/** /**
* REMOVE_DEVICE * REMOVE_DEVICE
* *
@ -286,15 +304,15 @@ public class SpaceDeviceController {
/** /**
* *
*/ */
@DeleteMapping(Constants.API_SPACE.REMOVE_DEVICE) @PostMapping(Constants.API_SPACE.REMOVE_DEVICE)
public void removeDevice(String deviceId) { public void removeDevice(@RequestBody @Validated Request<String> request) {
SpaceDevice spaceDevice = spaceDeviceService.findByDeviceId(deviceId); SpaceDevice spaceDevice = spaceDeviceService.findByDeviceId(request.getData());
if (spaceDevice == null) { if (spaceDevice == null) {
throw new BizException(ErrCode.SPACE_DEVICE_NOT_FOUND); throw new BizException(ErrCode.SPACE_DEVICE_NOT_FOUND);
} }
spaceDeviceService.deleteById(spaceDevice.getId()); spaceDeviceService.deleteById(spaceDevice.getId());
DeviceInfo deviceInfo = deviceInfoData.findByDeviceId(deviceId); DeviceInfo deviceInfo = deviceInfoData.findByDeviceId(request.getData());
UserInfo userInfo = userInfoData.findById(LoginHelper.getUserId()); UserInfo userInfo = userInfoData.findById(LoginHelper.getUserId());
if (userInfo == null) { if (userInfo == null) {
throw new BizException(ErrCode.USER_NOT_FOUND); throw new BizException(ErrCode.USER_NOT_FOUND);

View File

@ -79,4 +79,7 @@ public class DeviceInfoVo implements Serializable {
@ApiModelProperty(value = "所属分组") @ApiModelProperty(value = "所属分组")
private Map<String, DeviceInfo.Group> group; private Map<String, DeviceInfo.Group> group;
@ApiModelProperty(value = "位置信息")
private DeviceInfo.Locate locate;
} }