Source code for bittensor.utils.axon_utils

# The MIT License (MIT)
# Copyright © 2024 Opentensor Foundation
#
# Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
# documentation files (the “Software”), to deal in the Software without restriction, including without limitation
# the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software,
# and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in all copies or substantial portions of
# the Software.
#
# THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO
# THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
# OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
# DEALINGS IN THE SOFTWARE.

from typing import Optional

ALLOWED_DELTA = 4_000_000_000  # Delta of 4 seconds for nonce validation
NANOSECONDS_IN_SECOND = 1_000_000_000


[docs] def allowed_nonce_window_ns(current_time_ns: int, synapse_timeout: Optional[float]): """ Calculates the allowed window for a nonce in nanoseconds. Args: current_time_ns (int): The current time in nanoseconds. synapse_timeout (Optional[float]): The optional timeout for the synapse in seconds. If None, it defaults to 0. Returns: int: The allowed nonce window in nanoseconds. """ synapse_timeout_ns = (synapse_timeout or 0) * NANOSECONDS_IN_SECOND allowed_window_ns = current_time_ns - ALLOWED_DELTA - synapse_timeout_ns return allowed_window_ns
[docs] def calculate_diff_seconds( current_time: int, synapse_timeout: Optional[float], synapse_nonce: int ): """ Calculates the difference in seconds between the current time and the synapse nonce, and also returns the allowed delta in seconds. Args: current_time (int): The current time in nanoseconds. synapse_timeout (Optional[float]): The optional timeout for the synapse in seconds. synapse_nonce (int): The nonce value for the synapse in nanoseconds. Returns: tuple: A tuple containing the difference in seconds (float) and the allowed delta in seconds (float). """ synapse_timeout_ns = (synapse_timeout or 0) * NANOSECONDS_IN_SECOND diff_seconds = (current_time - synapse_nonce) / NANOSECONDS_IN_SECOND allowed_delta_seconds = (ALLOWED_DELTA + synapse_timeout_ns) / NANOSECONDS_IN_SECOND return diff_seconds, allowed_delta_seconds