summaryrefslogtreecommitdiff
path: root/src/lib/encode_server.cc
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2020-04-16 23:35:02 +0200
committerCarl Hetherington <cth@carlh.net>2020-04-17 00:42:54 +0200
commit1201f316347d2ea8b09aa89b0c5edaebfaa64c93 (patch)
tree5339d7e78357ed48d72d4e48b3c83e6b8681958a /src/lib/encode_server.cc
parent3f2bec7b6ee2f27b2de056cdc0137744d2e9e253 (diff)
Checksum network encode requests and replies to protect against
network corruption (#1381).
Diffstat (limited to 'src/lib/encode_server.cc')
-rw-r--r--src/lib/encode_server.cc7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/lib/encode_server.cc b/src/lib/encode_server.cc
index 5884df09a..8db3f867c 100644
--- a/src/lib/encode_server.cc
+++ b/src/lib/encode_server.cc
@@ -121,6 +121,8 @@ EncodeServer::~EncodeServer ()
int
EncodeServer::process (shared_ptr<Socket> socket, struct timeval& after_read, struct timeval& after_encode)
{
+ Socket::ReadDigestScope ds (socket);
+
uint32_t length = socket->read_uint32 ();
scoped_array<char> buffer (new char[length]);
socket->read (reinterpret_cast<uint8_t*> (buffer.get()), length);
@@ -139,6 +141,10 @@ EncodeServer::process (shared_ptr<Socket> socket, struct timeval& after_read, st
shared_ptr<PlayerVideo> pvf (new PlayerVideo (xml, socket));
+ if (!ds.check()) {
+ throw NetworkError ("Checksums do not match");
+ }
+
DCPVideo dcp_video_frame (pvf, xml);
gettimeofday (&after_read, 0);
@@ -148,6 +154,7 @@ EncodeServer::process (shared_ptr<Socket> socket, struct timeval& after_read, st
gettimeofday (&after_encode, 0);
try {
+ Socket::WriteDigestScope ds (socket);
socket->write (encoded.size());
socket->write (encoded.data().get(), encoded.size());
} catch (std::exception& e) {