You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

55 lines
1.5 KiB

package com.xsn.explorer.util
import com.alexitc.playsonify.core.FutureOr
import com.alexitc.playsonify.models.ApplicationError
import org.scalactic.{Bad, Good, One}
import scala.concurrent.{ExecutionContext, Future}
object Extensions {
private val SatoshiScale = 100000000L
implicit class BigDecimalExt(val inner: BigDecimal) extends AnyVal {
def fromSatoshis: BigDecimal = {
inner / SatoshiScale
}
def toSatoshis: BigInt = {
(inner * SatoshiScale).toBigInt()
}
}
implicit class ListOptionExt[+A](val inner: List[Option[A]]) extends AnyVal {
def everything: Option[List[A]] = {
if (inner.forall(_.isDefined)) {
Some(inner.flatten)
} else {
None
}
}
}
implicit class FutureOrExt[+A](val inner: FutureOr[A]) {
def recoverFrom[B >: A](error: ApplicationError)(f: => B)(implicit ec: ExecutionContext): FutureOr[B] = {
val future = inner.toFuture.map {
case Good(result) => Good(result)
case Bad(One(e)) if e == error => Good(f)
case Bad(errors) => Bad(errors)
}
new FutureOr(future)
}
def recoverWith[B >: A](error: ApplicationError)(f: => FutureOr[B])(implicit ec: ExecutionContext): FutureOr[B] = {
val future = inner.toFuture.flatMap {
case Good(result) => Future.successful(Good(result))
case Bad(One(e)) if e == error => f.toFuture
case Bad(errors) => Future.successful(Bad(errors))
}
new FutureOr(future)
}
}
}