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.
39 lines
1.3 KiB
39 lines
1.3 KiB
package com.xsn.explorer.services
|
|
|
|
import javax.inject.Inject
|
|
|
|
import com.alexitc.playsonify.core.FutureOr.Implicits.{FutureOps, OrOps}
|
|
import com.alexitc.playsonify.core.{ApplicationResult, FutureApplicationResult}
|
|
import com.xsn.explorer.errors.AddressFormatError
|
|
import com.xsn.explorer.models.{Address, AddressDetails}
|
|
import org.scalactic.{One, Or}
|
|
import play.api.libs.json.JsValue
|
|
|
|
import scala.concurrent.ExecutionContext
|
|
|
|
class AddressService @Inject() (xsnService: XSNService)(implicit ec: ExecutionContext) {
|
|
|
|
def getDetails(addressString: String): FutureApplicationResult[AddressDetails] = {
|
|
val result = for {
|
|
address <- getAddress(addressString).toFutureOr
|
|
balance <- xsnService.getAddressBalance(address).toFutureOr
|
|
transactions <- xsnService.getTransactions(address).toFutureOr
|
|
} yield AddressDetails(balance, transactions)
|
|
|
|
result.toFuture
|
|
}
|
|
|
|
def getUnspentOutputs(addressString: String): FutureApplicationResult[JsValue] = {
|
|
val result = for {
|
|
address <- getAddress(addressString).toFutureOr
|
|
outputs <- xsnService.getUnspentOutputs(address).toFutureOr
|
|
} yield outputs
|
|
|
|
result.toFuture
|
|
}
|
|
|
|
private def getAddress(addressString: String): ApplicationResult[Address] = {
|
|
val maybe = Address.from(addressString)
|
|
Or.from(maybe, One(AddressFormatError))
|
|
}
|
|
}
|
|
|