|  |  |  | 
|---|
|  |  |  | catalogXml.append("<Item>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<DeviceID>" + channel.getChannelId() + "</DeviceID>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Name>" + channel.getName() + "</Name>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Manufacturer>" + channel.getManufacture() + "</Manufacturer>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Parental>" + channel.getParental() + "</Parental>\r\n"); | 
|---|
|  |  |  | if (channel.getParentId() != null) { | 
|---|
|  |  |  | catalogXml.append("<ParentID>" + channel.getParentId() + "</ParentID>\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catalogXml.append("<RegisterWay>" + channel.getRegisterWay() + "</RegisterWay>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Status>" + (channel.getStatus() == 0?"OFF":"ON") + "</Status>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Secrecy>" + channel.getSecrecy() + "</Secrecy>\r\n"); | 
|---|
|  |  |  | if (channel.getChannelType() != 2) { // 业务分组/虚拟组织/行政区划 不设置以下字段 | 
|---|
|  |  |  | catalogXml.append("<Model>" + channel.getModel() + "</Model>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Owner>" + channel.getOwner() + "</Owner>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<CivilCode>" + channel.getCivilCode() + "</CivilCode>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Address>" + channel.getAddress() + "</Address>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Longitude>" + channel.getLongitude() + "</Longitude>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Latitude>" + channel.getLatitude() + "</Latitude>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<IPAddress>" + channel.getIpAddress() + "</IPAddress>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Port>" + channel.getPort() + "</Port>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Info>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<PTZType>" + channel.getPTZType() + "</PTZType>\r\n"); | 
|---|
|  |  |  | catalogXml.append("</Info>\r\n"); | 
|---|
|  |  |  | if (channel.getChannelId().length() == 20) { | 
|---|
|  |  |  | if (Integer.parseInt(channel.getChannelId().substring(10, 13)) == 216) { // 虚拟组织增加BusinessGroupID字段 | 
|---|
|  |  |  | catalogXml.append("<BusinessGroupID>" + channel.getParentId() + "</BusinessGroupID>\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catalogXml.append("<Manufacturer>" + channel.getManufacture() + "</Manufacturer>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<RegisterWay>" + channel.getRegisterWay() + "</RegisterWay>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Status>" + (channel.getStatus() == 0?"OFF":"ON") + "</Status>\r\n"); | 
|---|
|  |  |  | if (channel.getChannelType() != 2) { // 业务分组/虚拟组织/行政区划 不设置以下字段 | 
|---|
|  |  |  | catalogXml.append("<Secrecy>" + channel.getSecrecy() + "</Secrecy>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Model>" + channel.getModel() + "</Model>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Owner>" + channel.getOwner() + "</Owner>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<CivilCode>" + channel.getCivilCode() + "</CivilCode>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Address>" + channel.getAddress() + "</Address>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Longitude>" + channel.getLongitude() + "</Longitude>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Latitude>" + channel.getLatitude() + "</Latitude>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<IPAddress>" + channel.getIpAddress() + "</IPAddress>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Port>" + channel.getPort() + "</Port>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Info>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<PTZType>" + channel.getPTZType() + "</PTZType>\r\n"); | 
|---|
|  |  |  | catalogXml.append("</Info>\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | catalogXml.append("</Item>\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public boolean sendAlarmMessage(ParentPlatform parentPlatform, DeviceAlarm deviceAlarm) { | 
|---|
|  |  |  | if (parentPlatform == null) { | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | logger.info("[发送 报警订阅] {}/{}->{},{}", parentPlatform.getServerGBId(), deviceAlarm.getChannelId(), | 
|---|
|  |  |  | deviceAlarm.getLongitude(), deviceAlarm.getLatitude()); | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | String characterSet = parentPlatform.getCharacterSet(); | 
|---|
|  |  |  | StringBuffer deviceStatusXml = new StringBuffer(600); | 
|---|
|  |  |  | deviceStatusXml.append("<?xml version=\"1.0\" encoding=\"" + characterSet + "\"?>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<Notify>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<CmdType>Alarm</CmdType>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<SN>" + (int)((Math.random()*9+1)*100000) + "</SN>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<DeviceID>" + deviceAlarm.getChannelId() + "</DeviceID>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<AlarmPriority>" + deviceAlarm.getAlarmPriority() + "</AlarmPriority>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<AlarmMethod>" + deviceAlarm.getAlarmMethod() + "</AlarmMethod>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<AlarmTime>" + deviceAlarm.getAlarmTime() + "</AlarmTime>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<AlarmDescription>" + deviceAlarm.getAlarmDescription() + "</AlarmDescription>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<Longitude>" + deviceAlarm.getLongitude() + "</Longitude>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<Latitude>" + deviceAlarm.getLatitude() + "</Latitude>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<info>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("<AlarmType>" + deviceAlarm.getAlarmType() + "</AlarmType>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("</info>\r\n"); | 
|---|
|  |  |  | deviceStatusXml.append("</Notify>\r\n"); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | CallIdHeader callIdHeader = parentPlatform.getTransport().equals("TCP") ? tcpSipProvider.getNewCallId() | 
|---|
|  |  |  | : udpSipProvider.getNewCallId(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | String tm = Long.toString(System.currentTimeMillis()); | 
|---|
|  |  |  | Request request = headerProviderPlarformProvider.createMessageRequest(parentPlatform, deviceStatusXml.toString(), "FromPtz" + tm, callIdHeader); | 
|---|
|  |  |  | transmitRequest(parentPlatform, request); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } catch (SipException | ParseException  e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | } catch (InvalidArgumentException e) { | 
|---|
|  |  |  | throw new RuntimeException(e); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public boolean sendNotifyForCatalogAddOrUpdate(String type, ParentPlatform parentPlatform, List<DeviceChannel> deviceChannels, SubscribeInfo subscribeInfo, Integer index) { | 
|---|
|  |  |  | if (parentPlatform == null || deviceChannels == null || deviceChannels.size() == 0 || subscribeInfo == null) { | 
|---|
|  |  |  | return false; | 
|---|
|  |  |  | 
|---|
|  |  |  | // 设置编码, 防止中文乱码 | 
|---|
|  |  |  | messageFactory.setDefaultContentEncodingCharset(characterSet); | 
|---|
|  |  |  | Dialog dialog  = subscribeInfo.getDialog(); | 
|---|
|  |  |  | if (dialog == null || !dialog.getState().equals(DialogState.CONFIRMED)) return; | 
|---|
|  |  |  | if (dialog == null || !dialog.getState().equals(DialogState.CONFIRMED)) { | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | SIPRequest notifyRequest = (SIPRequest)dialog.createRequest(Request.NOTIFY); | 
|---|
|  |  |  | ContentTypeHeader contentTypeHeader = sipFactory.createHeaderFactory().createContentTypeHeader("Application", "MANSCDP+xml"); | 
|---|
|  |  |  | notifyRequest.setContent(catalogXmlContent, contentTypeHeader); | 
|---|
|  |  |  | 
|---|
|  |  |  | event.setEventId(subscribeInfo.getEventId()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | notifyRequest.addHeader(event); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | SipURI sipURI = (SipURI) notifyRequest.getRequestURI(); | 
|---|
|  |  |  | SIPRequest request = (SIPRequest) subscribeInfo.getTransaction().getRequest(); | 
|---|
|  |  |  | sipURI.setHost(request.getRemoteAddress().getHostAddress()); | 
|---|
|  |  |  | sipURI.setPort(request.getRemotePort()); | 
|---|
|  |  |  | if (subscribeInfo.getTransaction() != null) { | 
|---|
|  |  |  | SIPRequest request = (SIPRequest) subscribeInfo.getTransaction().getRequest(); | 
|---|
|  |  |  | sipURI.setHost(request.getRemoteAddress().getHostAddress()); | 
|---|
|  |  |  | sipURI.setPort(request.getRemotePort()); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | sipURI.setHost(parentPlatform.getServerIP()); | 
|---|
|  |  |  | sipURI.setPort(parentPlatform.getServerPort()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | ClientTransaction transaction = null; | 
|---|
|  |  |  | if ("TCP".equals(parentPlatform.getTransport())) { | 
|---|
|  |  |  | transaction = tcpSipProvider.getNewClientTransaction(notifyRequest); | 
|---|
|  |  |  | 
|---|
|  |  |  | catalogXml.append("<Secrecy>" + channel.getSecrecy() + "</Secrecy>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<RegisterWay>" + channel.getRegisterWay() + "</RegisterWay>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Status>" + (channel.getStatus() == 0 ? "OFF" : "ON") + "</Status>\r\n"); | 
|---|
|  |  |  | if (channel.getChannelId().length() == 20 && Integer.parseInt(channel.getChannelId().substring(10, 13)) == 216) { // 虚拟组织增加BusinessGroupID字段 | 
|---|
|  |  |  | catalogXml.append("<BusinessGroupID>" + channel.getParentId() + "</BusinessGroupID>\r\n"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (channel.getChannelType() == 2) {  // 业务分组/虚拟组织/行政区划 不设置以下属性 | 
|---|
|  |  |  | catalogXml.append("<Model>" + channel.getModel() + "</Model>\r\n"); | 
|---|
|  |  |  | catalogXml.append("<Owner>0</Owner>\r\n"); | 
|---|