skip crearte/device logic for now

This commit is contained in:
Michael Zanetti 2017-10-05 10:38:12 +02:00
parent a2cffbc5fc
commit 94c2b90e4a
3 changed files with 34 additions and 22 deletions

View File

@ -45,6 +45,10 @@ AWSConnector::~AWSConnector()
void AWSConnector::connect2AWS(const QString &endpoint, const QString &clientId, const QString &clientName, const QString &caFile, const QString &clientCertFile, const QString &clientPrivKeyFile)
{
m_currentEndpoint = endpoint;
m_caFile = caFile;
m_clientCertFile = clientCertFile;
m_clientPrivKeyFile = clientPrivKeyFile;
m_reconnect = true;
m_networkConnection = std::shared_ptr<MbedTLSConnection>(new MbedTLSConnection(
endpoint.toStdString(),
@ -61,8 +65,20 @@ void AWSConnector::connect2AWS(const QString &endpoint, const QString &clientId,
m_clientId = clientId;
m_clientName = clientName;
qCDebug(dcAWS()) << "Connecting to AWS with ID:" << m_clientId << "endpoint:" << endpoint;
doConnect();
m_client->SetAutoReconnectEnabled(true);
m_client->SetMaxReconnectBackoffTimeout(std::chrono::seconds(10));
qCDebug(dcAWS()) << "Connecting to AWS with ID:" << m_clientId << "endpoint:" << endpoint << m_client->GetMinReconnectBackoffTimeout().count() << (quint32)m_client->GetMaxReconnectBackoffTimeout().count();
m_connectingFuture = QtConcurrent::run([&]() {
ResponseCode rc = m_client->Connect(std::chrono::milliseconds(30000), true, mqtt::Version::MQTT_3_1_1, std::chrono::seconds(60), Utf8String::Create(m_clientId.toStdString()), nullptr, nullptr, nullptr);
if (rc == ResponseCode::MQTT_CONNACK_CONNECTION_ACCEPTED) {
emit connected();
} else {
qCWarning(dcAWS) << "Error connecting to AWS. Response code:" << QString::fromStdString(ResponseHelper::ToString(rc));
m_client.reset();
m_networkConnection.reset();
}
});
}
DisconnectCallbackContextData::~DisconnectCallbackContextData() {}
@ -114,31 +130,22 @@ quint16 AWSConnector::publish(const QString &topic, const QVariantMap &message)
return packetId;
}
void AWSConnector::doConnect()
{
qCDebug(dcAWS()) << "(re)connecting...";
m_connectingFuture = QtConcurrent::run([&]() {
ResponseCode rc = m_client->Connect(std::chrono::milliseconds(30000), true, mqtt::Version::MQTT_3_1_1, std::chrono::seconds(60), Utf8String::Create(m_clientId.toStdString()), nullptr, nullptr, nullptr);
if (rc == ResponseCode::MQTT_CONNACK_CONNECTION_ACCEPTED) {
emit connected();
} else {
qCWarning(dcAWS) << "Error connecting to AWS. Response code:" << QString::fromStdString(ResponseHelper::ToString(rc));
}
});
}
void AWSConnector::onConnected()
{
qCDebug(dcAWS()) << "AWS connected";
m_client->SetAutoReconnectEnabled(true);
registerDevice();
// TODO: remove this again. just using this for testing now to skip the registerDevice step
retrievePairedDeviceInfo();
}
void AWSConnector::onDisconnected()
{
qCDebug(dcAWS()) << "AWS disconnected.";
if (m_reconnect) {
QTimer::singleShot(10000, this, &AWSConnector::doConnect);
m_client->Disconnect(std::chrono::milliseconds(1000));
// m_networkConnection->Connect();
connect2AWS(m_currentEndpoint, m_clientId, m_clientName, m_caFile, m_clientCertFile, m_clientPrivKeyFile);
}
}
@ -302,8 +309,11 @@ ResponseCode AWSConnector::onSubscriptionReceivedCallback(util::String topic_nam
ResponseCode AWSConnector::onDisconnectedCallback(util::String mqtt_client_id, std::shared_ptr<DisconnectCallbackContextData> p_app_handler_data)
{
qCDebug(dcAWS()) << "disconnected" << QString::fromStdString(mqtt_client_id) << p_app_handler_data.get();
// AWSConnector* connector = dynamic_cast<AWSConnector*>(p_app_handler_data.get());
// emit connector->disconnected();
Q_UNUSED(p_app_handler_data)
AWSConnector* connector = dynamic_cast<AWSConnector*>(p_app_handler_data.get());
qWarning() << connector->m_client->IsAutoReconnectEnabled();
qCDebug(dcAWS()) << "disconnected" << QString::fromStdString(mqtt_client_id) << connector << p_app_handler_data.get();
emit connector->disconnected();
return ResponseCode::SUCCESS;
}

View File

@ -50,7 +50,6 @@ signals:
void webRtcHandshakeMessageReceived(const QString &transactionId, const QVariantMap &data);
private slots:
void doConnect();
void onConnected();
void onDisconnected();
void retrievePairedDeviceInfo();
@ -71,6 +70,10 @@ private:
std::shared_ptr<awsiotsdk::network::MbedTLSConnection> m_networkConnection;
std::shared_ptr<awsiotsdk::MqttClient> m_client;
bool m_reconnect = false;
QString m_currentEndpoint;
QString m_caFile;
QString m_clientCertFile;
QString m_clientPrivKeyFile;
QString m_clientId;
QString m_clientName;

View File

@ -122,7 +122,6 @@ void CloudManager::connect2aws()
void CloudManager::onlineStateChanged()
{
qWarning() << "online state changed" << m_networkManager->state();
if (m_networkManager->state() == NetworkManager::NetworkManagerStateConnectedGlobal) {
if (m_enabled && !m_awsConnector->isConnected()) {
connect2aws();