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/plugin/registry.h"
25
#include "drizzled/gettext.h"
26
#include "drizzled/security_context.h"
35
std::vector<plugin::Authentication *> all_authentication;
38
bool plugin::Authentication::addPlugin(plugin::Authentication *auth)
41
all_authentication.push_back(auth);
21
#include <drizzled/server_includes.h>
22
#include <drizzled/authentication.h>
23
#include <drizzled/gettext.h>
24
#include <drizzled/errmsg_print.h>
26
static bool are_plugins_loaded= false;
28
static bool authenticate_by(Session *session, plugin_ref plugin, void* p_data)
30
const char *password= (const char *)p_data;
31
authentication_st *auth= plugin_data(plugin, authentication_st *);
35
if (auth && auth->authenticate)
37
if (auth->authenticate(session, password))
45
void plugin::Authentication::removePlugin(plugin::Authentication *auth)
48
all_authentication.erase(find(all_authentication.begin(),
49
all_authentication.end(),
53
class AuthenticateBy : public unary_function<plugin::Authentication *, bool>
55
const SecurityContext &sctx;
56
const string &password;
58
AuthenticateBy(const SecurityContext &sctx_arg, const string &password_arg) :
59
unary_function<plugin::Authentication *, bool>(),
60
sctx(sctx_arg), password(password_arg) {}
62
inline result_type operator()(argument_type auth)
64
return auth->authenticate(sctx, password);
68
bool plugin::Authentication::isAuthenticated(const SecurityContext &sctx,
69
const string &password)
44
bool authenticate_user(Session *session, const char *password)
71
46
/* If we never loaded any auth plugins, just return true */
72
if (all_authentication.empty())
47
if (are_plugins_loaded != true)
75
/* Use find_if instead of foreach so that we can collect return codes */
76
vector<plugin::Authentication *>::iterator iter=
77
find_if(all_authentication.begin(), all_authentication.end(),
78
AuthenticateBy(sctx, password));
80
/* We only require one plugin to return success in order to authenticate.
81
* If iter is == end() here, that means that all of the plugins returned
82
* false, which means they all failed.
84
if (iter == all_authentication.end())
50
return plugin_foreach(session, authenticate_by, DRIZZLE_AUTH_PLUGIN, (void *)password);
54
int authentication_initializer(st_plugin_int *plugin)
56
authentication_st *authen;
58
authen= new authentication_st;
63
memset(authen, 0, sizeof(authentication_st));
65
if (plugin->plugin->init)
86
my_error(ER_ACCESS_DENIED_ERROR, MYF(0),
87
sctx.getUser().c_str(),
89
password.empty() ? ER(ER_NO) : ER(ER_YES));
67
if (plugin->plugin->init(authen))
69
errmsg_printf(ERRMSG_LVL_ERROR, _("Plugin '%s' init function returned error."),
95
} /* namespace drizzled */
75
plugin->data= (void *)authen;
76
are_plugins_loaded= true;
84
int authentication_finalizer(st_plugin_int *plugin)
86
authentication_st *authen= (authentication_st *)plugin->data;
89
if (authen && plugin->plugin->deinit)
90
plugin->plugin->deinit(authen);