TB-41: Improvements
This commit is contained in:
parent
a2d4a759ef
commit
162101c9b7
@ -1,36 +0,0 @@
|
|||||||
/**
|
|
||||||
* Copyright © 2016-2017 The Thingsboard Authors
|
|
||||||
*
|
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
* you may not use this file except in compliance with the License.
|
|
||||||
* You may obtain a copy of the License at
|
|
||||||
*
|
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
*
|
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
* See the License for the specific language governing permissions and
|
|
||||||
* limitations under the License.
|
|
||||||
*/
|
|
||||||
package org.thingsboard.server.transport.mqtt.adaptors;
|
|
||||||
|
|
||||||
import io.netty.handler.codec.mqtt.MqttMessage;
|
|
||||||
import org.thingsboard.server.common.msg.session.AdaptorToSessionActorMsg;
|
|
||||||
import org.thingsboard.server.common.msg.session.MsgType;
|
|
||||||
import org.thingsboard.server.common.msg.session.SessionActorToAdaptorMsg;
|
|
||||||
import org.thingsboard.server.common.transport.adaptor.AdaptorException;
|
|
||||||
import org.thingsboard.server.transport.mqtt.session.GatewaySessionCtx;
|
|
||||||
|
|
||||||
import java.util.Optional;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Created by ashvayka on 19.01.17.
|
|
||||||
*/
|
|
||||||
public interface MqttGatewayAdaptor {
|
|
||||||
|
|
||||||
AdaptorToSessionActorMsg convertToActorMsg(GatewaySessionCtx ctx, MsgType type, MqttMessage inbound) throws AdaptorException;
|
|
||||||
|
|
||||||
Optional<MqttMessage> convertToAdaptorMsg(GatewaySessionCtx ctx, SessionActorToAdaptorMsg msg) throws AdaptorException;
|
|
||||||
|
|
||||||
}
|
|
||||||
@ -1,12 +1,12 @@
|
|||||||
/**
|
/**
|
||||||
* Copyright © 2016-2017 The Thingsboard Authors
|
* Copyright © 2016-2017 The Thingsboard Authors
|
||||||
*
|
* <p>
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
* You may obtain a copy of the License at
|
* You may obtain a copy of the License at
|
||||||
*
|
* <p>
|
||||||
* http://www.apache.org/licenses/LICENSE-2.0
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
*
|
* <p>
|
||||||
* Unless required by applicable law or agreed to in writing, software
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
@ -26,10 +26,8 @@ import org.springframework.util.StringUtils;
|
|||||||
import org.thingsboard.server.common.data.Device;
|
import org.thingsboard.server.common.data.Device;
|
||||||
import org.thingsboard.server.common.data.id.SessionId;
|
import org.thingsboard.server.common.data.id.SessionId;
|
||||||
import org.thingsboard.server.common.data.kv.BaseAttributeKvEntry;
|
import org.thingsboard.server.common.data.kv.BaseAttributeKvEntry;
|
||||||
import org.thingsboard.server.common.msg.core.BasicTelemetryUploadRequest;
|
import org.thingsboard.server.common.msg.core.*;
|
||||||
import org.thingsboard.server.common.msg.core.BasicUpdateAttributesRequest;
|
import org.thingsboard.server.common.msg.session.AdaptorToSessionActorMsg;
|
||||||
import org.thingsboard.server.common.msg.core.TelemetryUploadRequest;
|
|
||||||
import org.thingsboard.server.common.msg.core.ToDeviceRpcResponseMsg;
|
|
||||||
import org.thingsboard.server.common.msg.session.BasicAdaptorToSessionActorMsg;
|
import org.thingsboard.server.common.msg.session.BasicAdaptorToSessionActorMsg;
|
||||||
import org.thingsboard.server.common.msg.session.BasicToDeviceActorSessionMsg;
|
import org.thingsboard.server.common.msg.session.BasicToDeviceActorSessionMsg;
|
||||||
import org.thingsboard.server.common.msg.session.FromDeviceMsg;
|
import org.thingsboard.server.common.msg.session.FromDeviceMsg;
|
||||||
@ -38,6 +36,7 @@ import org.thingsboard.server.common.transport.SessionMsgProcessor;
|
|||||||
import org.thingsboard.server.common.transport.adaptor.AdaptorException;
|
import org.thingsboard.server.common.transport.adaptor.AdaptorException;
|
||||||
import org.thingsboard.server.common.transport.adaptor.JsonConverter;
|
import org.thingsboard.server.common.transport.adaptor.JsonConverter;
|
||||||
import org.thingsboard.server.common.transport.auth.DeviceAuthService;
|
import org.thingsboard.server.common.transport.auth.DeviceAuthService;
|
||||||
|
import org.thingsboard.server.common.transport.session.DeviceAwareSessionContext;
|
||||||
import org.thingsboard.server.dao.device.DeviceService;
|
import org.thingsboard.server.dao.device.DeviceService;
|
||||||
import org.thingsboard.server.transport.mqtt.MqttTopics;
|
import org.thingsboard.server.transport.mqtt.MqttTopics;
|
||||||
import org.thingsboard.server.transport.mqtt.MqttTransportHandler;
|
import org.thingsboard.server.transport.mqtt.MqttTransportHandler;
|
||||||
@ -49,6 +48,7 @@ import java.util.Map;
|
|||||||
import java.util.Optional;
|
import java.util.Optional;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
|
|
||||||
|
import static org.thingsboard.server.common.msg.session.MsgType.SUBSCRIBE_ATTRIBUTES_REQUEST;
|
||||||
import static org.thingsboard.server.transport.mqtt.adaptors.JsonMqttAdaptor.validateJsonPayload;
|
import static org.thingsboard.server.transport.mqtt.adaptors.JsonMqttAdaptor.validateJsonPayload;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -83,7 +83,10 @@ public class GatewaySessionCtx {
|
|||||||
newDevice.setName(deviceName);
|
newDevice.setName(deviceName);
|
||||||
return deviceService.saveDevice(newDevice);
|
return deviceService.saveDevice(newDevice);
|
||||||
});
|
});
|
||||||
devices.put(deviceName, new GatewayDeviceSessionCtx(this, device));
|
GatewayDeviceSessionCtx ctx = new GatewayDeviceSessionCtx(this, device);
|
||||||
|
devices.put(deviceName, ctx);
|
||||||
|
processor.process(new BasicToDeviceActorSessionMsg(device, new BasicAdaptorToSessionActorMsg(ctx, new AttributesSubscribeMsg())));
|
||||||
|
processor.process(new BasicToDeviceActorSessionMsg(device, new BasicAdaptorToSessionActorMsg(ctx, new RpcSubscribeMsg())));
|
||||||
ack(msg);
|
ack(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user