aboutsummaryrefslogtreecommitdiffstats
path: root/executor
diff options
context:
space:
mode:
Diffstat (limited to 'executor')
-rw-r--r--executor/executor_runner.h16
1 files changed, 16 insertions, 0 deletions
diff --git a/executor/executor_runner.h b/executor/executor_runner.h
index a3b668893..88fc785db 100644
--- a/executor/executor_runner.h
+++ b/executor/executor_runner.h
@@ -629,9 +629,24 @@ private:
failmsg("bad restarting", "restarting=%d", restarting_);
}
+ // Implementation must match that in pkg/rpcserver/rpcserver.go.
+ uint64 HashAuthCookie(uint64 cookie)
+ {
+ const uint64_t prime1 = 73856093;
+ const uint64_t prime2 = 83492791;
+
+ return (cookie * prime1) ^ prime2;
+ }
+
int Handshake()
{
+ // Handshake stage 0: get a cookie from the manager.
+ rpc::ConnectHelloRawT conn_hello;
+ conn_.Recv(conn_hello);
+
+ // Handshake stage 1: share basic information about the client.
rpc::ConnectRequestRawT conn_req;
+ conn_req.cookie = HashAuthCookie(conn_hello.cookie);
conn_req.id = vm_index_;
conn_req.arch = GOARCH;
conn_req.git_revision = GIT_REVISION;
@@ -656,6 +671,7 @@ private:
if (conn_reply.cover)
max_signal_.emplace();
+ // Handshake stage 2: share information requested by the manager.
rpc::InfoRequestRawT info_req;
info_req.files = ReadFiles(conn_reply.files);