1d4afb5ceSopenharmony_ci/* 2d4afb5ceSopenharmony_ci * libwebsockets - small server side websockets and web server implementation 3d4afb5ceSopenharmony_ci * 4d4afb5ceSopenharmony_ci * Copyright (C) 2010 - 2019 Andy Green <andy@warmcat.com> 5d4afb5ceSopenharmony_ci * 6d4afb5ceSopenharmony_ci * Permission is hereby granted, free of charge, to any person obtaining a copy 7d4afb5ceSopenharmony_ci * of this software and associated documentation files (the "Software"), to 8d4afb5ceSopenharmony_ci * deal in the Software without restriction, including without limitation the 9d4afb5ceSopenharmony_ci * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or 10d4afb5ceSopenharmony_ci * sell copies of the Software, and to permit persons to whom the Software is 11d4afb5ceSopenharmony_ci * furnished to do so, subject to the following conditions: 12d4afb5ceSopenharmony_ci * 13d4afb5ceSopenharmony_ci * The above copyright notice and this permission notice shall be included in 14d4afb5ceSopenharmony_ci * all copies or substantial portions of the Software. 15d4afb5ceSopenharmony_ci * 16d4afb5ceSopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17d4afb5ceSopenharmony_ci * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18d4afb5ceSopenharmony_ci * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19d4afb5ceSopenharmony_ci * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20d4afb5ceSopenharmony_ci * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 21d4afb5ceSopenharmony_ci * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 22d4afb5ceSopenharmony_ci * IN THE SOFTWARE. 23d4afb5ceSopenharmony_ci */ 24d4afb5ceSopenharmony_ci 25d4afb5ceSopenharmony_ci#define LWS_AESGCM_IV 12 26d4afb5ceSopenharmony_ci#define LWS_AESGCM_TAG 16 27d4afb5ceSopenharmony_ci 28d4afb5ceSopenharmony_ci/* jwe-rsa-aescbc.c */ 29d4afb5ceSopenharmony_ci 30d4afb5ceSopenharmony_ciint 31d4afb5ceSopenharmony_cilws_jwe_auth_and_decrypt_rsa_aes_cbc_hs(struct lws_jwe *jwe); 32d4afb5ceSopenharmony_ci 33d4afb5ceSopenharmony_ci 34d4afb5ceSopenharmony_ciint 35d4afb5ceSopenharmony_cilws_jwe_encrypt_rsa_aes_cbc_hs(struct lws_jwe *jwe, 36d4afb5ceSopenharmony_ci char *temp, int *temp_len); 37d4afb5ceSopenharmony_ci 38d4afb5ceSopenharmony_ciint 39d4afb5ceSopenharmony_cilws_jwe_auth_and_decrypt_cbc_hs(struct lws_jwe *jwe, uint8_t *enc_cek, 40d4afb5ceSopenharmony_ci uint8_t *aad, int aad_len); 41d4afb5ceSopenharmony_ci 42d4afb5ceSopenharmony_ci 43d4afb5ceSopenharmony_ci/* jws-rsa-aesgcm.c */ 44d4afb5ceSopenharmony_ci 45d4afb5ceSopenharmony_ciint 46d4afb5ceSopenharmony_cilws_jwe_auth_and_decrypt_gcm(struct lws_jwe *jwe, uint8_t *enc_cek, 47d4afb5ceSopenharmony_ci uint8_t *aad, int aad_len); 48d4afb5ceSopenharmony_ci 49d4afb5ceSopenharmony_ciint 50d4afb5ceSopenharmony_cilws_jwe_auth_and_decrypt_rsa_aes_gcm(struct lws_jwe *jwe); 51d4afb5ceSopenharmony_ci 52d4afb5ceSopenharmony_ciint 53d4afb5ceSopenharmony_cilws_jwe_encrypt_gcm(struct lws_jwe *jwe, 54d4afb5ceSopenharmony_ci uint8_t *enc_cek, uint8_t *aad, int aad_len); 55d4afb5ceSopenharmony_ci 56d4afb5ceSopenharmony_ciint 57d4afb5ceSopenharmony_cilws_jwe_encrypt_rsa_aes_gcm(struct lws_jwe *jwe, 58d4afb5ceSopenharmony_ci char *temp, int *temp_len); 59d4afb5ceSopenharmony_ci 60d4afb5ceSopenharmony_ci 61d4afb5ceSopenharmony_ci 62d4afb5ceSopenharmony_ci 63d4afb5ceSopenharmony_ci/* jwe-rsa-aeskw.c */ 64d4afb5ceSopenharmony_ci 65d4afb5ceSopenharmony_ciint 66d4afb5ceSopenharmony_cilws_jwe_encrypt_aeskw_cbc_hs(struct lws_jwe *jwe, 67d4afb5ceSopenharmony_ci char *temp, int *temp_len); 68d4afb5ceSopenharmony_ci 69d4afb5ceSopenharmony_ciint 70d4afb5ceSopenharmony_cilws_jwe_auth_and_decrypt_aeskw_cbc_hs(struct lws_jwe *jwe); 71d4afb5ceSopenharmony_ci 72d4afb5ceSopenharmony_ci/* aescbc.c */ 73d4afb5ceSopenharmony_ci 74d4afb5ceSopenharmony_ciint 75d4afb5ceSopenharmony_cilws_jwe_auth_and_decrypt_cbc_hs(struct lws_jwe *jwe, uint8_t *enc_cek, 76d4afb5ceSopenharmony_ci uint8_t *aad, int aad_len); 77d4afb5ceSopenharmony_ci 78d4afb5ceSopenharmony_ciint 79d4afb5ceSopenharmony_cilws_jwe_encrypt_cbc_hs(struct lws_jwe *jwe, 80d4afb5ceSopenharmony_ci uint8_t *cek, uint8_t *aad, int aad_len); 81d4afb5ceSopenharmony_ci 82d4afb5ceSopenharmony_ciint 83d4afb5ceSopenharmony_cilws_jwe_auth_and_decrypt_ecdh_cbc_hs(struct lws_jwe *jwe, 84d4afb5ceSopenharmony_ci char *temp, int *temp_len); 85d4afb5ceSopenharmony_ci 86d4afb5ceSopenharmony_ciint 87d4afb5ceSopenharmony_cilws_jwe_encrypt_ecdh_cbc_hs(struct lws_jwe *jwe, 88d4afb5ceSopenharmony_ci char *temp, int *temp_len); 89