};
static void
-static_verify_plain(struct auth_request *request, const char *password,
- verify_plain_callback_t *callback)
+static_save_fields(struct auth_request *request, const char **password_r)
{
struct static_passdb_module *module =
(struct static_passdb_module *)request->passdb->passdb;
const struct var_expand_table *table;
- const char *const *args, *static_password = "";
+ const char *const *args;
unsigned int i, count;
string_t *str = t_str_new(128);
- int ret;
auth_request_log_debug(request, "static", "lookup");
table = auth_request_get_var_expand_table(request, NULL);
+ *password_r = "";
args = array_get(&module->tmpl, &count);
i_assert((count % 2) == 0);
for (i = 0; i < count; i += 2) {
}
if (strcmp(key, "password") == 0)
- static_password = value;
+ *password_r = value;
else {
auth_request_set_field(request, key, value,
STATIC_PASS_SCHEME);
}
}
+}
+
+static void
+static_verify_plain(struct auth_request *request, const char *password,
+ verify_plain_callback_t *callback)
+{
+ const char *static_password;
+ int ret;
+
+ static_save_fields(request, &static_password);
ret = auth_request_password_verify(request, password, static_password,
STATIC_PASS_SCHEME, "static");
callback(PASSDB_RESULT_OK, request);
}
+static void
+static_lookup_credentials(struct auth_request *request,
+ lookup_credentials_callback_t *callback)
+{
+ const char *static_password;
+
+ static_save_fields(request, &static_password);
+ passdb_handle_credentials(PASSDB_RESULT_OK, static_password,
+ STATIC_PASS_SCHEME, callback, request);
+}
+
static struct passdb_module *
static_preinit(pool_t pool, const char *args)
{
NULL,
static_verify_plain,
- NULL,
+ static_lookup_credentials,
NULL
};