zio.http.netty.ChannelFactories.scala Maven / Gradle / Ivy
The newest version!
/*
* Copyright 2021 - 2023 Sporta Technologies PVT LTD & the ZIO HTTP contributors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package zio.http.netty
import zio._
import zio.stacktracer.TracingImplicits.disableAutoTrace
import io.netty.channel._
import io.netty.channel.embedded.EmbeddedChannel
import io.netty.channel.epoll._
import io.netty.channel.kqueue._
import io.netty.channel.socket.nio._
import io.netty.incubator.channel.uring._
private[netty] object ChannelFactories {
private[zio] def make[A <: Channel](channel: => A)(implicit trace: Trace): UIO[ChannelFactory[A]] =
ZIO.succeed(new ChannelFactory[A] {
override def newChannel(): A = channel
})
private[zio] def serverChannel[A <: ServerChannel](channel: => A)(implicit trace: Trace) =
make[ServerChannel](channel)
private[zio] def clientChannel(channel: => Channel)(implicit trace: Trace) = make(channel)
object Server {
def nio(implicit trace: Trace) = serverChannel(new NioServerSocketChannel())
def epoll(implicit trace: Trace) = serverChannel(new EpollServerSocketChannel())
def uring(implicit trace: Trace) = serverChannel(new IOUringServerSocketChannel())
def kqueue(implicit trace: Trace) = serverChannel(new KQueueServerSocketChannel())
val fromConfig = {
implicit val trace: Trace = Trace.empty
ZLayer.fromZIO {
ZIO.service[ChannelType.Config].flatMap {
_.channelType match {
case ChannelType.NIO => nio
case ChannelType.EPOLL => epoll
case ChannelType.KQUEUE => kqueue
case ChannelType.URING => uring
case ChannelType.AUTO =>
if (Epoll.isAvailable) epoll
else if (KQueue.isAvailable) kqueue
else nio
}
}
}
}
}
object Client {
def nio(implicit trace: Trace) = clientChannel(new NioSocketChannel())
def epoll(implicit trace: Trace) = clientChannel(new EpollSocketChannel())
def kqueue(implicit trace: Trace) = clientChannel(new KQueueSocketChannel())
def uring(implicit trace: Trace) = clientChannel(new IOUringSocketChannel())
def embedded(implicit trace: Trace) = clientChannel(new EmbeddedChannel(false, false))
implicit val trace: Trace = Trace.empty
val live: ZLayer[ChannelType.Config, Nothing, ChannelFactory[Channel]] =
ZLayer.fromZIO {
ZIO.service[ChannelType.Config].flatMap {
_.channelType match {
case ChannelType.NIO => nio
case ChannelType.EPOLL => epoll
case ChannelType.KQUEUE => kqueue
case ChannelType.URING => uring
case ChannelType.AUTO =>
if (Epoll.isAvailable) epoll
else if (KQueue.isAvailable) kqueue
else nio
}
}
}
}
}