1*3ff40c12SJohn Marino /*
2*3ff40c12SJohn Marino * External password backend
3*3ff40c12SJohn Marino * Copyright (c) 2012, Jouni Malinen <j@w1.fi>
4*3ff40c12SJohn Marino *
5*3ff40c12SJohn Marino * This software may be distributed under the terms of the BSD license.
6*3ff40c12SJohn Marino * See README for more details.
7*3ff40c12SJohn Marino */
8*3ff40c12SJohn Marino
9*3ff40c12SJohn Marino #include "includes.h"
10*3ff40c12SJohn Marino
11*3ff40c12SJohn Marino #ifdef __linux__
12*3ff40c12SJohn Marino #include <sys/mman.h>
13*3ff40c12SJohn Marino #endif /* __linux__ */
14*3ff40c12SJohn Marino
15*3ff40c12SJohn Marino #include "common.h"
16*3ff40c12SJohn Marino #include "ext_password_i.h"
17*3ff40c12SJohn Marino
18*3ff40c12SJohn Marino
19*3ff40c12SJohn Marino static const struct ext_password_backend *backends[] = {
20*3ff40c12SJohn Marino #ifdef CONFIG_EXT_PASSWORD_TEST
21*3ff40c12SJohn Marino &ext_password_test,
22*3ff40c12SJohn Marino #endif /* CONFIG_EXT_PASSWORD_TEST */
23*3ff40c12SJohn Marino NULL
24*3ff40c12SJohn Marino };
25*3ff40c12SJohn Marino
26*3ff40c12SJohn Marino struct ext_password_data {
27*3ff40c12SJohn Marino const struct ext_password_backend *backend;
28*3ff40c12SJohn Marino void *priv;
29*3ff40c12SJohn Marino };
30*3ff40c12SJohn Marino
31*3ff40c12SJohn Marino
ext_password_init(const char * backend,const char * params)32*3ff40c12SJohn Marino struct ext_password_data * ext_password_init(const char *backend,
33*3ff40c12SJohn Marino const char *params)
34*3ff40c12SJohn Marino {
35*3ff40c12SJohn Marino struct ext_password_data *data;
36*3ff40c12SJohn Marino int i;
37*3ff40c12SJohn Marino
38*3ff40c12SJohn Marino data = os_zalloc(sizeof(*data));
39*3ff40c12SJohn Marino if (data == NULL)
40*3ff40c12SJohn Marino return NULL;
41*3ff40c12SJohn Marino
42*3ff40c12SJohn Marino for (i = 0; backends[i]; i++) {
43*3ff40c12SJohn Marino if (os_strcmp(backends[i]->name, backend) == 0) {
44*3ff40c12SJohn Marino data->backend = backends[i];
45*3ff40c12SJohn Marino break;
46*3ff40c12SJohn Marino }
47*3ff40c12SJohn Marino }
48*3ff40c12SJohn Marino
49*3ff40c12SJohn Marino if (!data->backend) {
50*3ff40c12SJohn Marino os_free(data);
51*3ff40c12SJohn Marino return NULL;
52*3ff40c12SJohn Marino }
53*3ff40c12SJohn Marino
54*3ff40c12SJohn Marino data->priv = data->backend->init(params);
55*3ff40c12SJohn Marino if (data->priv == NULL) {
56*3ff40c12SJohn Marino os_free(data);
57*3ff40c12SJohn Marino return NULL;
58*3ff40c12SJohn Marino }
59*3ff40c12SJohn Marino
60*3ff40c12SJohn Marino return data;
61*3ff40c12SJohn Marino }
62*3ff40c12SJohn Marino
63*3ff40c12SJohn Marino
ext_password_deinit(struct ext_password_data * data)64*3ff40c12SJohn Marino void ext_password_deinit(struct ext_password_data *data)
65*3ff40c12SJohn Marino {
66*3ff40c12SJohn Marino if (data && data->backend && data->priv)
67*3ff40c12SJohn Marino data->backend->deinit(data->priv);
68*3ff40c12SJohn Marino os_free(data);
69*3ff40c12SJohn Marino }
70*3ff40c12SJohn Marino
71*3ff40c12SJohn Marino
ext_password_get(struct ext_password_data * data,const char * name)72*3ff40c12SJohn Marino struct wpabuf * ext_password_get(struct ext_password_data *data,
73*3ff40c12SJohn Marino const char *name)
74*3ff40c12SJohn Marino {
75*3ff40c12SJohn Marino if (data == NULL)
76*3ff40c12SJohn Marino return NULL;
77*3ff40c12SJohn Marino return data->backend->get(data->priv, name);
78*3ff40c12SJohn Marino }
79*3ff40c12SJohn Marino
80*3ff40c12SJohn Marino
ext_password_alloc(size_t len)81*3ff40c12SJohn Marino struct wpabuf * ext_password_alloc(size_t len)
82*3ff40c12SJohn Marino {
83*3ff40c12SJohn Marino struct wpabuf *buf;
84*3ff40c12SJohn Marino
85*3ff40c12SJohn Marino buf = wpabuf_alloc(len);
86*3ff40c12SJohn Marino if (buf == NULL)
87*3ff40c12SJohn Marino return NULL;
88*3ff40c12SJohn Marino
89*3ff40c12SJohn Marino #ifdef __linux__
90*3ff40c12SJohn Marino if (mlock(wpabuf_head(buf), wpabuf_len(buf)) < 0) {
91*3ff40c12SJohn Marino wpa_printf(MSG_ERROR, "EXT PW: mlock failed: %s",
92*3ff40c12SJohn Marino strerror(errno));
93*3ff40c12SJohn Marino }
94*3ff40c12SJohn Marino #endif /* __linux__ */
95*3ff40c12SJohn Marino
96*3ff40c12SJohn Marino return buf;
97*3ff40c12SJohn Marino }
98*3ff40c12SJohn Marino
99*3ff40c12SJohn Marino
ext_password_free(struct wpabuf * pw)100*3ff40c12SJohn Marino void ext_password_free(struct wpabuf *pw)
101*3ff40c12SJohn Marino {
102*3ff40c12SJohn Marino if (pw == NULL)
103*3ff40c12SJohn Marino return;
104*3ff40c12SJohn Marino os_memset(wpabuf_mhead(pw), 0, wpabuf_len(pw));
105*3ff40c12SJohn Marino #ifdef __linux__
106*3ff40c12SJohn Marino if (munlock(wpabuf_head(pw), wpabuf_len(pw)) < 0) {
107*3ff40c12SJohn Marino wpa_printf(MSG_ERROR, "EXT PW: munlock failed: %s",
108*3ff40c12SJohn Marino strerror(errno));
109*3ff40c12SJohn Marino }
110*3ff40c12SJohn Marino #endif /* __linux__ */
111*3ff40c12SJohn Marino wpabuf_free(pw);
112*3ff40c12SJohn Marino }
113