xref: /aosp_15_r20/external/libwebsockets/lib/tls/mbedtls/lws-genhash.c (revision 1c60b9aca93fdbc9b5f19b2d2194c91294b22281)
1*1c60b9acSAndroid Build Coastguard Worker  /*
2*1c60b9acSAndroid Build Coastguard Worker  * libwebsockets - small server side websockets and web server implementation
3*1c60b9acSAndroid Build Coastguard Worker  *
4*1c60b9acSAndroid Build Coastguard Worker  * Copyright (C) 2010 - 2019 Andy Green <[email protected]>
5*1c60b9acSAndroid Build Coastguard Worker  *
6*1c60b9acSAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a copy
7*1c60b9acSAndroid Build Coastguard Worker  * of this software and associated documentation files (the "Software"), to
8*1c60b9acSAndroid Build Coastguard Worker  * deal in the Software without restriction, including without limitation the
9*1c60b9acSAndroid Build Coastguard Worker  * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10*1c60b9acSAndroid Build Coastguard Worker  * sell copies of the Software, and to permit persons to whom the Software is
11*1c60b9acSAndroid Build Coastguard Worker  * furnished to do so, subject to the following conditions:
12*1c60b9acSAndroid Build Coastguard Worker  *
13*1c60b9acSAndroid Build Coastguard Worker  * The above copyright notice and this permission notice shall be included in
14*1c60b9acSAndroid Build Coastguard Worker  * all copies or substantial portions of the Software.
15*1c60b9acSAndroid Build Coastguard Worker  *
16*1c60b9acSAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*1c60b9acSAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*1c60b9acSAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19*1c60b9acSAndroid Build Coastguard Worker  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20*1c60b9acSAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21*1c60b9acSAndroid Build Coastguard Worker  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
22*1c60b9acSAndroid Build Coastguard Worker  * IN THE SOFTWARE.
23*1c60b9acSAndroid Build Coastguard Worker  *
24*1c60b9acSAndroid Build Coastguard Worker  *  lws_genhash provides a hash / hmac abstraction api in lws that works the
25*1c60b9acSAndroid Build Coastguard Worker  *  same whether you are using openssl or mbedtls hash functions underneath.
26*1c60b9acSAndroid Build Coastguard Worker  */
27*1c60b9acSAndroid Build Coastguard Worker #include "libwebsockets.h"
28*1c60b9acSAndroid Build Coastguard Worker #include <mbedtls/version.h>
29*1c60b9acSAndroid Build Coastguard Worker 
30*1c60b9acSAndroid Build Coastguard Worker #if defined(MBEDTLS_VERSION_NUMBER) && (MBEDTLS_VERSION_NUMBER >= 0x03000000)
31*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_md5_starts_ret mbedtls_md5_starts
32*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_md5_update_ret mbedtls_md5_update
33*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_md5_finish_ret mbedtls_md5_finish
34*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_sha1_finish_ret mbedtls_sha1_finish
35*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_sha1_update_ret mbedtls_sha1_update
36*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_sha1_starts_ret mbedtls_sha1_starts
37*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_sha256_starts_ret mbedtls_sha256_starts
38*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_sha256_update_ret mbedtls_sha256_update
39*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_sha256_finish_ret mbedtls_sha256_finish
40*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_sha512_starts_ret mbedtls_sha512_starts
41*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_sha512_update_ret mbedtls_sha512_update
42*1c60b9acSAndroid Build Coastguard Worker #define mbedtls_sha512_finish_ret mbedtls_sha512_finish
43*1c60b9acSAndroid Build Coastguard Worker #endif
44*1c60b9acSAndroid Build Coastguard Worker 
45*1c60b9acSAndroid Build Coastguard Worker #if defined(MBEDTLS_VERSION_NUMBER) && (MBEDTLS_VERSION_NUMBER >= 0x02070000)
46*1c60b9acSAndroid Build Coastguard Worker 
47*1c60b9acSAndroid Build Coastguard Worker /*
48*1c60b9acSAndroid Build Coastguard Worker  * We have the _ret variants available, check the return codes on everything
49*1c60b9acSAndroid Build Coastguard Worker  */
50*1c60b9acSAndroid Build Coastguard Worker 
51*1c60b9acSAndroid Build Coastguard Worker int
lws_genhash_init(struct lws_genhash_ctx * ctx,enum lws_genhash_types type)52*1c60b9acSAndroid Build Coastguard Worker lws_genhash_init(struct lws_genhash_ctx *ctx, enum lws_genhash_types type)
53*1c60b9acSAndroid Build Coastguard Worker {
54*1c60b9acSAndroid Build Coastguard Worker 	ctx->type = (uint8_t)type;
55*1c60b9acSAndroid Build Coastguard Worker 
56*1c60b9acSAndroid Build Coastguard Worker 	switch (ctx->type) {
57*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_MD5:
58*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_md5_init(&ctx->u.md5);
59*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_md5_starts_ret(&ctx->u.md5))
60*1c60b9acSAndroid Build Coastguard Worker 			return 1;
61*1c60b9acSAndroid Build Coastguard Worker 		break;
62*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA1:
63*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha1_init(&ctx->u.sha1);
64*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha1_starts_ret(&ctx->u.sha1))
65*1c60b9acSAndroid Build Coastguard Worker 			return 1;
66*1c60b9acSAndroid Build Coastguard Worker 		break;
67*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA256:
68*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha256_init(&ctx->u.sha256);
69*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha256_starts_ret(&ctx->u.sha256, 0))
70*1c60b9acSAndroid Build Coastguard Worker 			return 1;
71*1c60b9acSAndroid Build Coastguard Worker 		break;
72*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA384:
73*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_init(&ctx->u.sha512);
74*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha512_starts_ret(&ctx->u.sha512, 1 /* is384 */))
75*1c60b9acSAndroid Build Coastguard Worker 			return 1;
76*1c60b9acSAndroid Build Coastguard Worker 		break;
77*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA512:
78*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_init(&ctx->u.sha512);
79*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha512_starts_ret(&ctx->u.sha512, 0))
80*1c60b9acSAndroid Build Coastguard Worker 			return 1;
81*1c60b9acSAndroid Build Coastguard Worker 		break;
82*1c60b9acSAndroid Build Coastguard Worker 	default:
83*1c60b9acSAndroid Build Coastguard Worker 		return 1;
84*1c60b9acSAndroid Build Coastguard Worker 	}
85*1c60b9acSAndroid Build Coastguard Worker 
86*1c60b9acSAndroid Build Coastguard Worker 	return 0;
87*1c60b9acSAndroid Build Coastguard Worker }
88*1c60b9acSAndroid Build Coastguard Worker 
89*1c60b9acSAndroid Build Coastguard Worker int
lws_genhash_update(struct lws_genhash_ctx * ctx,const void * in,size_t len)90*1c60b9acSAndroid Build Coastguard Worker lws_genhash_update(struct lws_genhash_ctx *ctx, const void *in, size_t len)
91*1c60b9acSAndroid Build Coastguard Worker {
92*1c60b9acSAndroid Build Coastguard Worker 	if (!len)
93*1c60b9acSAndroid Build Coastguard Worker 		return 0;
94*1c60b9acSAndroid Build Coastguard Worker 
95*1c60b9acSAndroid Build Coastguard Worker 	switch (ctx->type) {
96*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_MD5:
97*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_md5_update_ret(&ctx->u.md5, in, len))
98*1c60b9acSAndroid Build Coastguard Worker 			return 1;
99*1c60b9acSAndroid Build Coastguard Worker 		break;
100*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA1:
101*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha1_update_ret(&ctx->u.sha1, in, len))
102*1c60b9acSAndroid Build Coastguard Worker 			return 1;
103*1c60b9acSAndroid Build Coastguard Worker 		break;
104*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA256:
105*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha256_update_ret(&ctx->u.sha256, in, len))
106*1c60b9acSAndroid Build Coastguard Worker 			return 1;
107*1c60b9acSAndroid Build Coastguard Worker 		break;
108*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA384:
109*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha512_update_ret(&ctx->u.sha512, in, len))
110*1c60b9acSAndroid Build Coastguard Worker 			return 1;
111*1c60b9acSAndroid Build Coastguard Worker 		break;
112*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA512:
113*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha512_update_ret(&ctx->u.sha512, in, len))
114*1c60b9acSAndroid Build Coastguard Worker 			return 1;
115*1c60b9acSAndroid Build Coastguard Worker 		break;
116*1c60b9acSAndroid Build Coastguard Worker 	}
117*1c60b9acSAndroid Build Coastguard Worker 
118*1c60b9acSAndroid Build Coastguard Worker 	return 0;
119*1c60b9acSAndroid Build Coastguard Worker }
120*1c60b9acSAndroid Build Coastguard Worker 
121*1c60b9acSAndroid Build Coastguard Worker int
lws_genhash_destroy(struct lws_genhash_ctx * ctx,void * result)122*1c60b9acSAndroid Build Coastguard Worker lws_genhash_destroy(struct lws_genhash_ctx *ctx, void *result)
123*1c60b9acSAndroid Build Coastguard Worker {
124*1c60b9acSAndroid Build Coastguard Worker 	switch (ctx->type) {
125*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_MD5:
126*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_md5_finish_ret(&ctx->u.md5, result))
127*1c60b9acSAndroid Build Coastguard Worker 			return 1;
128*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_md5_free(&ctx->u.md5);
129*1c60b9acSAndroid Build Coastguard Worker 		break;
130*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA1:
131*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha1_finish_ret(&ctx->u.sha1, result))
132*1c60b9acSAndroid Build Coastguard Worker 			return 1;
133*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha1_free(&ctx->u.sha1);
134*1c60b9acSAndroid Build Coastguard Worker 		break;
135*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA256:
136*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha256_finish_ret(&ctx->u.sha256, result))
137*1c60b9acSAndroid Build Coastguard Worker 			return 1;
138*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha256_free(&ctx->u.sha256);
139*1c60b9acSAndroid Build Coastguard Worker 		break;
140*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA384:
141*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha512_finish_ret(&ctx->u.sha512, result))
142*1c60b9acSAndroid Build Coastguard Worker 			return 1;
143*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_free(&ctx->u.sha512);
144*1c60b9acSAndroid Build Coastguard Worker 		break;
145*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA512:
146*1c60b9acSAndroid Build Coastguard Worker 		if (mbedtls_sha512_finish_ret(&ctx->u.sha512, result))
147*1c60b9acSAndroid Build Coastguard Worker 			return 1;
148*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_free(&ctx->u.sha512);
149*1c60b9acSAndroid Build Coastguard Worker 		break;
150*1c60b9acSAndroid Build Coastguard Worker 	}
151*1c60b9acSAndroid Build Coastguard Worker 
152*1c60b9acSAndroid Build Coastguard Worker 	return 0;
153*1c60b9acSAndroid Build Coastguard Worker }
154*1c60b9acSAndroid Build Coastguard Worker 
155*1c60b9acSAndroid Build Coastguard Worker #else
156*1c60b9acSAndroid Build Coastguard Worker 
157*1c60b9acSAndroid Build Coastguard Worker /*
158*1c60b9acSAndroid Build Coastguard Worker  * mbedtls is too old to have the _ret variants
159*1c60b9acSAndroid Build Coastguard Worker  */
160*1c60b9acSAndroid Build Coastguard Worker 
161*1c60b9acSAndroid Build Coastguard Worker int
lws_genhash_init(struct lws_genhash_ctx * ctx,enum lws_genhash_types type)162*1c60b9acSAndroid Build Coastguard Worker lws_genhash_init(struct lws_genhash_ctx *ctx, enum lws_genhash_types type)
163*1c60b9acSAndroid Build Coastguard Worker {
164*1c60b9acSAndroid Build Coastguard Worker 	ctx->type = type;
165*1c60b9acSAndroid Build Coastguard Worker 
166*1c60b9acSAndroid Build Coastguard Worker 	switch (ctx->type) {
167*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_MD5:
168*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_md5_init(&ctx->u.md5);
169*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_md5_starts(&ctx->u.md5);
170*1c60b9acSAndroid Build Coastguard Worker 		break;
171*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA1:
172*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha1_init(&ctx->u.sha1);
173*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha1_starts(&ctx->u.sha1);
174*1c60b9acSAndroid Build Coastguard Worker 		break;
175*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA256:
176*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha256_init(&ctx->u.sha256);
177*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha256_starts(&ctx->u.sha256, 0);
178*1c60b9acSAndroid Build Coastguard Worker 		break;
179*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA384:
180*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_init(&ctx->u.sha512);
181*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_starts(&ctx->u.sha512, 1 /* is384 */);
182*1c60b9acSAndroid Build Coastguard Worker 		break;
183*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA512:
184*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_init(&ctx->u.sha512);
185*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_starts(&ctx->u.sha512, 0);
186*1c60b9acSAndroid Build Coastguard Worker 		break;
187*1c60b9acSAndroid Build Coastguard Worker 	default:
188*1c60b9acSAndroid Build Coastguard Worker 		return 1;
189*1c60b9acSAndroid Build Coastguard Worker 	}
190*1c60b9acSAndroid Build Coastguard Worker 
191*1c60b9acSAndroid Build Coastguard Worker 	return 0;
192*1c60b9acSAndroid Build Coastguard Worker }
193*1c60b9acSAndroid Build Coastguard Worker 
194*1c60b9acSAndroid Build Coastguard Worker int
lws_genhash_update(struct lws_genhash_ctx * ctx,const void * in,size_t len)195*1c60b9acSAndroid Build Coastguard Worker lws_genhash_update(struct lws_genhash_ctx *ctx, const void *in, size_t len)
196*1c60b9acSAndroid Build Coastguard Worker {
197*1c60b9acSAndroid Build Coastguard Worker 	if (!len)
198*1c60b9acSAndroid Build Coastguard Worker 		return 0;
199*1c60b9acSAndroid Build Coastguard Worker 
200*1c60b9acSAndroid Build Coastguard Worker 	switch (ctx->type) {
201*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_MD5:
202*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_md5_update(&ctx->u.md5, in, len);
203*1c60b9acSAndroid Build Coastguard Worker 		break;
204*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA1:
205*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha1_update(&ctx->u.sha1, in, len);
206*1c60b9acSAndroid Build Coastguard Worker 		break;
207*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA256:
208*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha256_update(&ctx->u.sha256, in, len);
209*1c60b9acSAndroid Build Coastguard Worker 		break;
210*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA384:
211*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_update(&ctx->u.sha512, in, len);
212*1c60b9acSAndroid Build Coastguard Worker 		break;
213*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA512:
214*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_update(&ctx->u.sha512, in, len);
215*1c60b9acSAndroid Build Coastguard Worker 		break;
216*1c60b9acSAndroid Build Coastguard Worker 	}
217*1c60b9acSAndroid Build Coastguard Worker 
218*1c60b9acSAndroid Build Coastguard Worker 	return 0;
219*1c60b9acSAndroid Build Coastguard Worker }
220*1c60b9acSAndroid Build Coastguard Worker 
221*1c60b9acSAndroid Build Coastguard Worker int
lws_genhash_destroy(struct lws_genhash_ctx * ctx,void * result)222*1c60b9acSAndroid Build Coastguard Worker lws_genhash_destroy(struct lws_genhash_ctx *ctx, void *result)
223*1c60b9acSAndroid Build Coastguard Worker {
224*1c60b9acSAndroid Build Coastguard Worker 	switch (ctx->type) {
225*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_MD5:
226*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_md5_finish(&ctx->u.md5, result);
227*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_md5_free(&ctx->u.md5);
228*1c60b9acSAndroid Build Coastguard Worker 		break;
229*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA1:
230*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha1_finish(&ctx->u.sha1, result);
231*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha1_free(&ctx->u.sha1);
232*1c60b9acSAndroid Build Coastguard Worker 		break;
233*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA256:
234*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha256_finish(&ctx->u.sha256, result);
235*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha256_free(&ctx->u.sha256);
236*1c60b9acSAndroid Build Coastguard Worker 		break;
237*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA384:
238*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_finish(&ctx->u.sha512, result);
239*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_free(&ctx->u.sha512);
240*1c60b9acSAndroid Build Coastguard Worker 		break;
241*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHASH_TYPE_SHA512:
242*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_finish(&ctx->u.sha512, result);
243*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_sha512_free(&ctx->u.sha512);
244*1c60b9acSAndroid Build Coastguard Worker 		break;
245*1c60b9acSAndroid Build Coastguard Worker 	}
246*1c60b9acSAndroid Build Coastguard Worker 
247*1c60b9acSAndroid Build Coastguard Worker 	return 0;
248*1c60b9acSAndroid Build Coastguard Worker }
249*1c60b9acSAndroid Build Coastguard Worker 
250*1c60b9acSAndroid Build Coastguard Worker #endif
251*1c60b9acSAndroid Build Coastguard Worker 
252*1c60b9acSAndroid Build Coastguard Worker int
lws_genhmac_init(struct lws_genhmac_ctx * ctx,enum lws_genhmac_types type,const uint8_t * key,size_t key_len)253*1c60b9acSAndroid Build Coastguard Worker lws_genhmac_init(struct lws_genhmac_ctx *ctx, enum lws_genhmac_types type,
254*1c60b9acSAndroid Build Coastguard Worker 		 const uint8_t *key, size_t key_len)
255*1c60b9acSAndroid Build Coastguard Worker {
256*1c60b9acSAndroid Build Coastguard Worker 	int t;
257*1c60b9acSAndroid Build Coastguard Worker 
258*1c60b9acSAndroid Build Coastguard Worker 	ctx->type = (uint8_t)type;
259*1c60b9acSAndroid Build Coastguard Worker 
260*1c60b9acSAndroid Build Coastguard Worker 	switch (type) {
261*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHMAC_TYPE_SHA256:
262*1c60b9acSAndroid Build Coastguard Worker 		t = MBEDTLS_MD_SHA256;
263*1c60b9acSAndroid Build Coastguard Worker 		break;
264*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHMAC_TYPE_SHA384:
265*1c60b9acSAndroid Build Coastguard Worker 		t = MBEDTLS_MD_SHA384;
266*1c60b9acSAndroid Build Coastguard Worker 		break;
267*1c60b9acSAndroid Build Coastguard Worker 	case LWS_GENHMAC_TYPE_SHA512:
268*1c60b9acSAndroid Build Coastguard Worker 		t = MBEDTLS_MD_SHA512;
269*1c60b9acSAndroid Build Coastguard Worker 		break;
270*1c60b9acSAndroid Build Coastguard Worker 	default:
271*1c60b9acSAndroid Build Coastguard Worker 		return -1;
272*1c60b9acSAndroid Build Coastguard Worker 	}
273*1c60b9acSAndroid Build Coastguard Worker 
274*1c60b9acSAndroid Build Coastguard Worker 	ctx->hmac = mbedtls_md_info_from_type((mbedtls_md_type_t)t);
275*1c60b9acSAndroid Build Coastguard Worker 	if (!ctx->hmac)
276*1c60b9acSAndroid Build Coastguard Worker 		return -1;
277*1c60b9acSAndroid Build Coastguard Worker 
278*1c60b9acSAndroid Build Coastguard Worker #if !defined(LWS_HAVE_mbedtls_md_setup)
279*1c60b9acSAndroid Build Coastguard Worker 	if (mbedtls_md_init_ctx(&ctx->ctx, ctx->hmac))
280*1c60b9acSAndroid Build Coastguard Worker 		return -1;
281*1c60b9acSAndroid Build Coastguard Worker #else
282*1c60b9acSAndroid Build Coastguard Worker 	if (mbedtls_md_setup(&ctx->ctx, ctx->hmac, 1))
283*1c60b9acSAndroid Build Coastguard Worker 		return -1;
284*1c60b9acSAndroid Build Coastguard Worker #endif
285*1c60b9acSAndroid Build Coastguard Worker 
286*1c60b9acSAndroid Build Coastguard Worker 	if (mbedtls_md_hmac_starts(&ctx->ctx, key, key_len)) {
287*1c60b9acSAndroid Build Coastguard Worker 		mbedtls_md_free(&ctx->ctx);
288*1c60b9acSAndroid Build Coastguard Worker 		ctx->hmac = NULL;
289*1c60b9acSAndroid Build Coastguard Worker 
290*1c60b9acSAndroid Build Coastguard Worker 		return -1;
291*1c60b9acSAndroid Build Coastguard Worker 	}
292*1c60b9acSAndroid Build Coastguard Worker 
293*1c60b9acSAndroid Build Coastguard Worker 	return 0;
294*1c60b9acSAndroid Build Coastguard Worker }
295*1c60b9acSAndroid Build Coastguard Worker 
296*1c60b9acSAndroid Build Coastguard Worker int
lws_genhmac_update(struct lws_genhmac_ctx * ctx,const void * in,size_t len)297*1c60b9acSAndroid Build Coastguard Worker lws_genhmac_update(struct lws_genhmac_ctx *ctx, const void *in, size_t len)
298*1c60b9acSAndroid Build Coastguard Worker {
299*1c60b9acSAndroid Build Coastguard Worker 	if (!len)
300*1c60b9acSAndroid Build Coastguard Worker 		return 0;
301*1c60b9acSAndroid Build Coastguard Worker 
302*1c60b9acSAndroid Build Coastguard Worker 	if (mbedtls_md_hmac_update(&ctx->ctx, in, len))
303*1c60b9acSAndroid Build Coastguard Worker 		return -1;
304*1c60b9acSAndroid Build Coastguard Worker 
305*1c60b9acSAndroid Build Coastguard Worker 	return 0;
306*1c60b9acSAndroid Build Coastguard Worker }
307*1c60b9acSAndroid Build Coastguard Worker 
308*1c60b9acSAndroid Build Coastguard Worker int
lws_genhmac_destroy(struct lws_genhmac_ctx * ctx,void * result)309*1c60b9acSAndroid Build Coastguard Worker lws_genhmac_destroy(struct lws_genhmac_ctx *ctx, void *result)
310*1c60b9acSAndroid Build Coastguard Worker {
311*1c60b9acSAndroid Build Coastguard Worker 	int n = 0;
312*1c60b9acSAndroid Build Coastguard Worker 
313*1c60b9acSAndroid Build Coastguard Worker 	if (result)
314*1c60b9acSAndroid Build Coastguard Worker 		n = mbedtls_md_hmac_finish(&ctx->ctx, result);
315*1c60b9acSAndroid Build Coastguard Worker 
316*1c60b9acSAndroid Build Coastguard Worker 	mbedtls_md_free(&ctx->ctx);
317*1c60b9acSAndroid Build Coastguard Worker 	ctx->hmac = NULL;
318*1c60b9acSAndroid Build Coastguard Worker 	if (n)
319*1c60b9acSAndroid Build Coastguard Worker 		return -1;
320*1c60b9acSAndroid Build Coastguard Worker 
321*1c60b9acSAndroid Build Coastguard Worker 	return 0;
322*1c60b9acSAndroid Build Coastguard Worker }
323