18
18
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
22
#include "drizzled/plugin/authentication.h"
23
#include "drizzled/error.h"
24
#include "drizzled/gettext.h"
25
#include "drizzled/security_context.h"
22
#include <boost/foreach.hpp>
23
#include <drizzled/plugin/authentication.h>
24
#include <drizzled/error.h>
25
#include <drizzled/gettext.h>
26
#include <drizzled/identifier.h>
32
std::vector<plugin::Authentication *> all_authentication;
35
bool plugin::Authentication::addPlugin(plugin::Authentication *auth)
31
static std::vector<plugin::Authentication*> all_authentication;
33
bool plugin::Authentication::addPlugin(plugin::Authentication* auth)
38
36
all_authentication.push_back(auth);
42
void plugin::Authentication::removePlugin(plugin::Authentication *auth)
40
void plugin::Authentication::removePlugin(plugin::Authentication* auth)
45
all_authentication.erase(std::find(all_authentication.begin(),
46
all_authentication.end(),
42
all_authentication.erase(std::find(all_authentication.begin(), all_authentication.end(), auth));
50
class AuthenticateBy : public std::unary_function<plugin::Authentication *, bool>
52
const SecurityContext &sctx;
53
const std::string &password;
55
AuthenticateBy(const SecurityContext &sctx_arg, const std::string &password_arg) :
56
std::unary_function<plugin::Authentication *, bool>(),
57
sctx(sctx_arg), password(password_arg) {}
59
inline result_type operator()(argument_type auth)
61
return auth->authenticate(sctx, password);
65
bool plugin::Authentication::isAuthenticated(const SecurityContext &sctx,
66
const std::string &password)
68
/* If we never loaded any auth plugins, just return true */
69
if (all_authentication.empty())
72
/* Use find_if instead of foreach so that we can collect return codes */
73
std::vector<plugin::Authentication *>::iterator iter=
74
std::find_if(all_authentication.begin(), all_authentication.end(),
75
AuthenticateBy(sctx, password));
77
/* We only require one plugin to return success in order to authenticate.
78
* If iter is == end() here, that means that all of the plugins returned
79
* false, which means they all failed.
81
if (iter == all_authentication.end())
83
my_error(ER_ACCESS_DENIED_ERROR, MYF(0),
84
sctx.getUser().c_str(),
86
password.empty() ? ER(ER_NO) : ER(ER_YES));
45
bool plugin::Authentication::isAuthenticated(const drizzled::identifier::User& sctx, const std::string& password)
47
BOOST_FOREACH(plugin::Authentication* auth, all_authentication)
49
if (auth->authenticate(sctx, password))
92
56
} /* namespace drizzled */