izumi.r2.idealingua.test.generated.PrivateTestServiceServer.scala Maven / Gradle / Ivy
package izumi.r2.idealingua.test.generated
import io.circe.*
import io.circe.generic.semiauto.*
import io.circe.syntax.*
import izumi.functional.bio.IO2 as IRTIO2
import izumi.idealingua.runtime.rpc.*
trait PrivateTestServiceServer[Or[+_, +_], C] {
type Just[+T] = Or[Nothing, T]
def test(ctx: C, str: String): Just[String]
}
trait PrivateTestServiceClient[Or[+_, +_]] {
type Just[+T] = Or[Nothing, T]
def test(str: String): Just[String]
}
class PrivateTestServiceWrappedClient[Or[+_, +_]: IRTIO2](_dispatcher: IRTDispatcher[Or]) extends PrivateTestServiceClient[Or] {
final val _F: IRTIO2[Or] = implicitly
import izumi.r2.idealingua.test.generated.PrivateTestService as _M
def test(str: String): Just[String] = {
_F.redeem(_dispatcher.dispatch(IRTMuxRequest(IRTReqBody(new _M.test.Input(str)), _M.test.id)))(
{
err => _F.terminate(err)
},
{
case IRTMuxResponse(IRTResBody(v: _M.test.Output), method) if method == _M.test.id =>
_F.pure(v.value)
case v =>
val id = "PrivateTestService.PrivateTestServiceWrappedClient.test"
val expected = classOf[_M.test.Input].toString
_F.terminate(new IRTTypeMismatchException(s"Unexpected type in $id: $v, expected $expected got ${v.getClass}", v, None))
},
)
}
}
object PrivateTestServiceWrappedClient extends IRTWrappedClient {
val allCodecs: Map[IRTMethodId, IRTCirceMarshaller] = {
Map(PrivateTestService.test.id -> PrivateTestServiceCodecs.test)
}
}
class PrivateTestServiceWrappedServer[Or[+_, +_]: IRTIO2, C](_service: PrivateTestServiceServer[Or, C]) extends IRTWrappedService[Or, C] {
final val _F: IRTIO2[Or] = implicitly
final val serviceId: IRTServiceId = PrivateTestService.serviceId
val allMethods: Map[IRTMethodId, IRTMethodWrapper[Or, C]] = {
Seq[IRTMethodWrapper[Or, C]](test).map(m => m.signature.id -> m).toMap
}
object test extends IRTMethodWrapper[Or, C] {
import PrivateTestService.test.*
val signature: PrivateTestService.test.type = PrivateTestService.test
val marshaller: PrivateTestServiceCodecs.test.type = PrivateTestServiceCodecs.test
def invoke(ctx: C, input: Input): Just[Output] = {
assert(ctx.asInstanceOf[_root_.scala.AnyRef] != null && input.asInstanceOf[_root_.scala.AnyRef] != null)
_F.map(_service.test(ctx, input.str))(v => new Output(v))
}
}
}
object PrivateTestServiceWrappedServer
object PrivateTestService {
final val serviceId: IRTServiceId = IRTServiceId("PrivateTestService")
object test extends IRTMethodSignature {
final val id: IRTMethodId = IRTMethodId(serviceId, IRTMethodName("test"))
type Input = TestInput
type Output = TestOutput
}
final case class TestInput(str: String)
object TestInput {
implicit val encodeTestInput: Encoder.AsObject[TestInput] = deriveEncoder[TestInput]
implicit val decodeTestInput: Decoder[TestInput] = deriveDecoder[TestInput]
}
final case class TestOutput(value: String)
object TestOutput {
implicit val encodeUnwrappedTestOutput: Encoder[TestOutput] = Encoder.instance {
v => v.value.asJson
}
implicit val decodeUnwrappedTestOutput: Decoder[TestOutput] = Decoder.instance {
v => v.as[String].map(d => TestOutput(d))
}
}
}
object PrivateTestServiceCodecs {
object test extends IRTCirceMarshaller {
import PrivateTestService.test.*
def encodeRequest: PartialFunction[IRTReqBody, Json] = {
case IRTReqBody(value: Input) =>
value.asJson
}
def decodeRequest[Or[+_, +_]: IRTIO2]: PartialFunction[IRTJsonBody, Or[DecodingFailure, IRTReqBody]] = {
case IRTJsonBody(m, packet) if m == id =>
this.decoded[Or, IRTReqBody](packet.as[Input].map(v => IRTReqBody(v)))
}
def encodeResponse: PartialFunction[IRTResBody, Json] = {
case IRTResBody(value: Output) =>
value.asJson
}
def decodeResponse[Or[+_, +_]: IRTIO2]: PartialFunction[IRTJsonBody, Or[DecodingFailure, IRTResBody]] = {
case IRTJsonBody(m, packet) if m == id =>
decoded[Or, IRTResBody](packet.as[Output].map(v => IRTResBody(v)))
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy