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 25*1c60b9acSAndroid Build Coastguard Worker #define LWS_AESGCM_IV 12 26*1c60b9acSAndroid Build Coastguard Worker #define LWS_AESGCM_TAG 16 27*1c60b9acSAndroid Build Coastguard Worker 28*1c60b9acSAndroid Build Coastguard Worker /* jwe-rsa-aescbc.c */ 29*1c60b9acSAndroid Build Coastguard Worker 30*1c60b9acSAndroid Build Coastguard Worker int 31*1c60b9acSAndroid Build Coastguard Worker lws_jwe_auth_and_decrypt_rsa_aes_cbc_hs(struct lws_jwe *jwe); 32*1c60b9acSAndroid Build Coastguard Worker 33*1c60b9acSAndroid Build Coastguard Worker 34*1c60b9acSAndroid Build Coastguard Worker int 35*1c60b9acSAndroid Build Coastguard Worker lws_jwe_encrypt_rsa_aes_cbc_hs(struct lws_jwe *jwe, 36*1c60b9acSAndroid Build Coastguard Worker char *temp, int *temp_len); 37*1c60b9acSAndroid Build Coastguard Worker 38*1c60b9acSAndroid Build Coastguard Worker int 39*1c60b9acSAndroid Build Coastguard Worker lws_jwe_auth_and_decrypt_cbc_hs(struct lws_jwe *jwe, uint8_t *enc_cek, 40*1c60b9acSAndroid Build Coastguard Worker uint8_t *aad, int aad_len); 41*1c60b9acSAndroid Build Coastguard Worker 42*1c60b9acSAndroid Build Coastguard Worker 43*1c60b9acSAndroid Build Coastguard Worker /* jws-rsa-aesgcm.c */ 44*1c60b9acSAndroid Build Coastguard Worker 45*1c60b9acSAndroid Build Coastguard Worker int 46*1c60b9acSAndroid Build Coastguard Worker lws_jwe_auth_and_decrypt_gcm(struct lws_jwe *jwe, uint8_t *enc_cek, 47*1c60b9acSAndroid Build Coastguard Worker uint8_t *aad, int aad_len); 48*1c60b9acSAndroid Build Coastguard Worker 49*1c60b9acSAndroid Build Coastguard Worker int 50*1c60b9acSAndroid Build Coastguard Worker lws_jwe_auth_and_decrypt_rsa_aes_gcm(struct lws_jwe *jwe); 51*1c60b9acSAndroid Build Coastguard Worker 52*1c60b9acSAndroid Build Coastguard Worker int 53*1c60b9acSAndroid Build Coastguard Worker lws_jwe_encrypt_gcm(struct lws_jwe *jwe, 54*1c60b9acSAndroid Build Coastguard Worker uint8_t *enc_cek, uint8_t *aad, int aad_len); 55*1c60b9acSAndroid Build Coastguard Worker 56*1c60b9acSAndroid Build Coastguard Worker int 57*1c60b9acSAndroid Build Coastguard Worker lws_jwe_encrypt_rsa_aes_gcm(struct lws_jwe *jwe, 58*1c60b9acSAndroid Build Coastguard Worker char *temp, int *temp_len); 59*1c60b9acSAndroid Build Coastguard Worker 60*1c60b9acSAndroid Build Coastguard Worker 61*1c60b9acSAndroid Build Coastguard Worker 62*1c60b9acSAndroid Build Coastguard Worker 63*1c60b9acSAndroid Build Coastguard Worker /* jwe-rsa-aeskw.c */ 64*1c60b9acSAndroid Build Coastguard Worker 65*1c60b9acSAndroid Build Coastguard Worker int 66*1c60b9acSAndroid Build Coastguard Worker lws_jwe_encrypt_aeskw_cbc_hs(struct lws_jwe *jwe, 67*1c60b9acSAndroid Build Coastguard Worker char *temp, int *temp_len); 68*1c60b9acSAndroid Build Coastguard Worker 69*1c60b9acSAndroid Build Coastguard Worker int 70*1c60b9acSAndroid Build Coastguard Worker lws_jwe_auth_and_decrypt_aeskw_cbc_hs(struct lws_jwe *jwe); 71*1c60b9acSAndroid Build Coastguard Worker 72*1c60b9acSAndroid Build Coastguard Worker /* aescbc.c */ 73*1c60b9acSAndroid Build Coastguard Worker 74*1c60b9acSAndroid Build Coastguard Worker int 75*1c60b9acSAndroid Build Coastguard Worker lws_jwe_auth_and_decrypt_cbc_hs(struct lws_jwe *jwe, uint8_t *enc_cek, 76*1c60b9acSAndroid Build Coastguard Worker uint8_t *aad, int aad_len); 77*1c60b9acSAndroid Build Coastguard Worker 78*1c60b9acSAndroid Build Coastguard Worker int 79*1c60b9acSAndroid Build Coastguard Worker lws_jwe_encrypt_cbc_hs(struct lws_jwe *jwe, 80*1c60b9acSAndroid Build Coastguard Worker uint8_t *cek, uint8_t *aad, int aad_len); 81*1c60b9acSAndroid Build Coastguard Worker 82*1c60b9acSAndroid Build Coastguard Worker int 83*1c60b9acSAndroid Build Coastguard Worker lws_jwe_auth_and_decrypt_ecdh_cbc_hs(struct lws_jwe *jwe, 84*1c60b9acSAndroid Build Coastguard Worker char *temp, int *temp_len); 85*1c60b9acSAndroid Build Coastguard Worker 86*1c60b9acSAndroid Build Coastguard Worker int 87*1c60b9acSAndroid Build Coastguard Worker lws_jwe_encrypt_ecdh_cbc_hs(struct lws_jwe *jwe, 88*1c60b9acSAndroid Build Coastguard Worker char *temp, int *temp_len); 89