mirror of
https://github.com/emsesp/EMS-ESP32.git
synced 2025-12-08 16:59:50 +03:00
124 lines
3.2 KiB
C++
124 lines
3.2 KiB
C++
/*
|
|
Copyright (c) 2022 Bert Melis. All rights reserved.
|
|
|
|
This work is licensed under the terms of the MIT license.
|
|
For a copy, see <https://opensource.org/licenses/MIT> or
|
|
the LICENSE file.
|
|
*/
|
|
|
|
#include "espMqttClient.h"
|
|
|
|
#if defined(ARDUINO_ARCH_ESP8266)
|
|
espMqttClient::espMqttClient()
|
|
: MqttClientSetup(espMqttClientTypes::UseInternalTask::NO)
|
|
, _client() {
|
|
_transport = &_client;
|
|
}
|
|
|
|
espMqttClientSecure::espMqttClientSecure()
|
|
: MqttClientSetup(espMqttClientTypes::UseInternalTask::NO)
|
|
, _client() {
|
|
_transport = &_client;
|
|
}
|
|
|
|
espMqttClientSecure& espMqttClientSecure::setInsecure() {
|
|
_client.client.setInsecure();
|
|
return *this;
|
|
}
|
|
|
|
espMqttClientSecure& espMqttClientSecure::setFingerprint(const uint8_t fingerprint[20]) {
|
|
_client.client.setFingerprint(fingerprint);
|
|
return *this;
|
|
}
|
|
|
|
espMqttClientSecure& espMqttClientSecure::setTrustAnchors(const X509List *ta) {
|
|
_client.client.setTrustAnchors(ta);
|
|
return *this;
|
|
}
|
|
|
|
espMqttClientSecure& espMqttClientSecure::setClientRSACert(const X509List *cert, const PrivateKey *sk) {
|
|
_client.client.setClientRSACert(cert, sk);
|
|
return *this;
|
|
}
|
|
|
|
espMqttClientSecure& espMqttClientSecure::setClientECCert(const X509List *cert, const PrivateKey *sk, unsigned allowed_usages, unsigned cert_issuer_key_type) {
|
|
_client.client.setClientECCert(cert, sk, allowed_usages, cert_issuer_key_type);
|
|
return *this;
|
|
}
|
|
|
|
espMqttClientSecure& espMqttClientSecure::setCertStore(CertStoreBase *certStore) {
|
|
_client.client.setCertStore(certStore);
|
|
return *this;
|
|
}
|
|
#endif
|
|
|
|
#if defined(ARDUINO_ARCH_ESP32)
|
|
espMqttClient::espMqttClient(espMqttClientTypes::UseInternalTask useInternalTask)
|
|
: MqttClientSetup(useInternalTask)
|
|
, _client() {
|
|
_transport = &_client;
|
|
}
|
|
|
|
espMqttClient::espMqttClient(uint8_t priority, uint8_t core)
|
|
: MqttClientSetup(espMqttClientTypes::UseInternalTask::YES, priority, core)
|
|
, _client() {
|
|
_transport = &_client;
|
|
}
|
|
|
|
espMqttClientSecure::espMqttClientSecure(espMqttClientTypes::UseInternalTask useInternalTask)
|
|
: MqttClientSetup(useInternalTask)
|
|
, _client() {
|
|
_transport = &_client;
|
|
}
|
|
|
|
espMqttClientSecure::espMqttClientSecure(uint8_t priority, uint8_t core)
|
|
: MqttClientSetup(espMqttClientTypes::UseInternalTask::YES, priority, core)
|
|
, _client() {
|
|
_transport = &_client;
|
|
}
|
|
|
|
espMqttClientSecure& espMqttClientSecure::setInsecure() {
|
|
#if defined(EMC_CLIENT_SECURE)
|
|
_client.client.setInsecure();
|
|
#endif
|
|
return *this;
|
|
}
|
|
|
|
espMqttClientSecure& espMqttClientSecure::setCACert(const char* rootCA) {
|
|
#if defined(EMC_CLIENT_SECURE)
|
|
_client.client.setCACert(rootCA);
|
|
#endif
|
|
return *this;
|
|
}
|
|
|
|
espMqttClientSecure& espMqttClientSecure::setCertificate(const char* clientCa) {
|
|
#if defined(EMC_CLIENT_SECURE)
|
|
_client.client.setCertificate(clientCa);
|
|
#endif
|
|
return *this;
|
|
}
|
|
|
|
espMqttClientSecure& espMqttClientSecure::setPrivateKey(const char* privateKey) {
|
|
#if defined(EMC_CLIENT_SECURE)
|
|
_client.client.setPrivateKey(privateKey);
|
|
#endif
|
|
return *this;
|
|
}
|
|
|
|
espMqttClientSecure& espMqttClientSecure::setPreSharedKey(const char* pskIdent, const char* psKey) {
|
|
#if defined(EMC_CLIENT_SECURE)
|
|
_client.client.setPreSharedKey(pskIdent, psKey);
|
|
#endif
|
|
return *this;
|
|
}
|
|
|
|
#endif
|
|
|
|
#if defined(__linux__)
|
|
espMqttClient::espMqttClient()
|
|
: MqttClientSetup(espMqttClientTypes::UseInternalTask::NO)
|
|
, _client() {
|
|
_transport = &_client;
|
|
}
|
|
#endif
|