forked from lthn/blockchain
186 lines
9.3 KiB
Python
186 lines
9.3 KiB
Python
|
|
# coding: utf-8
|
||
|
|
|
||
|
|
"""
|
||
|
|
Lethean Blockchain API
|
||
|
|
|
||
|
|
OpenAPI for Lethean Blockchain
|
||
|
|
|
||
|
|
The version of the OpenAPI document: 6.0.1
|
||
|
|
Generated by OpenAPI Generator (https://openapi-generator.tech)
|
||
|
|
|
||
|
|
Do not edit the class manually.
|
||
|
|
""" # noqa: E501
|
||
|
|
|
||
|
|
|
||
|
|
from __future__ import annotations
|
||
|
|
import pprint
|
||
|
|
import re # noqa: F401
|
||
|
|
import json
|
||
|
|
|
||
|
|
from pydantic import BaseModel, ConfigDict, StrictBool, StrictFloat, StrictInt, StrictStr
|
||
|
|
from typing import Any, ClassVar, Dict, List, Optional, Union
|
||
|
|
from lthn.models.maintainers_info_model import MaintainersInfoModel
|
||
|
|
from lthn.models.performance_model import PerformanceModel
|
||
|
|
from typing import Optional, Set
|
||
|
|
from typing_extensions import Self
|
||
|
|
|
||
|
|
class InfoModel(BaseModel):
|
||
|
|
"""
|
||
|
|
InfoModel
|
||
|
|
""" # noqa: E501
|
||
|
|
height: Optional[StrictInt] = None
|
||
|
|
tx_count: Optional[StrictInt] = None
|
||
|
|
tx_pool_size: Optional[StrictInt] = None
|
||
|
|
alt_blocks_count: Optional[StrictInt] = None
|
||
|
|
outgoing_connections_count: Optional[StrictInt] = None
|
||
|
|
incoming_connections_count: Optional[StrictInt] = None
|
||
|
|
synchronized_connections_count: Optional[StrictInt] = None
|
||
|
|
white_peerlist_size: Optional[StrictInt] = None
|
||
|
|
grey_peerlist_size: Optional[StrictInt] = None
|
||
|
|
current_blocks_median: Optional[StrictInt] = None
|
||
|
|
alias_count: Optional[StrictInt] = None
|
||
|
|
current_max_allowed_block_size: Optional[StrictInt] = None
|
||
|
|
daemon_network_state: Optional[StrictStr] = None
|
||
|
|
synchronization_start_height: Optional[StrictInt] = None
|
||
|
|
max_net_seen_height: Optional[StrictInt] = None
|
||
|
|
mi: Optional[MaintainersInfoModel] = None
|
||
|
|
pos_allowed: Optional[StrictBool] = None
|
||
|
|
pos_difficulty: Optional[StrictStr] = None
|
||
|
|
pow_difficulty: Optional[StrictInt] = None
|
||
|
|
default_fee: Optional[StrictInt] = None
|
||
|
|
minimum_fee: Optional[StrictInt] = None
|
||
|
|
is_hardfork_active: Optional[List[StrictBool]] = None
|
||
|
|
net_time_delta_median: Optional[StrictInt] = None
|
||
|
|
current_network_hashrate_50: Optional[StrictInt] = None
|
||
|
|
current_network_hashrate_350: Optional[StrictInt] = None
|
||
|
|
seconds_for_10_blocks: Optional[StrictInt] = None
|
||
|
|
seconds_for_30_blocks: Optional[StrictInt] = None
|
||
|
|
transactions_cnt_per_day: Optional[List[StrictInt]] = None
|
||
|
|
transactions_volume_per_day: Optional[List[StrictInt]] = None
|
||
|
|
last_pos_timestamp: Optional[StrictInt] = None
|
||
|
|
last_pow_timestamp: Optional[StrictInt] = None
|
||
|
|
total_coins: Optional[StrictStr] = None
|
||
|
|
last_block_size: Optional[StrictInt] = None
|
||
|
|
tx_count_in_last_block: Optional[StrictInt] = None
|
||
|
|
pos_sequence_factor: Optional[Union[StrictFloat, StrictInt]] = None
|
||
|
|
pow_sequence_factor: Optional[Union[StrictFloat, StrictInt]] = None
|
||
|
|
block_reward: Optional[StrictInt] = None
|
||
|
|
last_block_total_reward: Optional[StrictInt] = None
|
||
|
|
pos_diff_total_coins_rate: Optional[StrictInt] = None
|
||
|
|
last_block_timestamp: Optional[StrictInt] = None
|
||
|
|
last_block_hash: Optional[StrictStr] = None
|
||
|
|
pos_block_ts_shift_vs_actual: Optional[StrictInt] = None
|
||
|
|
outs_stat: Optional[Dict[str, StrictInt]] = None
|
||
|
|
performance_data: Optional[PerformanceModel] = None
|
||
|
|
offers_count: Optional[StrictInt] = None
|
||
|
|
expiration_median_timestamp: Optional[StrictInt] = None
|
||
|
|
__properties: ClassVar[List[str]] = ["height", "tx_count", "tx_pool_size", "alt_blocks_count", "outgoing_connections_count", "incoming_connections_count", "synchronized_connections_count", "white_peerlist_size", "grey_peerlist_size", "current_blocks_median", "alias_count", "current_max_allowed_block_size", "daemon_network_state", "synchronization_start_height", "max_net_seen_height", "mi", "pos_allowed", "pos_difficulty", "pow_difficulty", "default_fee", "minimum_fee", "is_hardfork_active", "net_time_delta_median", "current_network_hashrate_50", "current_network_hashrate_350", "seconds_for_10_blocks", "seconds_for_30_blocks", "transactions_cnt_per_day", "transactions_volume_per_day", "last_pos_timestamp", "last_pow_timestamp", "total_coins", "last_block_size", "tx_count_in_last_block", "pos_sequence_factor", "pow_sequence_factor", "block_reward", "last_block_total_reward", "pos_diff_total_coins_rate", "last_block_timestamp", "last_block_hash", "pos_block_ts_shift_vs_actual", "outs_stat", "performance_data", "offers_count", "expiration_median_timestamp"]
|
||
|
|
|
||
|
|
model_config = ConfigDict(
|
||
|
|
populate_by_name=True,
|
||
|
|
validate_assignment=True,
|
||
|
|
protected_namespaces=(),
|
||
|
|
)
|
||
|
|
|
||
|
|
|
||
|
|
def to_str(self) -> str:
|
||
|
|
"""Returns the string representation of the model using alias"""
|
||
|
|
return pprint.pformat(self.model_dump(by_alias=True))
|
||
|
|
|
||
|
|
def to_json(self) -> str:
|
||
|
|
"""Returns the JSON representation of the model using alias"""
|
||
|
|
# TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
|
||
|
|
return json.dumps(self.to_dict())
|
||
|
|
|
||
|
|
@classmethod
|
||
|
|
def from_json(cls, json_str: str) -> Optional[Self]:
|
||
|
|
"""Create an instance of InfoModel from a JSON string"""
|
||
|
|
return cls.from_dict(json.loads(json_str))
|
||
|
|
|
||
|
|
def to_dict(self) -> Dict[str, Any]:
|
||
|
|
"""Return the dictionary representation of the model using alias.
|
||
|
|
|
||
|
|
This has the following differences from calling pydantic's
|
||
|
|
`self.model_dump(by_alias=True)`:
|
||
|
|
|
||
|
|
* `None` is only added to the output dict for nullable fields that
|
||
|
|
were set at model initialization. Other fields with value `None`
|
||
|
|
are ignored.
|
||
|
|
"""
|
||
|
|
excluded_fields: Set[str] = set([
|
||
|
|
])
|
||
|
|
|
||
|
|
_dict = self.model_dump(
|
||
|
|
by_alias=True,
|
||
|
|
exclude=excluded_fields,
|
||
|
|
exclude_none=True,
|
||
|
|
)
|
||
|
|
# override the default output from pydantic by calling `to_dict()` of mi
|
||
|
|
if self.mi:
|
||
|
|
_dict['mi'] = self.mi.to_dict()
|
||
|
|
# override the default output from pydantic by calling `to_dict()` of performance_data
|
||
|
|
if self.performance_data:
|
||
|
|
_dict['performance_data'] = self.performance_data.to_dict()
|
||
|
|
return _dict
|
||
|
|
|
||
|
|
@classmethod
|
||
|
|
def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
|
||
|
|
"""Create an instance of InfoModel from a dict"""
|
||
|
|
if obj is None:
|
||
|
|
return None
|
||
|
|
|
||
|
|
if not isinstance(obj, dict):
|
||
|
|
return cls.model_validate(obj)
|
||
|
|
|
||
|
|
_obj = cls.model_validate({
|
||
|
|
"height": obj.get("height"),
|
||
|
|
"tx_count": obj.get("tx_count"),
|
||
|
|
"tx_pool_size": obj.get("tx_pool_size"),
|
||
|
|
"alt_blocks_count": obj.get("alt_blocks_count"),
|
||
|
|
"outgoing_connections_count": obj.get("outgoing_connections_count"),
|
||
|
|
"incoming_connections_count": obj.get("incoming_connections_count"),
|
||
|
|
"synchronized_connections_count": obj.get("synchronized_connections_count"),
|
||
|
|
"white_peerlist_size": obj.get("white_peerlist_size"),
|
||
|
|
"grey_peerlist_size": obj.get("grey_peerlist_size"),
|
||
|
|
"current_blocks_median": obj.get("current_blocks_median"),
|
||
|
|
"alias_count": obj.get("alias_count"),
|
||
|
|
"current_max_allowed_block_size": obj.get("current_max_allowed_block_size"),
|
||
|
|
"daemon_network_state": obj.get("daemon_network_state"),
|
||
|
|
"synchronization_start_height": obj.get("synchronization_start_height"),
|
||
|
|
"max_net_seen_height": obj.get("max_net_seen_height"),
|
||
|
|
"mi": MaintainersInfoModel.from_dict(obj["mi"]) if obj.get("mi") is not None else None,
|
||
|
|
"pos_allowed": obj.get("pos_allowed"),
|
||
|
|
"pos_difficulty": obj.get("pos_difficulty"),
|
||
|
|
"pow_difficulty": obj.get("pow_difficulty"),
|
||
|
|
"default_fee": obj.get("default_fee"),
|
||
|
|
"minimum_fee": obj.get("minimum_fee"),
|
||
|
|
"is_hardfork_active": obj.get("is_hardfork_active"),
|
||
|
|
"net_time_delta_median": obj.get("net_time_delta_median"),
|
||
|
|
"current_network_hashrate_50": obj.get("current_network_hashrate_50"),
|
||
|
|
"current_network_hashrate_350": obj.get("current_network_hashrate_350"),
|
||
|
|
"seconds_for_10_blocks": obj.get("seconds_for_10_blocks"),
|
||
|
|
"seconds_for_30_blocks": obj.get("seconds_for_30_blocks"),
|
||
|
|
"transactions_cnt_per_day": obj.get("transactions_cnt_per_day"),
|
||
|
|
"transactions_volume_per_day": obj.get("transactions_volume_per_day"),
|
||
|
|
"last_pos_timestamp": obj.get("last_pos_timestamp"),
|
||
|
|
"last_pow_timestamp": obj.get("last_pow_timestamp"),
|
||
|
|
"total_coins": obj.get("total_coins"),
|
||
|
|
"last_block_size": obj.get("last_block_size"),
|
||
|
|
"tx_count_in_last_block": obj.get("tx_count_in_last_block"),
|
||
|
|
"pos_sequence_factor": obj.get("pos_sequence_factor"),
|
||
|
|
"pow_sequence_factor": obj.get("pow_sequence_factor"),
|
||
|
|
"block_reward": obj.get("block_reward"),
|
||
|
|
"last_block_total_reward": obj.get("last_block_total_reward"),
|
||
|
|
"pos_diff_total_coins_rate": obj.get("pos_diff_total_coins_rate"),
|
||
|
|
"last_block_timestamp": obj.get("last_block_timestamp"),
|
||
|
|
"last_block_hash": obj.get("last_block_hash"),
|
||
|
|
"pos_block_ts_shift_vs_actual": obj.get("pos_block_ts_shift_vs_actual"),
|
||
|
|
"outs_stat": obj.get("outs_stat"),
|
||
|
|
"performance_data": PerformanceModel.from_dict(obj["performance_data"]) if obj.get("performance_data") is not None else None,
|
||
|
|
"offers_count": obj.get("offers_count"),
|
||
|
|
"expiration_median_timestamp": obj.get("expiration_median_timestamp")
|
||
|
|
})
|
||
|
|
return _obj
|
||
|
|
|
||
|
|
|