|  | @@ -8,6 +8,7 @@ import javax.sip.SipException;
 | 
	
		
			
				|  |  |  import javax.sip.message.Request;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  import org.springframework.beans.factory.annotation.Autowired;
 | 
	
		
			
				|  |  | +import org.springframework.context.ApplicationEventPublisher;
 | 
	
		
			
				|  |  |  import org.springframework.stereotype.Component;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  import com.genersoft.iot.vmp.conf.SipConfig;
 | 
	
	
		
			
				|  | @@ -15,7 +16,7 @@ import com.genersoft.iot.vmp.gb28181.SipLayer;
 | 
	
		
			
				|  |  |  import com.genersoft.iot.vmp.gb28181.bean.Device;
 | 
	
		
			
				|  |  |  import com.genersoft.iot.vmp.gb28181.transmit.cmd.ISIPCommander;
 | 
	
		
			
				|  |  |  import com.genersoft.iot.vmp.gb28181.transmit.cmd.SIPRequestHeaderProvider;
 | 
	
		
			
				|  |  | -import com.genersoft.iot.vmp.storager.IVideoManagerStorager;
 | 
	
		
			
				|  |  | +import com.genersoft.iot.vmp.gb28181.utils.DateUtil;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  /**    
 | 
	
		
			
				|  |  |   * @Description:设备能力接口,用于定义设备的控制、查询能力   
 | 
	
	
		
			
				|  | @@ -34,66 +35,63 @@ public class SIPCommander implements ISIPCommander {
 | 
	
		
			
				|  |  |  	@Autowired
 | 
	
		
			
				|  |  |  	private SipLayer sipLayer;
 | 
	
		
			
				|  |  |  	
 | 
	
		
			
				|  |  | -	@Autowired
 | 
	
		
			
				|  |  | -	private IVideoManagerStorager storager;
 | 
	
		
			
				|  |  | -	 
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 云台方向放控制,使用配置文件中的默认镜头移动速度
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  控制设备
 | 
	
		
			
				|  |  | +	 * @param device  控制设备
 | 
	
		
			
				|  |  |  	 * @param channelId  预览通道
 | 
	
		
			
				|  |  |  	 * @param leftRight  镜头左移右移 0:停止 1:左移 2:右移
 | 
	
		
			
				|  |  |       * @param upDown     镜头上移下移 0:停止 1:上移 2:下移
 | 
	
		
			
				|  |  |       * @param moveSpeed  镜头移动速度
 | 
	
		
			
				|  |  |  	 */
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public boolean ptzdirectCmd(String deviceId, String channelId, int leftRight, int upDown) {
 | 
	
		
			
				|  |  | -		return ptzCmd(deviceId, channelId, leftRight, upDown, 0, config.getSpeed(), 0);
 | 
	
		
			
				|  |  | +	public boolean ptzdirectCmd(Device device, String channelId, int leftRight, int upDown) {
 | 
	
		
			
				|  |  | +		return ptzCmd(device, channelId, leftRight, upDown, 0, config.getSpeed(), 0);
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 云台方向放控制
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  控制设备
 | 
	
		
			
				|  |  | +	 * @param device  控制设备
 | 
	
		
			
				|  |  |  	 * @param channelId  预览通道
 | 
	
		
			
				|  |  |  	 * @param leftRight  镜头左移右移 0:停止 1:左移 2:右移
 | 
	
		
			
				|  |  |       * @param upDown     镜头上移下移 0:停止 1:上移 2:下移
 | 
	
		
			
				|  |  |       * @param moveSpeed  镜头移动速度
 | 
	
		
			
				|  |  |  	 */
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public boolean ptzdirectCmd(String deviceId, String channelId, int leftRight, int upDown, int moveSpeed) {
 | 
	
		
			
				|  |  | -		return ptzCmd(deviceId, channelId, leftRight, upDown, 0, moveSpeed, 0);
 | 
	
		
			
				|  |  | +	public boolean ptzdirectCmd(Device device, String channelId, int leftRight, int upDown, int moveSpeed) {
 | 
	
		
			
				|  |  | +		return ptzCmd(device, channelId, leftRight, upDown, 0, moveSpeed, 0);
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 云台缩放控制,使用配置文件中的默认镜头缩放速度
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  控制设备
 | 
	
		
			
				|  |  | +	 * @param device  控制设备
 | 
	
		
			
				|  |  |  	 * @param channelId  预览通道
 | 
	
		
			
				|  |  |       * @param inOut      镜头放大缩小 0:停止 1:缩小 2:放大
 | 
	
		
			
				|  |  |  	 */  
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public boolean ptzZoomCmd(String deviceId, String channelId, int inOut) {
 | 
	
		
			
				|  |  | -		return ptzCmd(deviceId, channelId, 0, 0, inOut, 0, config.getSpeed());
 | 
	
		
			
				|  |  | +	public boolean ptzZoomCmd(Device device, String channelId, int inOut) {
 | 
	
		
			
				|  |  | +		return ptzCmd(device, channelId, 0, 0, inOut, 0, config.getSpeed());
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 云台缩放控制
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  控制设备
 | 
	
		
			
				|  |  | +	 * @param device  控制设备
 | 
	
		
			
				|  |  |  	 * @param channelId  预览通道
 | 
	
		
			
				|  |  |       * @param inOut      镜头放大缩小 0:停止 1:缩小 2:放大
 | 
	
		
			
				|  |  |       * @param zoomSpeed  镜头缩放速度
 | 
	
		
			
				|  |  |  	 */ 
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public boolean ptzZoomCmd(String deviceId, String channelId, int inOut, int zoomSpeed) {
 | 
	
		
			
				|  |  | -		return ptzCmd(deviceId, channelId, 0, 0, inOut, 0, zoomSpeed);
 | 
	
		
			
				|  |  | +	public boolean ptzZoomCmd(Device device, String channelId, int inOut, int zoomSpeed) {
 | 
	
		
			
				|  |  | +		return ptzCmd(device, channelId, 0, 0, inOut, 0, zoomSpeed);
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |    
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 云台控制,支持方向与缩放控制
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  控制设备
 | 
	
		
			
				|  |  | +	 * @param device  控制设备
 | 
	
		
			
				|  |  |  	 * @param channelId  预览通道
 | 
	
		
			
				|  |  |  	 * @param leftRight  镜头左移右移 0:停止 1:左移 2:右移
 | 
	
		
			
				|  |  |       * @param upDown     镜头上移下移 0:停止 1:上移 2:下移
 | 
	
	
		
			
				|  | @@ -102,10 +100,9 @@ public class SIPCommander implements ISIPCommander {
 | 
	
		
			
				|  |  |       * @param zoomSpeed  镜头缩放速度
 | 
	
		
			
				|  |  |  	 */
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public boolean ptzCmd(String deviceId, String channelId, int leftRight, int upDown, int inOut, int moveSpeed,
 | 
	
		
			
				|  |  | +	public boolean ptzCmd(Device device, String channelId, int leftRight, int upDown, int inOut, int moveSpeed,
 | 
	
		
			
				|  |  |  			int zoomSpeed) {
 | 
	
		
			
				|  |  |  		try {
 | 
	
		
			
				|  |  | -			Device device = storager.queryVideoDevice(deviceId);
 | 
	
		
			
				|  |  |  			StringBuffer ptzXml = new StringBuffer(200);
 | 
	
		
			
				|  |  |  			ptzXml.append("<?xml version=\"1.0\" ?>");
 | 
	
		
			
				|  |  |  			ptzXml.append("<Control>");
 | 
	
	
		
			
				|  | @@ -119,7 +116,7 @@ public class SIPCommander implements ISIPCommander {
 | 
	
		
			
				|  |  |  			
 | 
	
		
			
				|  |  |  			Request request = headerProvider.createMessageRequest(device, ptzXml.toString(), "ViaPtzBranch", "FromPtzTag", "ToPtzTag");
 | 
	
		
			
				|  |  |  			
 | 
	
		
			
				|  |  | -			transmitRequest(device.getTransport(), request);
 | 
	
		
			
				|  |  | +			transmitRequest(device, request);
 | 
	
		
			
				|  |  |  			
 | 
	
		
			
				|  |  |  			return true;
 | 
	
		
			
				|  |  |  		} catch (SipException | ParseException | InvalidArgumentException e) {
 | 
	
	
		
			
				|  | @@ -131,15 +128,13 @@ public class SIPCommander implements ISIPCommander {
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 请求预览视频流
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  视频设备
 | 
	
		
			
				|  |  | +	 * @param device  视频设备
 | 
	
		
			
				|  |  |  	 * @param channelId  预览通道
 | 
	
		
			
				|  |  |  	 */  
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public String playStreamCmd(String deviceId, String channelId) {
 | 
	
		
			
				|  |  | +	public String playStreamCmd(Device device, String channelId) {
 | 
	
		
			
				|  |  |  		try {
 | 
	
		
			
				|  |  |  			
 | 
	
		
			
				|  |  | -			Device device = storager.queryVideoDevice(deviceId);
 | 
	
		
			
				|  |  | -			
 | 
	
		
			
				|  |  |  			//生成ssrc标识数据流 10位数字
 | 
	
		
			
				|  |  |  			String ssrc = "";
 | 
	
		
			
				|  |  |  			Random random = new Random();
 | 
	
	
		
			
				|  | @@ -170,7 +165,7 @@ public class SIPCommander implements ISIPCommander {
 | 
	
		
			
				|  |  |  	        
 | 
	
		
			
				|  |  |  	        Request request = headerProvider.createInviteRequest(device, content.toString(), null, "live", null);
 | 
	
		
			
				|  |  |  	
 | 
	
		
			
				|  |  | -	        transmitRequest(device.getTransport(), request);
 | 
	
		
			
				|  |  | +	        transmitRequest(device, request);
 | 
	
		
			
				|  |  |  			return ssrc;
 | 
	
		
			
				|  |  |  		} catch ( SipException | ParseException | InvalidArgumentException e) {
 | 
	
		
			
				|  |  |  			e.printStackTrace();
 | 
	
	
		
			
				|  | @@ -181,81 +176,81 @@ public class SIPCommander implements ISIPCommander {
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 语音广播
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  视频设备
 | 
	
		
			
				|  |  | +	 * @param device  视频设备
 | 
	
		
			
				|  |  |  	 * @param channelId  预览通道
 | 
	
		
			
				|  |  |  	 */
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public String audioBroadcastCmd(String deviceId, String channelId) {
 | 
	
		
			
				|  |  | +	public boolean audioBroadcastCmd(Device device, String channelId) {
 | 
	
		
			
				|  |  |  		// TODO Auto-generated method stub
 | 
	
		
			
				|  |  | -		return null;
 | 
	
		
			
				|  |  | +		return false;
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 音视频录像控制
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  视频设备
 | 
	
		
			
				|  |  | +	 * @param device  视频设备
 | 
	
		
			
				|  |  |  	 * @param channelId  预览通道
 | 
	
		
			
				|  |  |  	 */  
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public String recordCmd(String deviceId, String channelId) {
 | 
	
		
			
				|  |  | +	public boolean recordCmd(Device device, String channelId) {
 | 
	
		
			
				|  |  |  		// TODO Auto-generated method stub
 | 
	
		
			
				|  |  | -		return null;
 | 
	
		
			
				|  |  | +		return false;
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 报警布防/撤防命令
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  视频设备
 | 
	
		
			
				|  |  | +	 * @param device  视频设备
 | 
	
		
			
				|  |  |  	 */  
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public String guardCmd(String deviceId) {
 | 
	
		
			
				|  |  | +	public boolean guardCmd(Device device) {
 | 
	
		
			
				|  |  |  		// TODO Auto-generated method stub
 | 
	
		
			
				|  |  | -		return null;
 | 
	
		
			
				|  |  | +		return false;
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 报警复位命令
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  视频设备
 | 
	
		
			
				|  |  | +	 * @param device  视频设备
 | 
	
		
			
				|  |  |  	 */  
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public String alarmCmd(String deviceId) {
 | 
	
		
			
				|  |  | +	public boolean alarmCmd(Device device) {
 | 
	
		
			
				|  |  |  		// TODO Auto-generated method stub
 | 
	
		
			
				|  |  | -		return null;
 | 
	
		
			
				|  |  | +		return false;
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 强制关键帧命令,设备收到此命令应立刻发送一个IDR帧
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  视频设备
 | 
	
		
			
				|  |  | +	 * @param device  视频设备
 | 
	
		
			
				|  |  |  	 * @param channelId  预览通道
 | 
	
		
			
				|  |  |  	 */ 
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public String iFameCmd(String deviceId, String channelId) {
 | 
	
		
			
				|  |  | +	public boolean iFameCmd(Device device, String channelId) {
 | 
	
		
			
				|  |  |  		// TODO Auto-generated method stub
 | 
	
		
			
				|  |  | -		return null;
 | 
	
		
			
				|  |  | +		return false;
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 看守位控制命令
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  视频设备
 | 
	
		
			
				|  |  | +	 * @param device  视频设备
 | 
	
		
			
				|  |  |  	 */  
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public String homePositionCmd(String deviceId) {
 | 
	
		
			
				|  |  | +	public boolean homePositionCmd(Device device) {
 | 
	
		
			
				|  |  |  		// TODO Auto-generated method stub
 | 
	
		
			
				|  |  | -		return null;
 | 
	
		
			
				|  |  | +		return false;
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	/**
 | 
	
		
			
				|  |  |  	 * 设备配置命令
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  | -	 * @param deviceId  视频设备
 | 
	
		
			
				|  |  | +	 * @param device  视频设备
 | 
	
		
			
				|  |  |  	 */  
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public String deviceConfigCmd(String deviceId) {
 | 
	
		
			
				|  |  | +	public boolean deviceConfigCmd(Device device) {
 | 
	
		
			
				|  |  |  		// TODO Auto-generated method stub
 | 
	
		
			
				|  |  | -		return null;
 | 
	
		
			
				|  |  | +		return false;
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	/**
 | 
	
	
		
			
				|  | @@ -286,8 +281,8 @@ public class SIPCommander implements ISIPCommander {
 | 
	
		
			
				|  |  |  			catalogXml.append("</Query>");
 | 
	
		
			
				|  |  |  			
 | 
	
		
			
				|  |  |  			Request request = headerProvider.createMessageRequest(device, catalogXml.toString(), "ViaDeviceInfoBranch", "FromDeviceInfoTag", "ToDeviceInfoTag");
 | 
	
		
			
				|  |  | +			transmitRequest(device, request);
 | 
	
		
			
				|  |  |  			
 | 
	
		
			
				|  |  | -			transmitRequest(device.getTransport(), request);
 | 
	
		
			
				|  |  |  		} catch (SipException | ParseException | InvalidArgumentException e) {
 | 
	
		
			
				|  |  |  			e.printStackTrace();
 | 
	
		
			
				|  |  |  			return false;
 | 
	
	
		
			
				|  | @@ -312,9 +307,7 @@ public class SIPCommander implements ISIPCommander {
 | 
	
		
			
				|  |  |  			catalogXml.append("</Query>");
 | 
	
		
			
				|  |  |  			
 | 
	
		
			
				|  |  |  			Request request = headerProvider.createMessageRequest(device, catalogXml.toString(), "ViaCatalogBranch", "FromCatalogTag", "ToCatalogTag");
 | 
	
		
			
				|  |  | -			
 | 
	
		
			
				|  |  | -			transmitRequest(device.getTransport(), request);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | +			transmitRequest(device, request);
 | 
	
		
			
				|  |  |  		} catch (SipException | ParseException | InvalidArgumentException e) {
 | 
	
		
			
				|  |  |  			e.printStackTrace();
 | 
	
		
			
				|  |  |  			return false;
 | 
	
	
		
			
				|  | @@ -326,11 +319,32 @@ public class SIPCommander implements ISIPCommander {
 | 
	
		
			
				|  |  |  	 * 查询录像信息
 | 
	
		
			
				|  |  |  	 * 
 | 
	
		
			
				|  |  |  	 * @param device 视频设备
 | 
	
		
			
				|  |  | +	 * @param startTime 开始时间,格式要求:yyyy-MM-dd HH:mm:ss
 | 
	
		
			
				|  |  | +	 * @param endTime 结束时间,格式要求:yyyy-MM-dd HH:mm:ss
 | 
	
		
			
				|  |  |  	 */  
 | 
	
		
			
				|  |  |  	@Override
 | 
	
		
			
				|  |  | -	public boolean recordInfoQuery(Device device) {
 | 
	
		
			
				|  |  | -		// TODO Auto-generated method stub
 | 
	
		
			
				|  |  | -		return false;
 | 
	
		
			
				|  |  | +	public boolean recordInfoQuery(Device device, String startTime, String endTime) {
 | 
	
		
			
				|  |  | +		
 | 
	
		
			
				|  |  | +		try {
 | 
	
		
			
				|  |  | +			StringBuffer catalogXml = new StringBuffer(200);
 | 
	
		
			
				|  |  | +			catalogXml.append("<?xml version=\"1.0\" encoding=\"GB2312\"?>");
 | 
	
		
			
				|  |  | +			catalogXml.append("<Query>");
 | 
	
		
			
				|  |  | +			catalogXml.append("<CmdType>RecordInfo</CmdType>");
 | 
	
		
			
				|  |  | +			catalogXml.append("<SN>" + (int)((Math.random()*9+1)*100000) + "</SN>");
 | 
	
		
			
				|  |  | +			catalogXml.append("<DeviceID>" + device.getDeviceId() + "</DeviceID>");
 | 
	
		
			
				|  |  | +			catalogXml.append("<StartTime>" + DateUtil.yyyy_MM_dd_HH_mm_ssToISO8601(startTime) + "</StartTime>");
 | 
	
		
			
				|  |  | +			catalogXml.append("<EndTime>" + DateUtil.yyyy_MM_dd_HH_mm_ssToISO8601(endTime) + "</EndTime>");
 | 
	
		
			
				|  |  | +			// 大华NVR要求必须增加一个值为all的文本元素节点Type
 | 
	
		
			
				|  |  | +			catalogXml.append("<Type>all</Type>");
 | 
	
		
			
				|  |  | +			catalogXml.append("</Query>");
 | 
	
		
			
				|  |  | +			
 | 
	
		
			
				|  |  | +			Request request = headerProvider.createMessageRequest(device, catalogXml.toString(), "ViaRecordInfoBranch", "FromRecordInfoTag", "ToRecordInfoTag");
 | 
	
		
			
				|  |  | +			transmitRequest(device, request);
 | 
	
		
			
				|  |  | +		} catch (SipException | ParseException | InvalidArgumentException e) {
 | 
	
		
			
				|  |  | +			e.printStackTrace();
 | 
	
		
			
				|  |  | +			return false;
 | 
	
		
			
				|  |  | +		}
 | 
	
		
			
				|  |  | +		return true;
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  	/**
 | 
	
	
		
			
				|  | @@ -377,10 +391,10 @@ public class SIPCommander implements ISIPCommander {
 | 
	
		
			
				|  |  |  		return false;
 | 
	
		
			
				|  |  |  	}
 | 
	
		
			
				|  |  |  	
 | 
	
		
			
				|  |  | -	private void transmitRequest(String transport, Request request) throws SipException {
 | 
	
		
			
				|  |  | -		if(transport.equals("TCP")) {
 | 
	
		
			
				|  |  | +	private void transmitRequest(Device device, Request request) throws SipException {
 | 
	
		
			
				|  |  | +		if(device.getTransport().equals("TCP")) {
 | 
	
		
			
				|  |  |  			sipLayer.getTcpSipProvider().sendRequest(request);
 | 
	
		
			
				|  |  | -		} else if(transport.equals("UDP")) {
 | 
	
		
			
				|  |  | +		} else if(device.getTransport().equals("UDP")) {
 | 
	
		
			
				|  |  |  			sipLayer.getUdpSipProvider().sendRequest(request);
 | 
	
		
			
				|  |  |  		}
 | 
	
		
			
				|  |  |  	}
 |