mirror of
https://github.com/Retropex/bitfeed.git
synced 2025-05-12 19:20:46 +02:00
73 lines
2.1 KiB
Elixir
73 lines
2.1 KiB
Elixir
require Logger
|
|
|
|
defmodule BitcoinStream.Router do
|
|
use Plug.Router
|
|
|
|
alias BitcoinStream.BlockData, as: BlockData
|
|
alias BitcoinStream.Protocol.Transaction, as: BitcoinTx
|
|
alias BitcoinStream.RPC, as: RPC
|
|
|
|
plug Corsica, origins: "*", allow_headers: :all
|
|
plug Plug.Static,
|
|
at: "/",
|
|
from: :bitcoin_stream
|
|
plug :match
|
|
plug Plug.Parsers,
|
|
parsers: [:json],
|
|
pass: ["application/json", "text/plain"],
|
|
json_decoder: Jason
|
|
plug :dispatch
|
|
|
|
match "/api/block/:hash" do
|
|
case get_block(hash) do
|
|
{:ok, block} ->
|
|
put_resp_header(conn, "cache-control", "public, max-age=604800, immutable")
|
|
|> send_resp(200, block)
|
|
_ ->
|
|
Logger.debug("Error getting block hash");
|
|
send_resp(conn, 404, "Block not available")
|
|
end
|
|
end
|
|
|
|
match "/api/tx/:hash" do
|
|
case get_tx(hash) do
|
|
{:ok, tx} ->
|
|
put_resp_header(conn, "cache-control", "public, max-age=604800, immutable")
|
|
|> send_resp(200, tx)
|
|
_ ->
|
|
Logger.debug("Error getting tx hash");
|
|
send_resp(conn, 404, "Transaction not found")
|
|
end
|
|
end
|
|
|
|
match _ do
|
|
send_resp(conn, 404, "Not found")
|
|
end
|
|
|
|
defp get_block(last_seen) do
|
|
last_id = BlockData.get_block_id(:block_data);
|
|
cond do
|
|
(last_seen == last_id) ->
|
|
payload = BlockData.get_json_block(:block_data);
|
|
{:ok, payload}
|
|
true -> :err
|
|
end
|
|
end
|
|
|
|
defp get_tx(txid) do
|
|
with {:ok, 200, verbosetx} <- RPC.request(:rpc, "getrawtransaction", [txid, true]),
|
|
%{"hex" => hex, "blockhash" => blockhash} <- Map.merge(%{"blockhash" => nil}, verbosetx),
|
|
{:ok, 200, %{"height" => height, "time" => time}} <- (if blockhash != nil do RPC.request(:rpc, "getblockheader", [blockhash, true]) else {:ok, 200, %{"height" => nil, "time" => nil}} end),
|
|
rawtx <- Base.decode16!(hex, case: :lower),
|
|
{:ok, txn } <- BitcoinTx.decode(rawtx),
|
|
inflated_txn <- BitcoinTx.inflate(txn, false),
|
|
{:ok, payload} <- Jason.encode(%{tx: inflated_txn, blockheight: height, blockhash: blockhash, time: time}) do
|
|
{:ok, payload}
|
|
else
|
|
err ->
|
|
IO.inspect(err);
|
|
:err
|
|
end
|
|
end
|
|
end
|