pull sasl config out of registration
This commit is contained in:
@@ -2,12 +2,10 @@
|
||||
|
||||
#include "connection.hpp"
|
||||
#include "client.hpp"
|
||||
#include "ref.hpp"
|
||||
|
||||
#include <memory>
|
||||
#include <string>
|
||||
#include <unordered_map>
|
||||
#include <unordered_set>
|
||||
|
||||
class Registration : public std::enable_shared_from_this<Registration>
|
||||
{
|
||||
@@ -17,11 +15,7 @@ public:
|
||||
std::string username;
|
||||
std::string realname;
|
||||
std::string password;
|
||||
std::string sasl_mechanism;
|
||||
std::string sasl_authcid;
|
||||
std::string sasl_authzid;
|
||||
std::string sasl_password;
|
||||
Ref<EVP_PKEY> sasl_key;
|
||||
std::unique_ptr<SaslMechanism> sasl_mechanism;
|
||||
};
|
||||
|
||||
private:
|
||||
|
@@ -2,8 +2,6 @@
|
||||
|
||||
#include "connection.hpp"
|
||||
#include "ircmsg.hpp"
|
||||
#include "sasl_mechanism.hpp"
|
||||
#include "openssl_utils.hpp"
|
||||
|
||||
#include <memory>
|
||||
#include <random>
|
||||
@@ -71,7 +69,7 @@ auto Registration::on_cap_list(const std::unordered_map<std::string, std::string
|
||||
}
|
||||
}
|
||||
|
||||
bool do_sasl = not settings_.sasl_mechanism.empty() && caps.contains("sasl");
|
||||
bool do_sasl = settings_.sasl_mechanism && caps.contains("sasl");
|
||||
if (do_sasl) {
|
||||
request.append("sasl ");
|
||||
}
|
||||
@@ -82,19 +80,8 @@ auto Registration::on_cap_list(const std::unordered_map<std::string, std::string
|
||||
client_->get_connection().send_cap_req(request);
|
||||
}
|
||||
|
||||
if (do_sasl && settings_.sasl_mechanism == "PLAIN") {
|
||||
client_->start_sasl(
|
||||
std::make_unique<SaslPlain>(
|
||||
settings_.sasl_authcid,
|
||||
settings_.sasl_authzid,
|
||||
settings_.sasl_password));
|
||||
} else if (do_sasl && settings_.sasl_mechanism == "EXTERNAL") {
|
||||
client_->start_sasl(std::make_unique<SaslExternal>(settings_.sasl_authzid));
|
||||
} else if (do_sasl && settings_.sasl_mechanism == "ECDSA") {
|
||||
client_->start_sasl(std::make_unique<SaslEcdsa>(
|
||||
settings_.sasl_authcid,
|
||||
settings_.sasl_authzid,
|
||||
settings_.sasl_key));
|
||||
if (do_sasl) {
|
||||
client_->start_sasl(std::move(settings_.sasl_mechanism));
|
||||
} else {
|
||||
client_->get_connection().send_cap_end();
|
||||
}
|
||||
|
Reference in New Issue
Block a user