aboutsummaryrefslogtreecommitdiff
path: root/vmime-master/examples/example6_authenticator.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'vmime-master/examples/example6_authenticator.hpp')
-rw-r--r--vmime-master/examples/example6_authenticator.hpp112
1 files changed, 112 insertions, 0 deletions
diff --git a/vmime-master/examples/example6_authenticator.hpp b/vmime-master/examples/example6_authenticator.hpp
new file mode 100644
index 0000000..56f0239
--- /dev/null
+++ b/vmime-master/examples/example6_authenticator.hpp
@@ -0,0 +1,112 @@
+
+
+#if VMIME_HAVE_SASL_SUPPORT
+
+// SASL authentication handler
+class interactiveAuthenticator : public vmime::security::sasl::defaultSASLAuthenticator {
+
+ const std::vector <vmime::shared_ptr <vmime::security::sasl::SASLMechanism> >
+ getAcceptableMechanisms(
+ const std::vector <vmime::shared_ptr <vmime::security::sasl::SASLMechanism> >& available,
+ const vmime::shared_ptr <vmime::security::sasl::SASLMechanism>& suggested
+ ) const {
+
+ std::cout << std::endl << "Available SASL mechanisms:" << std::endl;
+
+ for (unsigned int i = 0 ; i < available.size() ; ++i) {
+
+ std::cout << " " << available[i]->getName();
+
+ if (suggested && available[i]->getName() == suggested->getName()) {
+ std::cout << "(suggested)";
+ }
+ }
+
+ std::cout << std::endl << std::endl;
+
+ return defaultSASLAuthenticator::getAcceptableMechanisms(available, suggested);
+ }
+
+ void setSASLMechanism(const vmime::shared_ptr <vmime::security::sasl::SASLMechanism>& mech) {
+
+ std::cout << "Trying '" << mech->getName() << "' authentication mechanism" << std::endl;
+
+ defaultSASLAuthenticator::setSASLMechanism(mech);
+ }
+
+ const vmime::string getUsername() const {
+
+ if (m_username.empty()) {
+ m_username = getUserInput("Username");
+ }
+
+ return m_username;
+ }
+
+ const vmime::string getPassword() const {
+
+ if (m_password.empty()) {
+ m_password = getUserInput("Password");
+ }
+
+ return m_password;
+ }
+
+ static const vmime::string getUserInput(const std::string& prompt) {
+
+ std::cout << prompt << ": ";
+ std::cout.flush();
+
+ vmime::string res;
+ std::getline(std::cin, res);
+
+ return res;
+ }
+
+private:
+
+ mutable vmime::string m_username;
+ mutable vmime::string m_password;
+};
+
+#else // !VMIME_HAVE_SASL_SUPPORT
+
+// Simple authentication handler
+class interactiveAuthenticator : public vmime::security::defaultAuthenticator {
+
+ const vmime::string getUsername() const {
+
+ if (m_username.empty()) {
+ m_username = getUserInput("Username");
+ }
+
+ return m_username;
+ }
+
+ const vmime::string getPassword() const {
+
+ if (m_password.empty()) {
+ m_password = getUserInput("Password");
+ }
+
+ return m_password;
+ }
+
+ static const vmime::string getUserInput(const std::string& prompt) {
+
+ std::cout << prompt << ": ";
+ std::cout.flush();
+
+ vmime::string res;
+ std::getline(std::cin, res);
+
+ return res;
+ }
+
+private:
+
+ mutable vmime::string m_username;
+ mutable vmime::string m_password;
+};
+
+#endif // VMIME_HAVE_SASL_SUPPORT