watchtowerrpc.WatchtowerClient.scala Maven / Gradle / Ivy
The newest version!
// Generated by Pekko gRPC. DO NOT EDIT.
package watchtowerrpc
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 WatchtowerClient extends Watchtower with WatchtowerClientPowerApi with PekkoGrpcClient
@PekkoGrpcGenerated
object WatchtowerClient {
def apply(settings: GrpcClientSettings)(implicit sys: ClassicActorSystemProvider): WatchtowerClient =
new DefaultWatchtowerClient(GrpcChannel(settings), isChannelOwned = true)
def apply(channel: GrpcChannel)(implicit sys: ClassicActorSystemProvider): WatchtowerClient =
new DefaultWatchtowerClient(channel, isChannelOwned = false)
private class DefaultWatchtowerClient(channel: GrpcChannel, isChannelOwned: Boolean)(implicit sys: ClassicActorSystemProvider) extends WatchtowerClient {
import Watchtower.MethodDescriptors._
private implicit val ex: ExecutionContext = sys.classicSystem.dispatcher
private val settings = channel.settings
private val options = NettyClientUtils.callOptions(settings)
private def getInfoRequestBuilder(channel: pekko.grpc.internal.InternalChannel) =
new ScalaUnaryRequestBuilder(getInfoDescriptor, channel, options, settings)
/**
* Lower level "lifted" version of the method, giving access to request metadata etc.
* prefer getInfo(watchtowerrpc.GetInfoRequest) if possible.
*/
override def getInfo(): SingleResponseRequestBuilder[watchtowerrpc.GetInfoRequest, watchtowerrpc.GetInfoResponse] =
getInfoRequestBuilder(channel.internalChannel)
/**
* For access to method metadata use the parameterless version of getInfo
*/
def getInfo(in: watchtowerrpc.GetInfoRequest): scala.concurrent.Future[watchtowerrpc.GetInfoResponse] =
getInfo().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 WatchtowerClientPowerApi {
/**
* Lower level "lifted" version of the method, giving access to request metadata etc.
* prefer getInfo(watchtowerrpc.GetInfoRequest) if possible.
*/
def getInfo(): SingleResponseRequestBuilder[watchtowerrpc.GetInfoRequest, watchtowerrpc.GetInfoResponse] = ???
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy