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