mirror of
https://github.com/Chia-Network/chia-blockchain.git
synced 2024-11-13 03:12:24 +03:00
96 lines
3.8 KiB
Python
96 lines
3.8 KiB
Python
from typing import Callable, Dict, List
|
|
|
|
from chia.farmer.farmer import Farmer
|
|
from chia.util.byte_types import hexstr_to_bytes
|
|
from chia.util.ws_message import WsRpcMessage, create_payload_dict
|
|
|
|
|
|
class FarmerRpcApi:
|
|
def __init__(self, farmer: Farmer):
|
|
self.service = farmer
|
|
self.service_name = "chia_farmer"
|
|
|
|
def get_routes(self) -> Dict[str, Callable]:
|
|
return {
|
|
"/get_signage_point": self.get_signage_point,
|
|
"/get_signage_points": self.get_signage_points,
|
|
"/get_reward_targets": self.get_reward_targets,
|
|
"/set_reward_targets": self.set_reward_targets,
|
|
}
|
|
|
|
async def _state_changed(self, change: str, change_data: Dict) -> List[WsRpcMessage]:
|
|
if change == "new_signage_point":
|
|
sp_hash = change_data["sp_hash"]
|
|
data = await self.get_signage_point({"sp_hash": sp_hash.hex()})
|
|
return [
|
|
create_payload_dict(
|
|
"new_signage_point",
|
|
data,
|
|
self.service_name,
|
|
"wallet_ui",
|
|
)
|
|
]
|
|
elif change == "new_farming_info":
|
|
return [
|
|
create_payload_dict(
|
|
"new_farming_info",
|
|
change_data,
|
|
self.service_name,
|
|
"wallet_ui",
|
|
)
|
|
]
|
|
return []
|
|
|
|
async def get_signage_point(self, request: Dict) -> Dict:
|
|
sp_hash = hexstr_to_bytes(request["sp_hash"])
|
|
for _, sps in self.service.sps.items():
|
|
for sp in sps:
|
|
if sp.challenge_chain_sp == sp_hash:
|
|
pospaces = self.service.proofs_of_space.get(sp.challenge_chain_sp, [])
|
|
return {
|
|
"signage_point": {
|
|
"challenge_hash": sp.challenge_hash,
|
|
"challenge_chain_sp": sp.challenge_chain_sp,
|
|
"reward_chain_sp": sp.reward_chain_sp,
|
|
"difficulty": sp.difficulty,
|
|
"sub_slot_iters": sp.sub_slot_iters,
|
|
"signage_point_index": sp.signage_point_index,
|
|
},
|
|
"proofs": pospaces,
|
|
}
|
|
raise ValueError(f"Signage point {sp_hash.hex()} not found")
|
|
|
|
async def get_signage_points(self, _: Dict) -> Dict:
|
|
result: List = []
|
|
for _, sps in self.service.sps.items():
|
|
for sp in sps:
|
|
pospaces = self.service.proofs_of_space.get(sp.challenge_chain_sp, [])
|
|
result.append(
|
|
{
|
|
"signage_point": {
|
|
"challenge_hash": sp.challenge_hash,
|
|
"challenge_chain_sp": sp.challenge_chain_sp,
|
|
"reward_chain_sp": sp.reward_chain_sp,
|
|
"difficulty": sp.difficulty,
|
|
"sub_slot_iters": sp.sub_slot_iters,
|
|
"signage_point_index": sp.signage_point_index,
|
|
},
|
|
"proofs": pospaces,
|
|
}
|
|
)
|
|
return {"signage_points": result}
|
|
|
|
async def get_reward_targets(self, request: Dict) -> Dict:
|
|
search_for_private_key = request["search_for_private_key"]
|
|
return self.service.get_reward_targets(search_for_private_key)
|
|
|
|
async def set_reward_targets(self, request: Dict) -> Dict:
|
|
farmer_target, pool_target = None, None
|
|
if "farmer_target" in request:
|
|
farmer_target = request["farmer_target"]
|
|
if "pool_target" in request:
|
|
pool_target = request["pool_target"]
|
|
|
|
self.service.set_reward_targets(farmer_target, pool_target)
|
|
return {}
|