services/syncbase: Export the NeighborConnectionTimeout
So that it can be used as an option to the RPC Server that is created to
host the syncbase service.
Without this change, the following could happen:
- Syncbase A and syncbase B discover each other
- Because both have internet connectivity, they have
a connection to the proxy and an endpoint through it
- A and B invoke methods on each other through their
proxied endpoints
- B loses internet connectivity (and correctly connects
to A through some other means such as bluetooth)
- However, when A wants to invoke a method on B,
it ends up trying to re-use the (defunct) proxied
endpoint in its cache instead of the bluetooth
connection.
As a result, changes in B would be propagated to A,
but not the reverse.
With this channel timeout being provided to the server,
A will determine (within 5 seconds) that the proxied
connection is defunct and it should try some other
endpoint instead.
RPC requests to multiple endpoints cannot be sent in
parallel in order to maintain "at most once" semantics
of an RPC invocation. It is possible that this is not
needed for the syncbase/GetDeltas use-case, but that
larger investigation is left as an excercise for the future.
MultiPart: 1/2
Change-Id: If82d4e08066ccca38bd5b0d72ebfcbd22a52981b
diff --git a/impl/google/services/syncbase/jni.go b/impl/google/services/syncbase/jni.go
index 7bab0f0..57d2540 100644
--- a/impl/google/services/syncbase/jni.go
+++ b/impl/google/services/syncbase/jni.go
@@ -12,7 +12,9 @@
"unsafe"
"v.io/v23"
+ "v.io/v23/options"
"v.io/x/ref/services/syncbase/server"
+ "v.io/x/ref/services/syncbase/vsync"
jrpc "v.io/x/jni/impl/google/rpc"
jutil "v.io/x/jni/util"
@@ -105,7 +107,7 @@
return nil
}
d := server.NewDispatcher(service)
- newCtx, s, err := v23.WithNewDispatchingServer(ctx, name, d)
+ newCtx, s, err := v23.WithNewDispatchingServer(ctx, name, d, options.ChannelTimeout(vsync.NeighborConnectionTimeout))
if err != nil {
jutil.JThrowV(env, err)
return nil