X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fencode_server.cc;h=8db3f867cc09f34fe97e4f040c1e576f123070a0;hb=143cfcf6c9e8c0a0879652d0d741ec268e8d9541;hp=5884df09aae9642ccea356b640a9d4491ef4fa3e;hpb=f515b8daea9d28200be803bb64ff17e9f30343c4;p=dcpomatic.git 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, struct timeval& after_read, struct timeval& after_encode) { + Socket::ReadDigestScope ds (socket); + uint32_t length = socket->read_uint32 (); scoped_array buffer (new char[length]); socket->read (reinterpret_cast (buffer.get()), length); @@ -139,6 +141,10 @@ EncodeServer::process (shared_ptr socket, struct timeval& after_read, st shared_ptr 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, 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) {