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 - 2021 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 25*1c60b9acSAndroid Build Coastguard Worker #define VERBOSE 26*1c60b9acSAndroid Build Coastguard Worker 27*1c60b9acSAndroid Build Coastguard Worker #define MAX_BLOBBED_PARAMS 96 /* largest bstr-encoded params */ 28*1c60b9acSAndroid Build Coastguard Worker 29*1c60b9acSAndroid Build Coastguard Worker enum { 30*1c60b9acSAndroid Build Coastguard Worker ST_UNKNOWN, 31*1c60b9acSAndroid Build Coastguard Worker 32*1c60b9acSAndroid Build Coastguard Worker ST_OUTER_PROTECTED, 33*1c60b9acSAndroid Build Coastguard Worker ST_OUTER_UNPROTECTED, 34*1c60b9acSAndroid Build Coastguard Worker ST_OUTER_PAYLOAD, 35*1c60b9acSAndroid Build Coastguard Worker ST_OUTER_SIGN1_SIGNATURE, 36*1c60b9acSAndroid Build Coastguard Worker 37*1c60b9acSAndroid Build Coastguard Worker ST_OUTER_SIGN_SIGARRAY, 38*1c60b9acSAndroid Build Coastguard Worker 39*1c60b9acSAndroid Build Coastguard Worker ST_OUTER_MACTAG, 40*1c60b9acSAndroid Build Coastguard Worker 41*1c60b9acSAndroid Build Coastguard Worker ST_INNER_PROTECTED, 42*1c60b9acSAndroid Build Coastguard Worker ST_INNER_UNPROTECTED, 43*1c60b9acSAndroid Build Coastguard Worker ST_INNER_SIGNATURE, 44*1c60b9acSAndroid Build Coastguard Worker 45*1c60b9acSAndroid Build Coastguard Worker ST_INNER_EXCESS, 46*1c60b9acSAndroid Build Coastguard Worker }; 47*1c60b9acSAndroid Build Coastguard Worker 48*1c60b9acSAndroid Build Coastguard Worker typedef struct lws_cose_sig_alg { 49*1c60b9acSAndroid Build Coastguard Worker lws_dll2_t list; 50*1c60b9acSAndroid Build Coastguard Worker uint8_t rhash[512]; 51*1c60b9acSAndroid Build Coastguard Worker const lws_cose_key_t *cose_key; 52*1c60b9acSAndroid Build Coastguard Worker struct lws_genhash_ctx hash_ctx; 53*1c60b9acSAndroid Build Coastguard Worker union { 54*1c60b9acSAndroid Build Coastguard Worker struct lws_genec_ctx ecdsactx; 55*1c60b9acSAndroid Build Coastguard Worker struct lws_genrsa_ctx rsactx; 56*1c60b9acSAndroid Build Coastguard Worker struct lws_genhmac_ctx hmacctx; 57*1c60b9acSAndroid Build Coastguard Worker } u; 58*1c60b9acSAndroid Build Coastguard Worker cose_param_t cose_alg; 59*1c60b9acSAndroid Build Coastguard Worker int keybits; 60*1c60b9acSAndroid Build Coastguard Worker int rhash_len; 61*1c60b9acSAndroid Build Coastguard Worker 62*1c60b9acSAndroid Build Coastguard Worker char failed; 63*1c60b9acSAndroid Build Coastguard Worker char completed; 64*1c60b9acSAndroid Build Coastguard Worker } lws_cose_sig_alg_t; 65*1c60b9acSAndroid Build Coastguard Worker 66*1c60b9acSAndroid Build Coastguard Worker typedef struct lws_cose_validate_param_stack { 67*1c60b9acSAndroid Build Coastguard Worker uint8_t ph[4][MAX_BLOBBED_PARAMS]; 68*1c60b9acSAndroid Build Coastguard Worker int ph_pos[4]; 69*1c60b9acSAndroid Build Coastguard Worker struct lws_gencrypto_keyelem kid; 70*1c60b9acSAndroid Build Coastguard Worker cose_param_t alg; 71*1c60b9acSAndroid Build Coastguard Worker } lws_cose_validate_param_stack_t; 72*1c60b9acSAndroid Build Coastguard Worker 73*1c60b9acSAndroid Build Coastguard Worker struct lws_cose_validate_context { 74*1c60b9acSAndroid Build Coastguard Worker lws_cose_validate_create_info_t info; 75*1c60b9acSAndroid Build Coastguard Worker uint8_t mac[LWS_GENHASH_LARGEST]; 76*1c60b9acSAndroid Build Coastguard Worker uint8_t sig_agg[512]; 77*1c60b9acSAndroid Build Coastguard Worker lws_cose_validate_param_stack_t st[3]; 78*1c60b9acSAndroid Build Coastguard Worker lws_dll2_owner_t algs; 79*1c60b9acSAndroid Build Coastguard Worker lws_dll2_owner_t results; 80*1c60b9acSAndroid Build Coastguard Worker uint8_t *payload_stash; 81*1c60b9acSAndroid Build Coastguard Worker struct lwsac *ac; 82*1c60b9acSAndroid Build Coastguard Worker struct lecp_ctx ctx; 83*1c60b9acSAndroid Build Coastguard Worker void *user; 84*1c60b9acSAndroid Build Coastguard Worker 85*1c60b9acSAndroid Build Coastguard Worker size_t payload_pos; 86*1c60b9acSAndroid Build Coastguard Worker size_t payload_stash_size; 87*1c60b9acSAndroid Build Coastguard Worker 88*1c60b9acSAndroid Build Coastguard Worker int seen; 89*1c60b9acSAndroid Build Coastguard Worker int depth; 90*1c60b9acSAndroid Build Coastguard Worker 91*1c60b9acSAndroid Build Coastguard Worker int outer; 92*1c60b9acSAndroid Build Coastguard Worker size_t mac_pos; 93*1c60b9acSAndroid Build Coastguard Worker size_t sig_agg_pos; 94*1c60b9acSAndroid Build Coastguard Worker 95*1c60b9acSAndroid Build Coastguard Worker cose_param_t map_key; /* parsing temp before val */ 96*1c60b9acSAndroid Build Coastguard Worker 97*1c60b9acSAndroid Build Coastguard Worker int tli; /* toplevel item */ 98*1c60b9acSAndroid Build Coastguard Worker int sp; 99*1c60b9acSAndroid Build Coastguard Worker 100*1c60b9acSAndroid Build Coastguard Worker uint8_t sub; 101*1c60b9acSAndroid Build Coastguard Worker }; 102*1c60b9acSAndroid Build Coastguard Worker 103*1c60b9acSAndroid Build Coastguard Worker struct lws_cose_sign_context { 104*1c60b9acSAndroid Build Coastguard Worker lws_cose_sign_create_info_t info; 105*1c60b9acSAndroid Build Coastguard Worker 106*1c60b9acSAndroid Build Coastguard Worker lws_dll2_owner_t algs; 107*1c60b9acSAndroid Build Coastguard Worker lws_cose_sig_alg_t *alg; 108*1c60b9acSAndroid Build Coastguard Worker 109*1c60b9acSAndroid Build Coastguard Worker size_t rem_pay; 110*1c60b9acSAndroid Build Coastguard Worker enum lws_cose_sig_types type; /* computed */ 111*1c60b9acSAndroid Build Coastguard Worker int flags; 112*1c60b9acSAndroid Build Coastguard Worker 113*1c60b9acSAndroid Build Coastguard Worker size_t along; 114*1c60b9acSAndroid Build Coastguard Worker 115*1c60b9acSAndroid Build Coastguard Worker int tli; 116*1c60b9acSAndroid Build Coastguard Worker 117*1c60b9acSAndroid Build Coastguard Worker char subsequent; 118*1c60b9acSAndroid Build Coastguard Worker }; 119*1c60b9acSAndroid Build Coastguard Worker 120*1c60b9acSAndroid Build Coastguard Worker extern const uint8_t *sig_mctx[]; 121*1c60b9acSAndroid Build Coastguard Worker extern uint8_t sig_mctx_len[]; 122*1c60b9acSAndroid Build Coastguard Worker extern const char *cose_sections[]; 123*1c60b9acSAndroid Build Coastguard Worker 124*1c60b9acSAndroid Build Coastguard Worker lws_cose_sig_alg_t * 125*1c60b9acSAndroid Build Coastguard Worker lws_cose_val_alg_create(struct lws_context *cx, lws_cose_key_t *ck, 126*1c60b9acSAndroid Build Coastguard Worker cose_param_t cose_alg, int op); 127*1c60b9acSAndroid Build Coastguard Worker 128*1c60b9acSAndroid Build Coastguard Worker int 129*1c60b9acSAndroid Build Coastguard Worker lws_cose_val_alg_hash(lws_cose_sig_alg_t *alg, const uint8_t *in, size_t in_len); 130*1c60b9acSAndroid Build Coastguard Worker 131*1c60b9acSAndroid Build Coastguard Worker void 132*1c60b9acSAndroid Build Coastguard Worker lws_cose_val_alg_destroy(struct lws_cose_validate_context *cps, 133*1c60b9acSAndroid Build Coastguard Worker lws_cose_sig_alg_t **_alg, const uint8_t *against, 134*1c60b9acSAndroid Build Coastguard Worker size_t against_len); 135*1c60b9acSAndroid Build Coastguard Worker 136*1c60b9acSAndroid Build Coastguard Worker lws_cose_sig_alg_t * 137*1c60b9acSAndroid Build Coastguard Worker lws_cose_sign_alg_create(struct lws_context *cx, const lws_cose_key_t *ck, 138*1c60b9acSAndroid Build Coastguard Worker cose_param_t cose_alg, int op); 139*1c60b9acSAndroid Build Coastguard Worker 140*1c60b9acSAndroid Build Coastguard Worker int 141*1c60b9acSAndroid Build Coastguard Worker lws_cose_sign_alg_hash(lws_cose_sig_alg_t *alg, const uint8_t *in, size_t in_len); 142*1c60b9acSAndroid Build Coastguard Worker 143*1c60b9acSAndroid Build Coastguard Worker void 144*1c60b9acSAndroid Build Coastguard Worker lws_cose_sign_alg_complete(lws_cose_sig_alg_t *alg); 145*1c60b9acSAndroid Build Coastguard Worker 146*1c60b9acSAndroid Build Coastguard Worker void 147*1c60b9acSAndroid Build Coastguard Worker lws_cose_sign_alg_destroy(lws_cose_sig_alg_t **_alg); 148*1c60b9acSAndroid Build Coastguard Worker 149