diff --git a/contracts/staking/IApplicationWithDecreaseDelay.sol b/contracts/staking/IApplicationWithDecreaseDelay.sol new file mode 100644 index 00000000..03ecc370 --- /dev/null +++ b/contracts/staking/IApplicationWithDecreaseDelay.sol @@ -0,0 +1,68 @@ +// SPDX-License-Identifier: GPL-3.0-or-later + +// ██████████████ ▐████▌ ██████████████ +// ██████████████ ▐████▌ ██████████████ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ +// ██████████████ ▐████▌ ██████████████ +// ██████████████ ▐████▌ ██████████████ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ + +pragma solidity ^0.8.9; + +import "./IApplication.sol"; + +/// @title Interface for Threshold Network applications with delay after decrease request +interface IApplicationWithDecreaseDelay is IApplication { + /// @notice Returns authorization-related parameters of the application. + /// @dev The minimum authorization is also returned by `minimumAuthorization()` + /// function, as a requirement of `IApplication` interface. + /// @return _minimumAuthorization The minimum authorization amount required + /// so that operator can participate in the application. + /// @return authorizationDecreaseDelay Delay in seconds that needs to pass + /// between the time authorization decrease is requested and the + /// time that request gets approved. Protects against participants + /// earning rewards and not being active in the network. + /// @return authorizationDecreaseChangePeriod Authorization decrease change + /// period in seconds. It is the time window, before authorization decrease + /// delay ends, during which the pending authorization decrease + /// request can be overwritten. + /// If set to 0, pending authorization decrease request can not be + /// overwritten until the entire `authorizationDecreaseDelay` ends. + /// If set to a value equal to `authorizationDecreaseDelay`, request can + /// always be overwritten. + function authorizationParameters() + external + view + returns ( + uint96 _minimumAuthorization, + uint64 authorizationDecreaseDelay, + uint64 authorizationDecreaseChangePeriod + ); + + /// @notice Returns the amount of stake that is pending authorization + /// decrease for the given staking provider. If no authorization + /// decrease has been requested, returns zero. + function pendingAuthorizationDecrease(address _stakingProvider) + external + view + returns (uint96); + + /// @notice Returns the remaining time in seconds that needs to pass before + /// the requested authorization decrease can be approved. + function remainingAuthorizationDecreaseDelay(address stakingProvider) + external + view + returns (uint64); + + /// @notice Approves the previously registered authorization decrease + /// request. Reverts if authorization decrease delay has not passed + /// yet or if the authorization decrease was not requested for the + /// given staking provider. + function approveAuthorizationDecrease(address stakingProvider) external; +} diff --git a/contracts/staking/IApplicationWithOperator.sol b/contracts/staking/IApplicationWithOperator.sol new file mode 100644 index 00000000..05879d21 --- /dev/null +++ b/contracts/staking/IApplicationWithOperator.sol @@ -0,0 +1,43 @@ +// SPDX-License-Identifier: GPL-3.0-or-later + +// ██████████████ ▐████▌ ██████████████ +// ██████████████ ▐████▌ ██████████████ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ +// ██████████████ ▐████▌ ██████████████ +// ██████████████ ▐████▌ ██████████████ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ +// ▐████▌ ▐████▌ + +pragma solidity ^0.8.9; + +import "./IApplication.sol"; + +/// @title Interface for Threshold Network applications with operator role +interface IApplicationWithOperator is IApplication { + /// @notice Returns operator registered for the given staking provider. + function stakingProviderToOperator(address stakingProvider) + external + view + returns (address); + + /// @notice Returns staking provider of the given operator. + function operatorToStakingProvider(address operator) + external + view + returns (address); + + /// @notice Used by staking provider to set operator address that will + /// operate a node. The operator address must be unique. + /// Reverts if the operator is already set for the staking provider + /// or if the operator address is already in use. + /// @dev Depending on application the given staking provider can set operator + /// address only once or multiple times. Besides that, application can decide + /// if function reverts if there is a pending authorization decrease for + /// the staking provider. + function registerOperator(address operator) external; +}