File: MetadataValueAesCcmEncryptedKey.h

package info (click to toggle)
sleuthkit 4.14.0%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 19,268 kB
  • sloc: ansic: 143,839; cpp: 54,644; java: 39,009; xml: 2,417; python: 1,085; perl: 874; makefile: 451; sh: 196
file content (43 lines) | stat: -rw-r--r-- 1,284 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
/*
 ** The Sleuth Kit
 **
 ** Brian Carrier [carrier <at> sleuthkit [dot] org]
 ** Copyright (c) 2024 Sleuth Kit Labs, LLC. All Rights reserved
 ** Copyright (c) 2010-2021 Brian Carrier.  All Rights reserved
 **
 ** This software is distributed under the Common Public License 1.0
 */

#pragma once

#ifdef HAVE_LIBMBEDTLS

#include "MetadataValue.h"
#include "mbedtls/aes.h"

#define BITLOCKER_KEY_MAC_LEN 16
#define BITLOCKER_DECRYPT_KEY_BLOCK_SIZE 16

class MetadataValueAesCcmEncryptedKey : public MetadataValue {
public:
	MetadataValueAesCcmEncryptedKey(BITLOCKER_METADATA_VALUE_TYPE valueType, uint8_t* buf, size_t bufLen);

	BITLOCKER_STATUS decrypt(uint8_t* key, size_t keyLen, MetadataEntry** keyEntry);

	~MetadataValueAesCcmEncryptedKey();
private:
	BITLOCKER_STATUS decryptKey(uint8_t* key, size_t keyLen, uint8_t* encryptedData, size_t encryptedDataLen, uint8_t* decryptedData);

	int createMessageAuthenticationCode(mbedtls_aes_context* aes_context, uint8_t* nonce, uint8_t nonceLen, uint8_t* data, size_t dataLen, uint8_t* mac);

	const size_t m_headerLen = 12;

	uint64_t m_nonceTimestamp = 0;
	uint32_t m_nonceCounter = 0;
	const static size_t m_nonceLen = 12;
	uint8_t m_nonce[m_nonceLen];
	size_t m_encryptedDataLen = 0;
	uint8_t* m_encryptedData = NULL;
};

#endif