com.google.protobuf
Interface Service


public interface Service

Abstract base interface for protocol-buffer-based RPC services. Services themselves are abstract classes (implemented either by servers or as stubs), but they subclass this base interface. The methods of this interface can be used to call the methods of the service without knowing its exact type at compile time (analogous to the Message interface).

Starting with version 2.3.0, RPC implementations should not try to build on this, but should instead provide code generator plugins which generate code specific to the particular RPC implementation. This way the generated code can be more appropriate for the implementation in use and can avoid unnecessary layers of indirection.

Author:
[email protected] Kenton Varda

Method Summary
 void callMethod(Descriptors.MethodDescriptor method, RpcController controller, Message request, RpcCallback<Message> done)
          Call a method of the service specified by MethodDescriptor.
 Descriptors.ServiceDescriptor getDescriptorForType()
          Get the ServiceDescriptor describing this service and its methods.
 Message getRequestPrototype(Descriptors.MethodDescriptor method)
          callMethod() requires that the request passed in is of a particular subclass of Message.
 Message getResponsePrototype(Descriptors.MethodDescriptor method)
          Like getRequestPrototype(), but gets a prototype of the response message.
 

Method Detail

getDescriptorForType

Descriptors.ServiceDescriptor getDescriptorForType()
Get the ServiceDescriptor describing this service and its methods.


callMethod

void callMethod(Descriptors.MethodDescriptor method,
                RpcController controller,
                Message request,
                RpcCallback<Message> done)

Call a method of the service specified by MethodDescriptor. This is normally implemented as a simple switch() that calls the standard definitions of the service's methods.

Preconditions:

Postconditions:


getRequestPrototype

Message getRequestPrototype(Descriptors.MethodDescriptor method)

callMethod() requires that the request passed in is of a particular subclass of Message. getRequestPrototype() gets the default instances of this type for a given method. You can then call Message.newBuilderForType() on this instance to construct a builder to build an object which you can then pass to callMethod().

Example:

   MethodDescriptor method =
     service.getDescriptorForType().findMethodByName("Foo");
   Message request =
     stub.getRequestPrototype(method).newBuilderForType()
         .mergeFrom(input).build();
   service.callMethod(method, request, callback);
 


getResponsePrototype

Message getResponsePrototype(Descriptors.MethodDescriptor method)
Like getRequestPrototype(), but gets a prototype of the response message. getResponsePrototype() is generally not needed because the Service implementation constructs the response message itself, but it may be useful in some cases to know ahead of time what type of object will be returned.



Copyright © 2008-2011 Google. All Rights Reserved.