|
|
@@ -3,7 +3,6 @@ package com.genersoft.iot.vmp.gb28181.transmit.event.request.impl;
|
|
|
import com.genersoft.iot.vmp.common.VideoManagerConstants;
|
|
|
import com.genersoft.iot.vmp.conf.SipConfig;
|
|
|
import com.genersoft.iot.vmp.gb28181.auth.DigestServerAuthenticationHelper;
|
|
|
-import com.genersoft.iot.vmp.gb28181.auth.RegisterLogicHandler;
|
|
|
import com.genersoft.iot.vmp.gb28181.bean.Device;
|
|
|
import com.genersoft.iot.vmp.gb28181.bean.WvpSipDate;
|
|
|
import com.genersoft.iot.vmp.gb28181.event.EventPublisher;
|
|
|
@@ -42,166 +41,157 @@ import java.util.Locale;
|
|
|
@Component
|
|
|
public class RegisterRequestProcessor extends SIPRequestProcessorParent implements InitializingBean, ISIPRequestProcessor {
|
|
|
|
|
|
- private Logger logger = LoggerFactory.getLogger(RegisterRequestProcessor.class);
|
|
|
-
|
|
|
- public String method = "REGISTER";
|
|
|
-
|
|
|
- @Autowired
|
|
|
- private SipConfig sipConfig;
|
|
|
-
|
|
|
- @Autowired
|
|
|
- private RegisterLogicHandler handler;
|
|
|
-
|
|
|
- @Autowired
|
|
|
- private IRedisCatchStorage redisCatchStorage;
|
|
|
-
|
|
|
- @Autowired
|
|
|
- private IVideoManagerStorage storager;
|
|
|
-
|
|
|
- @Autowired
|
|
|
- private EventPublisher publisher;
|
|
|
-
|
|
|
- @Autowired
|
|
|
- private SIPProcessorObserver sipProcessorObserver;
|
|
|
-
|
|
|
- @Override
|
|
|
- public void afterPropertiesSet() throws Exception {
|
|
|
- // 添加消息处理的订阅
|
|
|
- sipProcessorObserver.addRequestProcessor(method, this);
|
|
|
- }
|
|
|
-
|
|
|
- /**
|
|
|
- * 收到注册请求 处理
|
|
|
- * @param evt
|
|
|
- */
|
|
|
- @Override
|
|
|
- public void process(RequestEvent evt) {
|
|
|
- try {
|
|
|
- RequestEventExt evtExt = (RequestEventExt)evt;
|
|
|
- String requestAddress = evtExt.getRemoteIpAddress() + ":" + evtExt.getRemotePort();
|
|
|
- logger.info("[{}] 收到注册请求,开始处理", requestAddress);
|
|
|
- Request request = evt.getRequest();
|
|
|
- ExpiresHeader expiresHeader = (ExpiresHeader) request.getHeader(Expires.NAME);
|
|
|
- Response response = null;
|
|
|
- boolean passwordCorrect = false;
|
|
|
- // 注册标志 0:未携带授权头或者密码错误 1:注册成功 2:注销成功
|
|
|
- int registerFlag = 0;
|
|
|
- FromHeader fromHeader = (FromHeader) request.getHeader(FromHeader.NAME);
|
|
|
- AddressImpl address = (AddressImpl) fromHeader.getAddress();
|
|
|
- SipUri uri = (SipUri) address.getURI();
|
|
|
- String deviceId = uri.getUser();
|
|
|
- Device deviceInRedis = redisCatchStorage.getDevice(deviceId);
|
|
|
- Device device = storager.queryVideoDevice(deviceId);
|
|
|
- if (deviceInRedis != null && device == null) {
|
|
|
- // redis 存在脏数据
|
|
|
- redisCatchStorage.clearCatchByDeviceId(deviceId);
|
|
|
- }
|
|
|
- AuthorizationHeader authorhead = (AuthorizationHeader) request.getHeader(AuthorizationHeader.NAME);
|
|
|
- // 校验密码是否正确
|
|
|
- if (authorhead != null) {
|
|
|
- passwordCorrect = new DigestServerAuthenticationHelper().doAuthenticatePlainTextPassword(request,
|
|
|
- sipConfig.getPassword());
|
|
|
- }
|
|
|
- if (StringUtils.isEmpty(sipConfig.getPassword())){
|
|
|
- passwordCorrect = true;
|
|
|
- }
|
|
|
-
|
|
|
- // 未携带授权头或者密码错误 回复401
|
|
|
- if (authorhead == null ) {
|
|
|
-
|
|
|
- logger.info("[{}] 未携带授权头 回复401", requestAddress);
|
|
|
- response = getMessageFactory().createResponse(Response.UNAUTHORIZED, request);
|
|
|
- new DigestServerAuthenticationHelper().generateChallenge(getHeaderFactory(), response, sipConfig.getDomain());
|
|
|
- }else {
|
|
|
- if (!passwordCorrect){
|
|
|
- // 注册失败
|
|
|
- response = getMessageFactory().createResponse(Response.FORBIDDEN, request);
|
|
|
- response.setReasonPhrase("wrong password");
|
|
|
- logger.info("[{}] 密码/SIP服务器ID错误, 回复403", requestAddress);
|
|
|
- }else {
|
|
|
- // 携带授权头并且密码正确
|
|
|
- response = getMessageFactory().createResponse(Response.OK, request);
|
|
|
- // 添加date头
|
|
|
- SIPDateHeader dateHeader = new SIPDateHeader();
|
|
|
- // 使用自己修改的
|
|
|
- WvpSipDate wvpSipDate = new WvpSipDate(Calendar.getInstance(Locale.ENGLISH).getTimeInMillis());
|
|
|
- dateHeader.setDate(wvpSipDate);
|
|
|
- response.addHeader(dateHeader);
|
|
|
-
|
|
|
-
|
|
|
- if (expiresHeader == null) {
|
|
|
- response = getMessageFactory().createResponse(Response.BAD_REQUEST, request);
|
|
|
- ServerTransaction serverTransaction = getServerTransaction(evt);
|
|
|
- serverTransaction.sendResponse(response);
|
|
|
- if (serverTransaction.getDialog() != null) serverTransaction.getDialog().delete();
|
|
|
- return;
|
|
|
- }
|
|
|
- // 添加Contact头
|
|
|
- response.addHeader(request.getHeader(ContactHeader.NAME));
|
|
|
- // 添加Expires头
|
|
|
- response.addHeader(request.getExpires());
|
|
|
-
|
|
|
- // 获取到通信地址等信息
|
|
|
- ViaHeader viaHeader = (ViaHeader) request.getHeader(ViaHeader.NAME);
|
|
|
- String received = viaHeader.getReceived();
|
|
|
- int rPort = viaHeader.getRPort();
|
|
|
- // 解析本地地址替代
|
|
|
- if (StringUtils.isEmpty(received) || rPort == -1) {
|
|
|
- received = viaHeader.getHost();
|
|
|
- rPort = viaHeader.getPort();
|
|
|
- }
|
|
|
- //
|
|
|
-
|
|
|
- if (device == null) {
|
|
|
- device = new Device();
|
|
|
- device.setStreamMode("UDP");
|
|
|
- device.setCharset("GB2312");
|
|
|
- device.setDeviceId(deviceId);
|
|
|
- device.setFirsRegister(true);
|
|
|
- }else {
|
|
|
- if (device.getOnline() == 0) {
|
|
|
- device.setFirsRegister(true);
|
|
|
- }
|
|
|
- }
|
|
|
- device.setIp(received);
|
|
|
- device.setPort(rPort);
|
|
|
- device.setHostAddress(received.concat(":").concat(String.valueOf(rPort)));
|
|
|
- // 注销成功
|
|
|
- if (expiresHeader.getExpires() == 0) {
|
|
|
- registerFlag = 2;
|
|
|
- }
|
|
|
- // 注册成功
|
|
|
- else {
|
|
|
- device.setExpires(expiresHeader.getExpires());
|
|
|
- registerFlag = 1;
|
|
|
- // 判断TCP还是UDP
|
|
|
- boolean isTcp = false;
|
|
|
- ViaHeader reqViaHeader = (ViaHeader) request.getHeader(ViaHeader.NAME);
|
|
|
- String transport = reqViaHeader.getTransport();
|
|
|
- if (transport.equals("TCP")) {
|
|
|
- isTcp = true;
|
|
|
- }
|
|
|
- device.setTransport(isTcp ? "TCP" : "UDP");
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- ServerTransaction serverTransaction = getServerTransaction(evt);
|
|
|
- serverTransaction.sendResponse(response);
|
|
|
- if (serverTransaction.getDialog() != null) serverTransaction.getDialog().delete();
|
|
|
- // 注册成功
|
|
|
- // 保存到redis
|
|
|
- if (registerFlag == 1 ) {
|
|
|
- logger.info("[{}] 注册成功! deviceId:" + device.getDeviceId(), requestAddress);
|
|
|
- publisher.onlineEventPublish(device, VideoManagerConstants.EVENT_ONLINE_REGISTER, expiresHeader.getExpires());
|
|
|
- } else if (registerFlag == 2) {
|
|
|
- logger.info("[{}] 注销成功! deviceId:" + device.getDeviceId(), requestAddress);
|
|
|
- publisher.outlineEventPublish(device.getDeviceId(), VideoManagerConstants.EVENT_OUTLINE_UNREGISTER);
|
|
|
- }
|
|
|
- } catch (SipException | InvalidArgumentException | NoSuchAlgorithmException | ParseException e) {
|
|
|
- e.printStackTrace();
|
|
|
- }
|
|
|
-
|
|
|
- }
|
|
|
+ private final Logger logger = LoggerFactory.getLogger(RegisterRequestProcessor.class);
|
|
|
+
|
|
|
+ public String method = "REGISTER";
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private SipConfig sipConfig;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IRedisCatchStorage redisCatchStorage;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IVideoManagerStorage storager;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private EventPublisher publisher;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private SIPProcessorObserver sipProcessorObserver;
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void afterPropertiesSet() throws Exception {
|
|
|
+ // 添加消息处理的订阅
|
|
|
+ sipProcessorObserver.addRequestProcessor(method, this);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 收到注册请求 处理
|
|
|
+ *
|
|
|
+ * @param evt
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ public void process(RequestEvent evt) {
|
|
|
+ try {
|
|
|
+ RequestEventExt evtExt = (RequestEventExt) evt;
|
|
|
+ String requestAddress = evtExt.getRemoteIpAddress() + ":" + evtExt.getRemotePort();
|
|
|
+ logger.info("[{}] 收到注册请求,开始处理", requestAddress);
|
|
|
+ Request request = evt.getRequest();
|
|
|
+ ExpiresHeader expiresHeader = (ExpiresHeader) request.getHeader(Expires.NAME);
|
|
|
+ Response response = null;
|
|
|
+ boolean passwordCorrect = false;
|
|
|
+ // 注册标志 0:未携带授权头或者密码错误 1:注册成功 2:注销成功
|
|
|
+ int registerFlag = 0;
|
|
|
+ FromHeader fromHeader = (FromHeader) request.getHeader(FromHeader.NAME);
|
|
|
+ AddressImpl address = (AddressImpl) fromHeader.getAddress();
|
|
|
+ SipUri uri = (SipUri) address.getURI();
|
|
|
+ String deviceId = uri.getUser();
|
|
|
+
|
|
|
+ AuthorizationHeader authHead = (AuthorizationHeader) request.getHeader(AuthorizationHeader.NAME);
|
|
|
+ if (authHead == null) {
|
|
|
+ logger.info("[{}] 未携带授权头 回复401", requestAddress);
|
|
|
+ response = getMessageFactory().createResponse(Response.UNAUTHORIZED, request);
|
|
|
+ new DigestServerAuthenticationHelper().generateChallenge(getHeaderFactory(), response, sipConfig.getDomain());
|
|
|
+ sendResponse(evt, response);
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ // 校验密码是否正确
|
|
|
+ passwordCorrect = StringUtils.isEmpty(sipConfig.getPassword()) ||
|
|
|
+ new DigestServerAuthenticationHelper().doAuthenticatePlainTextPassword(request, sipConfig.getPassword());
|
|
|
+ // 未携带授权头或者密码错误 回复401
|
|
|
+
|
|
|
+ if (!passwordCorrect) {
|
|
|
+ // 注册失败
|
|
|
+ response = getMessageFactory().createResponse(Response.FORBIDDEN, request);
|
|
|
+ response.setReasonPhrase("wrong password");
|
|
|
+ logger.info("[{}] 密码/SIP服务器ID错误, 回复403", requestAddress);
|
|
|
+ sendResponse(evt, response);
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ Device deviceInRedis = redisCatchStorage.getDevice(deviceId);
|
|
|
+ Device device = storager.queryVideoDevice(deviceId);
|
|
|
+ if (deviceInRedis != null && device == null) {
|
|
|
+ // redis 存在脏数据
|
|
|
+ redisCatchStorage.clearCatchByDeviceId(deviceId);
|
|
|
+ }
|
|
|
+ // 携带授权头并且密码正确
|
|
|
+ response = getMessageFactory().createResponse(Response.OK, request);
|
|
|
+ // 添加date头
|
|
|
+ SIPDateHeader dateHeader = new SIPDateHeader();
|
|
|
+ // 使用自己修改的
|
|
|
+ WvpSipDate wvpSipDate = new WvpSipDate(Calendar.getInstance(Locale.ENGLISH).getTimeInMillis());
|
|
|
+ dateHeader.setDate(wvpSipDate);
|
|
|
+ response.addHeader(dateHeader);
|
|
|
+
|
|
|
+ if (expiresHeader == null) {
|
|
|
+ response = getMessageFactory().createResponse(Response.BAD_REQUEST, request);
|
|
|
+ ServerTransaction serverTransaction = getServerTransaction(evt);
|
|
|
+ serverTransaction.sendResponse(response);
|
|
|
+ if (serverTransaction.getDialog() != null) serverTransaction.getDialog().delete();
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ // 添加Contact头
|
|
|
+ response.addHeader(request.getHeader(ContactHeader.NAME));
|
|
|
+ // 添加Expires头
|
|
|
+ response.addHeader(request.getExpires());
|
|
|
+
|
|
|
+ // 获取到通信地址等信息
|
|
|
+ ViaHeader viaHeader = (ViaHeader) request.getHeader(ViaHeader.NAME);
|
|
|
+ String received = viaHeader.getReceived();
|
|
|
+ int rPort = viaHeader.getRPort();
|
|
|
+ // 解析本地地址替代
|
|
|
+ if (StringUtils.isEmpty(received) || rPort == -1) {
|
|
|
+ received = viaHeader.getHost();
|
|
|
+ rPort = viaHeader.getPort();
|
|
|
+ }
|
|
|
+ if (device == null) {
|
|
|
+ device = new Device();
|
|
|
+ device.setStreamMode("UDP");
|
|
|
+ device.setCharset("GB2312");
|
|
|
+ device.setDeviceId(deviceId);
|
|
|
+ device.setFirsRegister(true);
|
|
|
+ } else {
|
|
|
+ device.setFirsRegister(device.getOnline() == 0);
|
|
|
+ }
|
|
|
+ device.setIp(received);
|
|
|
+ device.setPort(rPort);
|
|
|
+ device.setHostAddress(received.concat(":").concat(String.valueOf(rPort)));
|
|
|
+ if (expiresHeader.getExpires() == 0) {
|
|
|
+ // 注销成功
|
|
|
+ registerFlag = 2;
|
|
|
+ } else {
|
|
|
+ // 注册成功
|
|
|
+ device.setExpires(expiresHeader.getExpires());
|
|
|
+ registerFlag = 1;
|
|
|
+ // 判断TCP还是UDP
|
|
|
+ ViaHeader reqViaHeader = (ViaHeader) request.getHeader(ViaHeader.NAME);
|
|
|
+ String transport = reqViaHeader.getTransport();
|
|
|
+ device.setTransport("TCP".equals(transport) ? "TCP" : "UDP");
|
|
|
+ }
|
|
|
+
|
|
|
+ sendResponse(evt, response);
|
|
|
+ // 注册成功
|
|
|
+ // 保存到redis
|
|
|
+ if (registerFlag == 1) {
|
|
|
+ logger.info("[{}] 注册成功! deviceId:" + deviceId, requestAddress);
|
|
|
+ publisher.onlineEventPublish(device, VideoManagerConstants.EVENT_ONLINE_REGISTER, expiresHeader.getExpires());
|
|
|
+ } else if (registerFlag == 2) {
|
|
|
+ logger.info("[{}] 注销成功! deviceId:" + deviceId, requestAddress);
|
|
|
+ publisher.outlineEventPublish(deviceId, VideoManagerConstants.EVENT_OUTLINE_UNREGISTER);
|
|
|
+ }
|
|
|
+ } catch (SipException | InvalidArgumentException | NoSuchAlgorithmException | ParseException e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ private void sendResponse(RequestEvent evt, Response response) throws InvalidArgumentException, SipException {
|
|
|
+ ServerTransaction serverTransaction = getServerTransaction(evt);
|
|
|
+ serverTransaction.sendResponse(response);
|
|
|
+ if (serverTransaction.getDialog() != null) serverTransaction.getDialog().delete();
|
|
|
+ }
|
|
|
|
|
|
}
|