Packages

o

com.twitter.finagle.thrift

ThriftServiceIface

object ThriftServiceIface

Construct Service interface for a Thrift method.

There are two ways to use a Scrooge-generated Thrift Service with Finagle:

1. Using a Service interface, i.e. a collection of Finagle Services.

2. Using a method interface, i.e. a collection of methods returning Futures.

Example: for a Thrift service IDL:

service Logger {
  string log(1: string message, 2: i32 logLevel);
  i32 getLogSize();
}

the Service interface, or ServiceIface, is

trait LoggerServiceIface {
  val log: com.twitter.finagle.Service[Logger.Log.Args, Logger.Log.SuccessType]
  val getLogSize: com.twitter.finagle.Service[Logger.GetLogSize.Args, Logger.GetLogSize.SuccessType]
}

and the method interface, or MethodIface, is

trait Logger[Future] {
  def log(message: String, logLevel: Int): Future[String]
  def getLogSize(): Future[Int]
}

Service interfaces can be modified and composed with Finagle Filters.

Linear Supertypes
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. ThriftServiceIface
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Type Members

  1. type Filterable[+T] = service.Filterable[T]
    Annotations
    @deprecated
    Deprecated

    (Since version 2017-11-06) Use com.twitter.finagle.thrift.service.Filterable

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. def apply(method: ThriftMethod, thriftService: Service[ThriftClientRequest, Array[Byte]], pf: TProtocolFactory, stats: StatsReceiver): Service[Args, SuccessType]
  5. def apply(method: ThriftMethod, thriftService: Service[ThriftClientRequest, Array[Byte]], clientParam: RichClientParam): Service[Args, SuccessType]

    Build a Service from a given Thrift method.

  6. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  7. def clone(): AnyRef
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @native() @throws( ... )
  8. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  9. def equals(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  10. def finalize(): Unit
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  11. final def getClass(): Class[_]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  12. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  13. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  14. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  15. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  16. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  17. def resultFilter(method: ThriftMethod): Filter[Args, SuccessType, Args, Result]
  18. final def synchronized[T0](arg0: ⇒ T0): T0
    Definition Classes
    AnyRef
  19. def toString(): String
    Definition Classes
    AnyRef → Any
  20. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  21. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  22. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @native() @throws( ... )

Deprecated Value Members

  1. def apply(method: ThriftMethod, thriftService: Service[ThriftClientRequest, Array[Byte]], pf: TProtocolFactory, stats: StatsReceiver, responseClassifier: ResponseClassifier): Service[Args, SuccessType]
    Annotations
    @deprecated
    Deprecated

    (Since version 2017-08-16) Use com.twitter.finagle.thrift.RichClientParam

Inherited from AnyRef

Inherited from Any

Ungrouped