devrpc.DevClient.scala Maven / Gradle / Ivy
The newest version!
// Generated by Pekko gRPC. DO NOT EDIT.
package devrpc
import scala.concurrent.ExecutionContext
import org.apache.pekko
import pekko.actor.ClassicActorSystemProvider
import pekko.grpc.GrpcChannel
import pekko.grpc.GrpcClientCloseException
import pekko.grpc.GrpcClientSettings
import pekko.grpc.scaladsl.PekkoGrpcClient
import pekko.grpc.internal.NettyClientUtils
import pekko.grpc.PekkoGrpcGenerated
import pekko.grpc.scaladsl.SingleResponseRequestBuilder
import pekko.grpc.internal.ScalaUnaryRequestBuilder
// Not sealed so users can extend to write their stubs
@PekkoGrpcGenerated
trait DevClient extends Dev with DevClientPowerApi with PekkoGrpcClient
@PekkoGrpcGenerated
object DevClient {
def apply(settings: GrpcClientSettings)(implicit sys: ClassicActorSystemProvider): DevClient =
new DefaultDevClient(GrpcChannel(settings), isChannelOwned = true)
def apply(channel: GrpcChannel)(implicit sys: ClassicActorSystemProvider): DevClient =
new DefaultDevClient(channel, isChannelOwned = false)
private class DefaultDevClient(channel: GrpcChannel, isChannelOwned: Boolean)(implicit sys: ClassicActorSystemProvider) extends DevClient {
import Dev.MethodDescriptors._
private implicit val ex: ExecutionContext = sys.classicSystem.dispatcher
private val settings = channel.settings
private val options = NettyClientUtils.callOptions(settings)
private def importGraphRequestBuilder(channel: pekko.grpc.internal.InternalChannel) =
new ScalaUnaryRequestBuilder(importGraphDescriptor, channel, options, settings)
/**
* Lower level "lifted" version of the method, giving access to request metadata etc.
* prefer importGraph(lnrpc.ChannelGraph) if possible.
*/
override def importGraph(): SingleResponseRequestBuilder[lnrpc.ChannelGraph, devrpc.ImportGraphResponse] =
importGraphRequestBuilder(channel.internalChannel)
/**
* For access to method metadata use the parameterless version of importGraph
*/
def importGraph(in: lnrpc.ChannelGraph): scala.concurrent.Future[devrpc.ImportGraphResponse] =
importGraph().invoke(in)
override def close(): scala.concurrent.Future[pekko.Done] =
if (isChannelOwned) channel.close()
else throw new GrpcClientCloseException()
override def closed: scala.concurrent.Future[pekko.Done] = channel.closed()
}
}
@PekkoGrpcGenerated
trait DevClientPowerApi {
/**
* Lower level "lifted" version of the method, giving access to request metadata etc.
* prefer importGraph(lnrpc.ChannelGraph) if possible.
*/
def importGraph(): SingleResponseRequestBuilder[lnrpc.ChannelGraph, devrpc.ImportGraphResponse] = ???
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy