forked from IntelRealSense/RealSenseID
-
Notifications
You must be signed in to change notification settings - Fork 0
/
SecureHostSession.h
82 lines (69 loc) · 2.99 KB
/
SecureHostSession.h
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
// License: Apache 2.0. See LICENSE file in root directory.
// Copyright(c) 2020-2021 Intel Corporation. All Rights Reserved.
#pragma once
#include "SerialConnection.h"
#include "SerialPacket.h"
#include "CommonTypes.h"
#include "Timer.h"
#include "MbedtlsWrapper.h"
#include <mutex>
// Thread safe secure session manager. sends/receive packets with encryption.
// Session starts on Start(serial_connection*) and ends in destruction.
// Note:
// This class is not responsible for opening/closing the serial connection. It only uses the given one.
namespace RealSenseID
{
namespace PacketManager
{
using SignCallback = std::function<bool(const unsigned char*, const unsigned int, unsigned char*)>;
using VerifyCallback =
std::function<bool(const unsigned char*, const unsigned int, const unsigned char*, const unsigned int)>;
class SecureHostSession
{
public:
SecureHostSession(SignCallback signCallback, VerifyCallback verifyCallback);
~SecureHostSession();
SecureHostSession(const SecureHostSession&) = delete;
SecureHostSession& operator=(const SecureHostSession&) = delete;
// start the session using the given (already open) serial connection.
// return Status::Ok on success, or error Status otherwise.
SerialStatus Start(SerialConnection* serial_conn);
// return true if session is open
bool IsOpen();
// send packet
// return Status::Ok on success, or error status otherwise.
SerialStatus SendPacket(SerialPacket& packet);
// wait for any packet until timeout.
// decrypt the packet.
// fill the given packet with the decrypted received packet packet.
// return Status::Ok on success, or error status otherwise.
SerialStatus RecvPacket(SerialPacket& packet);
// wait for fa packet until timeout.
// decrypt the packet.
// fill the given packet with the received fa packet.
// if no fa packet available, return timeout status.
// if the wrong packet type arrives, return RecvUnexpectedPacket status.
// return Status::Ok on success, or error status otherwise.
SerialStatus RecvFaPacket(FaPacket& packet);
// wait for data packet until timeout.
// decrypt the packet.
// fill the given packet with the received data packet.
// if no data packet available, return timeout status.
// if the wrong packet type arrives, return RecvUnexpectedPacket status.
// return Status::Ok on success, or error status otherwise.
SerialStatus RecvDataPacket(DataPacket& packet);
static SerialStatus SwitchToBinary(SerialConnection* serial_conn, const char* bincommand);
private:
SerialConnection* _serial = nullptr;
uint32_t _last_sent_seq_number = 0;
uint32_t _last_recv_seq_number = 0;
SignCallback _sign_callback;
VerifyCallback _verify_callback;
MbedtlsWrapper _crypto_wrapper;
bool _is_open = false;
std::mutex _mutex;
SerialStatus SendPacketImpl(SerialPacket& packet);
SerialStatus RecvPacketImpl(SerialPacket& packet);
};
} // namespace PacketManager
} // namespace RealSenseID