Browse Source

server: Add endpoint: "GET /blocks/:query/raw"

scalafmt-draft
Alexis Hernandez 7 years ago
parent
commit
0f5687c5b9
  1. 22
      server/app/com/xsn/explorer/services/BlockService.scala
  2. 7
      server/app/controllers/BlocksController.scala
  3. 1
      server/conf/routes
  4. 35
      server/test/controllers/BlocksControllerSpec.scala

22
server/app/com/xsn/explorer/services/BlockService.scala

@ -9,6 +9,7 @@ import com.xsn.explorer.models._
import com.xsn.explorer.models.rpc.{Block, TransactionVIN} import com.xsn.explorer.models.rpc.{Block, TransactionVIN}
import com.xsn.explorer.services.logic.{BlockLogic, TransactionLogic} import com.xsn.explorer.services.logic.{BlockLogic, TransactionLogic}
import org.scalactic.Good import org.scalactic.Good
import play.api.libs.json.JsValue
import scala.concurrent.{ExecutionContext, Future} import scala.concurrent.{ExecutionContext, Future}
@ -18,6 +19,27 @@ class BlockService @Inject() (
transactionLogic: TransactionLogic)( transactionLogic: TransactionLogic)(
implicit ec: ExecutionContext) { implicit ec: ExecutionContext) {
def getRawBlock(blockhashString: String): FutureApplicationResult[JsValue] = {
val result = for {
blockhash <- blockLogic
.getBlockhash(blockhashString)
.toFutureOr
block <- xsnService.getRawBlock(blockhash).toFutureOr
} yield block
result.toFuture
}
def getRawBlock(height: Height): FutureApplicationResult[JsValue] = {
val result = for {
blockhash <- xsnService.getBlockhash(height).toFutureOr
block <- xsnService.getRawBlock(blockhash).toFutureOr
} yield block
result.toFuture
}
def getDetails(blockhashString: String): FutureApplicationResult[BlockDetails] = { def getDetails(blockhashString: String): FutureApplicationResult[BlockDetails] = {
val result = for { val result = for {
blockhash <- blockLogic blockhash <- blockLogic

7
server/app/controllers/BlocksController.scala

@ -28,4 +28,11 @@ class BlocksController @Inject() (
.map(blockService.getDetails) .map(blockService.getDetails)
.getOrElse(blockService.getDetails(query)) .getOrElse(blockService.getDetails(query))
} }
def getRawBlock(query: String) = publicNoInput { _ =>
Try(query.toInt)
.map(Height.apply)
.map(blockService.getRawBlock)
.getOrElse(blockService.getRawBlock(query))
}
} }

1
server/conf/routes

@ -12,6 +12,7 @@ GET /addresses/:address controllers.AddressesController.getDetails(address:
GET /blocks controllers.BlocksController.getLatestBlocks() GET /blocks controllers.BlocksController.getLatestBlocks()
GET /blocks/:query controllers.BlocksController.getDetails(query: String) GET /blocks/:query controllers.BlocksController.getDetails(query: String)
GET /blocks/:query/raw controllers.BlocksController.getRawBlock(query: String)
GET /stats controllers.StatisticsController.getStatus() GET /stats controllers.StatisticsController.getStatus()

35
server/test/controllers/BlocksControllerSpec.scala

@ -60,6 +60,17 @@ class BlocksControllerSpec extends MyAPISpec {
Future.successful(result) Future.successful(result)
} }
override def getRawBlock(blockhash: Blockhash): FutureApplicationResult[JsValue] = {
val result = blocks.get(blockhash)
.map { _ => BlockLoader.json(blockhash.string) }
.map(Good(_))
.getOrElse {
Bad(BlockNotFoundError).accumulating
}
Future.successful(result)
}
override def getBlockhash(height: Height): FutureApplicationResult[Blockhash] = { override def getBlockhash(height: Height): FutureApplicationResult[Blockhash] = {
val result = blocks val result = blocks
.values .values
@ -359,4 +370,28 @@ class BlocksControllerSpec extends MyAPISpec {
(error \ "message").as[String].nonEmpty mustEqual true (error \ "message").as[String].nonEmpty mustEqual true
} }
} }
"GET /blocks/:query/raw" should {
def url(query: String) = s"/blocks/$query/raw"
"retrieve a block by blockhash" in {
val block = posBlock
val response = GET(url(block.hash.string))
status(response) mustEqual OK
val json = contentAsJson(response)
json mustEqual BlockLoader.json(block.hash.string)
}
"retrieve a block by height" in {
val block = posBlock
val response = GET(url(block.height.toString))
status(response) mustEqual OK
val json = contentAsJson(response)
json mustEqual BlockLoader.json(block.hash.string)
}
}
} }

Loading…
Cancel
Save