1e1051a39Sopenharmony_ci/* 2e1051a39Sopenharmony_ci * Copyright 2015-2020 The OpenSSL Project Authors. All Rights Reserved. 3e1051a39Sopenharmony_ci * 4e1051a39Sopenharmony_ci * Licensed under the Apache License 2.0 (the "License"). You may not use 5e1051a39Sopenharmony_ci * this file except in compliance with the License. You can obtain a copy 6e1051a39Sopenharmony_ci * in the file LICENSE in the source distribution or at 7e1051a39Sopenharmony_ci * https://www.openssl.org/source/license.html 8e1051a39Sopenharmony_ci */ 9e1051a39Sopenharmony_ci 10e1051a39Sopenharmony_ci/* 11e1051a39Sopenharmony_ci * MD5 and SHA-1 low level APIs are deprecated for public use, but still ok for 12e1051a39Sopenharmony_ci * internal use. 13e1051a39Sopenharmony_ci */ 14e1051a39Sopenharmony_ci#include "internal/deprecated.h" 15e1051a39Sopenharmony_ci 16e1051a39Sopenharmony_ci#include <string.h> 17e1051a39Sopenharmony_ci#include "prov/md5_sha1.h" 18e1051a39Sopenharmony_ci#include <openssl/evp.h> 19e1051a39Sopenharmony_ci 20e1051a39Sopenharmony_ciint ossl_md5_sha1_init(MD5_SHA1_CTX *mctx) 21e1051a39Sopenharmony_ci{ 22e1051a39Sopenharmony_ci if (!MD5_Init(&mctx->md5)) 23e1051a39Sopenharmony_ci return 0; 24e1051a39Sopenharmony_ci return SHA1_Init(&mctx->sha1); 25e1051a39Sopenharmony_ci} 26e1051a39Sopenharmony_ci 27e1051a39Sopenharmony_ciint ossl_md5_sha1_update(MD5_SHA1_CTX *mctx, const void *data, size_t count) 28e1051a39Sopenharmony_ci{ 29e1051a39Sopenharmony_ci if (!MD5_Update(&mctx->md5, data, count)) 30e1051a39Sopenharmony_ci return 0; 31e1051a39Sopenharmony_ci return SHA1_Update(&mctx->sha1, data, count); 32e1051a39Sopenharmony_ci} 33e1051a39Sopenharmony_ci 34e1051a39Sopenharmony_ciint ossl_md5_sha1_final(unsigned char *md, MD5_SHA1_CTX *mctx) 35e1051a39Sopenharmony_ci{ 36e1051a39Sopenharmony_ci if (!MD5_Final(md, &mctx->md5)) 37e1051a39Sopenharmony_ci return 0; 38e1051a39Sopenharmony_ci return SHA1_Final(md + MD5_DIGEST_LENGTH, &mctx->sha1); 39e1051a39Sopenharmony_ci} 40e1051a39Sopenharmony_ci 41e1051a39Sopenharmony_ciint ossl_md5_sha1_ctrl(MD5_SHA1_CTX *mctx, int cmd, int mslen, void *ms) 42e1051a39Sopenharmony_ci{ 43e1051a39Sopenharmony_ci unsigned char padtmp[48]; 44e1051a39Sopenharmony_ci unsigned char md5tmp[MD5_DIGEST_LENGTH]; 45e1051a39Sopenharmony_ci unsigned char sha1tmp[SHA_DIGEST_LENGTH]; 46e1051a39Sopenharmony_ci 47e1051a39Sopenharmony_ci if (cmd != EVP_CTRL_SSL3_MASTER_SECRET) 48e1051a39Sopenharmony_ci return -2; 49e1051a39Sopenharmony_ci 50e1051a39Sopenharmony_ci if (mctx == NULL) 51e1051a39Sopenharmony_ci return 0; 52e1051a39Sopenharmony_ci 53e1051a39Sopenharmony_ci /* SSLv3 client auth handling: see RFC-6101 5.6.8 */ 54e1051a39Sopenharmony_ci if (mslen != 48) 55e1051a39Sopenharmony_ci return 0; 56e1051a39Sopenharmony_ci 57e1051a39Sopenharmony_ci /* At this point hash contains all handshake messages, update 58e1051a39Sopenharmony_ci * with master secret and pad_1. 59e1051a39Sopenharmony_ci */ 60e1051a39Sopenharmony_ci 61e1051a39Sopenharmony_ci if (ossl_md5_sha1_update(mctx, ms, mslen) <= 0) 62e1051a39Sopenharmony_ci return 0; 63e1051a39Sopenharmony_ci 64e1051a39Sopenharmony_ci /* Set padtmp to pad_1 value */ 65e1051a39Sopenharmony_ci memset(padtmp, 0x36, sizeof(padtmp)); 66e1051a39Sopenharmony_ci 67e1051a39Sopenharmony_ci if (!MD5_Update(&mctx->md5, padtmp, sizeof(padtmp))) 68e1051a39Sopenharmony_ci return 0; 69e1051a39Sopenharmony_ci 70e1051a39Sopenharmony_ci if (!MD5_Final(md5tmp, &mctx->md5)) 71e1051a39Sopenharmony_ci return 0; 72e1051a39Sopenharmony_ci 73e1051a39Sopenharmony_ci if (!SHA1_Update(&mctx->sha1, padtmp, 40)) 74e1051a39Sopenharmony_ci return 0; 75e1051a39Sopenharmony_ci 76e1051a39Sopenharmony_ci if (!SHA1_Final(sha1tmp, &mctx->sha1)) 77e1051a39Sopenharmony_ci return 0; 78e1051a39Sopenharmony_ci 79e1051a39Sopenharmony_ci /* Reinitialise context */ 80e1051a39Sopenharmony_ci 81e1051a39Sopenharmony_ci if (!ossl_md5_sha1_init(mctx)) 82e1051a39Sopenharmony_ci return 0; 83e1051a39Sopenharmony_ci 84e1051a39Sopenharmony_ci if (ossl_md5_sha1_update(mctx, ms, mslen) <= 0) 85e1051a39Sopenharmony_ci return 0; 86e1051a39Sopenharmony_ci 87e1051a39Sopenharmony_ci /* Set padtmp to pad_2 value */ 88e1051a39Sopenharmony_ci memset(padtmp, 0x5c, sizeof(padtmp)); 89e1051a39Sopenharmony_ci 90e1051a39Sopenharmony_ci if (!MD5_Update(&mctx->md5, padtmp, sizeof(padtmp))) 91e1051a39Sopenharmony_ci return 0; 92e1051a39Sopenharmony_ci 93e1051a39Sopenharmony_ci if (!MD5_Update(&mctx->md5, md5tmp, sizeof(md5tmp))) 94e1051a39Sopenharmony_ci return 0; 95e1051a39Sopenharmony_ci 96e1051a39Sopenharmony_ci if (!SHA1_Update(&mctx->sha1, padtmp, 40)) 97e1051a39Sopenharmony_ci return 0; 98e1051a39Sopenharmony_ci 99e1051a39Sopenharmony_ci if (!SHA1_Update(&mctx->sha1, sha1tmp, sizeof(sha1tmp))) 100e1051a39Sopenharmony_ci return 0; 101e1051a39Sopenharmony_ci 102e1051a39Sopenharmony_ci /* Now when ctx is finalised it will return the SSL v3 hash value */ 103e1051a39Sopenharmony_ci 104e1051a39Sopenharmony_ci OPENSSL_cleanse(md5tmp, sizeof(md5tmp)); 105e1051a39Sopenharmony_ci OPENSSL_cleanse(sha1tmp, sizeof(sha1tmp)); 106e1051a39Sopenharmony_ci 107e1051a39Sopenharmony_ci return 1; 108e1051a39Sopenharmony_ci} 109