#include #include #include #include #include "conversation.h" namespace { conversation_result err = {"",""}; class impl : public conversation_ifc { private: pam pam_; public: impl (pam &pam) : pam_ (pam) {} conversation_result initiate (const pam_request &request) { const pam_conv *conv; int get_conv_result = pam_.get_conv (request.handle(), &conv); if (get_conv_result != PAM_SUCCESS) { return err; } pam_message msg; msg.msg = const_cast ("Dual control token: "); msg.msg_style = PAM_PROMPT_ECHO_OFF; std::vector messages; messages.push_back (&msg); std::vector responses (1); int conv_result = conv->conv (1, messages.data(), responses.data(), conv->appdata_ptr); std::string answer (responses[0]->resp); std::string::iterator delim = std::find (answer.begin(), answer.end(), ':'); if (delim == answer.end()) { return err; } return { std::string (answer.begin(), delim), std::string (delim + 1, answer.end()) }; } }; } conversation create_conversation (pam &pam) { return conversation (std::shared_ptr (new impl (pam))); } /* int (*conv)(int num_msg, const struct pam_message **msg, struct pam_response **resp, void *appdata_ptr) */ /* pam_token_conversation::pam_token_conversation (pam_handle_t *pamh, const pam_p pam) { pam_conversation_p pam_conversation; int get_conversation_result = pam->get_conversation (pamh, pam_conversation); if (get_conversation_result != 0) { return; } struct pam_message prompt; std::string message ("Dual control token: "); prompt.msg = const_cast (message.c_str()); prompt.msg_style = PAM_PROMPT_ECHO_OFF; std::vector prompts (1); prompts[0] = &prompt; std::vector answers (1); int conversation_result = pam_conversation->conv (prompts, answers); if (conversation_result) { return; } if (answers[0]->resp_retcode) { return; } std::string answer (answers[0]->resp); std::string::iterator delim = std::find (answer.begin(), answer.end(), ':'); if (delim == answer.end()) { return; } std::string user_name (answer.begin(), delim); std::string token (delim + 1, answer.end()); user_ = user_name; token_ = token; } std::string pam_token_conversation::token() { return token_; } std::string pam_token_conversation::user_name() { return user_; } */