-
Notifications
You must be signed in to change notification settings - Fork 39
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
chore(drive): reduce withdrawal limits [WIP] #2286
Conversation
Important Review skippedAuto reviews are disabled on base/target branches other than the default branch. Please check the settings in the CodeRabbit UI or the You can disable this status message by setting the WalkthroughThe changes introduce a new versioning system for the daily withdrawal limit functionality, adding a Changes
Possibly related PRs
Suggested labels
Suggested reviewers
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
CodeRabbit Configuration File (
|
packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/v4.rs
Outdated
Show resolved
Hide resolved
pub const PROTOCOL_VERSION_5: ProtocolVersion = 5; | ||
|
||
/// This version contains some fixes for withdrawals. | ||
pub const PLATFORM_V5: PlatformVersion = PlatformVersion { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It must be version 6
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nope
The PR should probably be named either "reduce withdrawal limitations" or "increase withdrawal limit" since the limit is going from 1000->2000. The limit is going up, while the limitations (restrictions on withdrawals) are going down. Confused yet? 🤪 |
…signing # Conflicts: # packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/v4.rs # packages/rs-platform-version/src/version/v5.rs
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 5
🧹 Outside diff range and nitpick comments (7)
packages/rs-platform-version/src/version/dpp_versions/dpp_method_versions/v2.rs (1)
2-5
: Add documentation for the version constant and its implications.This constant introduces versioning for withdrawal limits, but lacks documentation explaining the significance of these version numbers and their impact on system behavior.
Add documentation above the constant:
+/// Defines version 2 of DPP method versions. +/// - daily_withdrawal_limit: Version 1 introduces increased withdrawal limit of 2000 Dash +/// - epoch_core_reward_credits_for_distribution: Version 0 maintains original behavior pub const DPP_METHOD_VERSIONS_V2: DPPMethodVersions = DPPMethodVersions { epoch_core_reward_credits_for_distribution: 0, daily_withdrawal_limit: 1, };packages/rs-platform-version/src/version/dpp_versions/dpp_method_versions/mod.rs (1)
Line range hint
7-11
: Consider adding documentation for version differences.Since this struct is being used across multiple versions (v1 and v2) and involves changes to withdrawal limits, it would be helpful to add documentation explaining the differences between versions and the rationale behind the changes.
Add documentation above the struct:
use versioned_feature_core::FeatureVersion; pub mod v1; pub mod v2; +/// Represents the versioned DPP method features +/// +/// Version differences: +/// - v1: Initial implementation with withdrawal limit of 1000 +/// - v2: Increased withdrawal limit to 2000 #[derive(Clone, Debug, Default)] pub struct DPPMethodVersions { pub epoch_core_reward_credits_for_distribution: FeatureVersion, pub daily_withdrawal_limit: FeatureVersion, }packages/rs-dpp/src/withdrawal/daily_withdrawal_limit/v1/mod.rs (1)
3-8
: Enhance documentation with conversion details and rationale.The documentation should explain:
- The conversion factor between Dash and Credits (1 Dash = 100,000,000,000 Credits)
- Why the limit was increased from 1000 to 2000 Dash
- Any potential impact on existing withdrawals
Consider updating the documentation like this:
/// Set constant withdrawal daily limit to 2000 Dash /// + /// The limit is expressed in Credits where: + /// 1 Dash = 100,000,000,000 Credits + /// 2000 Dash = 200,000,000,000,000 Credits + /// + /// This represents an increase from the previous limit of 1000 Dash + /// introduced to accommodate higher volume withdrawals. + /// /// # Returns /// /// * `Credits`: The calculated daily withdrawal limit based on the available credits.packages/rs-platform-version/src/version/mod.rs (1)
Documentation Updates Required for Protocol Version 6
Based on the verification results, while there are code changes related to withdrawal limits in protocol version 6 (as seen in recent commits), there appears to be insufficient documentation updates:
- No protocol version 6 specific documentation was found in README files or docs directories
- The CHANGELOG entries mention withdrawal limit changes but don't specifically document protocol version 6 impacts
- No migration guide updates were found for the new protocol version
- No API documentation updates were found regarding the new withdrawal limits
Required documentation updates:
- Add protocol version 6 changes to release notes
- Document new withdrawal limits in the withdrawals-contract README
- Update API documentation to reflect the new limits
- Create/update migration guide for protocol version 6
🔗 Analysis chain
Line range hint
1-26
: Verify Documentation UpdatesSince this introduces a new protocol version that affects withdrawal limits, ensure that:
- Release notes document the protocol version change
- Migration guides are updated
- API documentation reflects the new withdrawal limits
Let's check for documentation updates:
Let me check the documentation for protocol version 6 and withdrawal limits more specifically.
Let me try one final check to look for any documentation updates in pull requests or recent commits related to protocol v6 and withdrawal limits.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Description: Check for documentation updates related to v6 and withdrawal limits # Look for documentation files echo "Checking for documentation updates..." fd -e md -e rst | xargs rg -l "withdrawal|protocol.*version|v6" # Check for changelog entries echo "Checking changelog..." fd CHANGELOG | xargs rg "v6|withdrawal"Length of output: 7417
Script:
#!/bin/bash # Check for specific v6 protocol version documentation and withdrawal limit changes # Check README files for protocol v6 or withdrawal limits documentation echo "Checking README files..." fd README.md | xargs rg -A 5 "protocol.*v(ersion)?.*6|withdrawal.*limit" # Check docs directory if it exists echo "Checking docs directory..." fd -t d "^docs$" | xargs -I {} fd . {} -t f -e md | xargs rg -A 5 "protocol.*v(ersion)?.*6|withdrawal.*limit" # Check specific withdrawal documentation echo "Checking withdrawal-specific docs..." rg -A 5 "withdrawal.*limit" packages/withdrawals-contract/README.mdLength of output: 465
Script:
#!/bin/bash # Check recent changes and PRs for documentation updates # Check commit messages and changed files in recent history echo "Checking recent commits..." git log --grep="protocol.*v6\|withdrawal.*limit" --name-only --since="3 months ago" # Look for documentation files in the PR that introduced v6 echo "Checking files in protocol v6 PR..." rg -l "PROTOCOL_VERSION_6" | xargs dirname | sort -u | xargs -I {} find {} -type f -name "*.md" -o -name "CHANGELOG*" | xargs rg "protocol.*v6\|withdrawal" # Check for any documentation in the version module itself echo "Checking version module docs..." rg -A 5 "protocol.*v6\|withdrawal" packages/rs-platform-version/src/version/Length of output: 8528
packages/rs-dpp/src/withdrawal/daily_withdrawal_limit/mod.rs (1)
15-15
: Consider adding documentation for version differences.The version handling logic is clean, but it would be helpful to document the key differences between v0 and v1 implementations (e.g., the increase from 1000 to 2000 Dash) in a doc comment.
pub fn daily_withdrawal_limit( total_credits_in_platform: Credits, platform_version: &PlatformVersion, ) -> Result<Credits, ProtocolError> { + // Version differences: + // v0: Dynamic limit based on total credits + // v1: Fixed limit of 2000 Dash match platform_version.dpp.methods.daily_withdrawal_limit {packages/rs-platform-version/src/version/v5.rs (1)
33-33
: Enhance documentation clarity.The comment "This version contains some fixes for withdrawals" is too vague. Consider adding more specific details about the withdrawal limit changes being implemented.
-/// This version contains some fixes for withdrawals. +/// This version modifies the withdrawal limits from 1000 to 2000 and implements associated validation changes.packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/v5.rs (1)
14-124
: Consider adding comments for version incrementsFor methods where the version number has been incremented (e.g.,
consensus_params_update
,create_owner_identity
,update_owner_withdrawal_address
,check_for_desired_protocol_upgrade
,validator_set_update
), consider adding comments explaining the changes or reasons for the version updates. This approach enhances readability and helps future developers understand the context, similar to the existing comment forpool_withdrawals_into_transactions_queue
.
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
📒 Files selected for processing (12)
packages/rs-dpp/src/withdrawal/daily_withdrawal_limit/mod.rs
(1 hunks)packages/rs-dpp/src/withdrawal/daily_withdrawal_limit/v1/mod.rs
(1 hunks)packages/rs-drive-abci/src/execution/engine/run_block_proposal/v0/mod.rs
(1 hunks)packages/rs-drive-abci/src/execution/platform_events/withdrawals/append_signatures_and_broadcast_withdrawal_transactions/v0/mod.rs
(3 hunks)packages/rs-drive-abci/src/rpc/core.rs
(0 hunks)packages/rs-platform-version/src/version/dpp_versions/dpp_method_versions/mod.rs
(1 hunks)packages/rs-platform-version/src/version/dpp_versions/dpp_method_versions/v2.rs
(1 hunks)packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/mod.rs
(1 hunks)packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/v5.rs
(1 hunks)packages/rs-platform-version/src/version/mod.rs
(2 hunks)packages/rs-platform-version/src/version/v5.rs
(2 hunks)packages/rs-platform-version/src/version/v6.rs
(1 hunks)
💤 Files with no reviewable changes (1)
- packages/rs-drive-abci/src/rpc/core.rs
🔇 Additional comments (18)
packages/rs-platform-version/src/version/dpp_versions/dpp_method_versions/v2.rs (2)
1-5
: Consider PR title revision.
The code implements increased withdrawal limits (to 2000 Dash) but the PR title suggests reducing limits. This could cause confusion.
Consider:
- Updating the PR title to "chore(drive): increase withdrawal limit to 2000 Dash"
- Adding PR description detailing:
- The version change from V1 to V2
- The withdrawal limit increase
- Migration considerations
1-5
: Verify version handling across the codebase.
Let's ensure this version constant is properly integrated with the withdrawal limit implementation.
✅ Verification successful
Based on the search results, I can now provide a final response:
Withdrawal limit version change is properly integrated
The version constant DPP_METHOD_VERSIONS_V2
with daily_withdrawal_limit: 1
is correctly integrated with the implementation:
- Version 1 implementation (
daily_withdrawal_limit_v1
) sets a fixed limit of 2000 Dash (200_000_000_000_000 credits) - The version change is documented in
v6.rs
as intentionally increasing the limit to 2000 Dash - The version router in
daily_withdrawal_limit/mod.rs
properly handles both v0 and v1 implementations - The change represents a deliberate upgrade from the variable limit in v0 to a fixed higher limit in v1
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Description: Verify the relationship between version constants and withdrawal limit implementation
# Test 1: Find where this version constant is used
echo "=== Usage of DPP_METHOD_VERSIONS_V2 ==="
rg "DPP_METHOD_VERSIONS_V2"
# Test 2: Find related withdrawal limit version checks
echo -e "\n=== Withdrawal Limit Version Checks ==="
rg "daily_withdrawal_limit.*version" -A 5
# Test 3: Find the actual limit implementation
echo -e "\n=== Withdrawal Limit Implementation ==="
rg "2000.*Dash" -A 5
Length of output: 112
Script:
#!/bin/bash
# Let's try a more comprehensive search strategy
# Search for withdrawal limit related code
echo "=== Withdrawal Limit Related Code ==="
rg "withdrawal.*limit" -i
# Search for DPPMethodVersions usage
echo -e "\n=== DPPMethodVersions Usage ==="
rg "DPPMethodVersions"
# Look for version-related constants and implementations
echo -e "\n=== Version Constants and Implementations ==="
ast-grep --pattern 'const $_ : DPPMethodVersions = $_'
# Search for specific method implementations
echo -e "\n=== Method Implementations ==="
rg "fn.*withdrawal" -A 5
Length of output: 121740
Script:
#!/bin/bash
# Let's specifically look for the withdrawal limit implementation and its usage
# Search for v1 withdrawal limit implementation
echo "=== V1 Withdrawal Limit Implementation ==="
rg -A 3 "daily_withdrawal_limit_v1"
# Search for withdrawal limit version changes
echo -e "\n=== Withdrawal Limit Version Changes ==="
rg "daily_withdrawal_limit.*v\d" -A 3
# Look for version constant usage
echo -e "\n=== DPP Method Version Usage ==="
ast-grep --pattern 'DPP_METHOD_VERSIONS_V2.daily_withdrawal_limit'
# Search for withdrawal limit tests
echo -e "\n=== Withdrawal Limit Tests ==="
rg "test.*withdrawal.*limit" -A 5
Length of output: 5173
packages/rs-platform-version/src/version/dpp_versions/dpp_method_versions/mod.rs (1)
4-4
: LGTM! The versioning structure looks correct.
The addition of v2
module follows good versioning practices by maintaining backward compatibility while introducing new functionality.
Let's verify the version implementation:
✅ Verification successful
Versioning implementation correctly handles withdrawal limit changes
The verification confirms that:
- V2 module is properly integrated into platform versions 5 and 6
- The daily withdrawal limit versioning is correctly implemented with a clear upgrade path:
- V0: Dynamic limit based on total platform credits (up to 1000 Dash)
- V1: Fixed limit of 2000 Dash (200_000_000_000_000 credits)
- Version selection is properly handled in the main
daily_withdrawal_limit
function
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Description: Verify the v2 module implementation and its usage
# Check the v2 module implementation
rg -A 10 "DPP_METHOD_VERSIONS_V2"
# Verify if there are any direct usages of the daily_withdrawal_limit version
ast-grep --pattern 'daily_withdrawal_limit'
Length of output: 5193
Script:
#!/bin/bash
# Let's verify the daily_withdrawal_limit version implementation and its changes
# Check the v1 implementation for comparison
rg -A 5 "DPP_METHOD_VERSIONS_V1.*daily_withdrawal_limit"
# Check the implementation details of daily_withdrawal_limit function
rg -A 20 "fn daily_withdrawal_limit"
# Check the v0 implementation referenced in the code
rg -A 10 "daily_withdrawal_limit_v0"
Length of output: 7569
packages/rs-dpp/src/withdrawal/daily_withdrawal_limit/v1/mod.rs (1)
1-12
: Verify PR title accuracy - limit is increasing, not reducing.
The implementation increases the withdrawal limit from 1000 to 2000 Dash, which contradicts the PR title "reduce withdrawal limits". This could cause confusion for reviewers and in future references.
Please update the PR title to accurately reflect that this is an increase in the withdrawal limit.
packages/rs-platform-version/src/version/mod.rs (2)
3-3
: LGTM: Module Structure
The addition of the v6 module and its import follows the established pattern and maintains consistency with the existing versioning structure.
Also applies to: 21-21
25-25
:
Updating LATEST_VERSION
to PROTOCOL_VERSION_6
is a breaking change that requires careful consideration:
- This change affects protocol compatibility
- Existing nodes may need to upgrade
- Client implementations might need updates
Let's verify the v6 module implementation and its changes:
#!/bin/bash
# Description: Verify v6 module implementation and changes
# Check v6 module implementation
echo "Checking v6 module implementation..."
rg -p "PROTOCOL_VERSION_6"
# Look for potential version checks in the codebase
echo "Checking version compatibility code..."
rg -p "LATEST_VERSION|PROTOCOL_VERSION_[0-9]"
# Check for version-specific features or breaking changes
echo "Checking for version-specific features..."
ast-grep --pattern 'if $version == PROTOCOL_VERSION_6 { $$$ }'
packages/rs-dpp/src/withdrawal/daily_withdrawal_limit/mod.rs (2)
7-7
: LGTM! Verify v1 module implementation.
The new module declaration follows Rust conventions.
Let's verify the v1 module implementation:
✅ Verification successful
Implementation matches PR objectives - withdrawal limit increased to 2000 Dash
The v1 module implements a fixed withdrawal limit of 2000 Dash (200_000_000_000_000 credits), which aligns with the PR's objective of increasing the withdrawal limit from 1000 to 2000 Dash. The implementation is simple and straightforward.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Description: Verify the v1 module implementation and its daily withdrawal limit value
# Test: Check the v1 module implementation
rg -A 5 "daily_withdrawal_limit_v1" packages/rs-dpp/src/withdrawal/daily_withdrawal_limit/v1/
Length of output: 2535
Line range hint 9-20
: PR title needs revision - limit is increasing, not reducing.
The implementation correctly handles the new v1 withdrawal limit, but as noted in PR comments, the PR title "reduce withdrawal limits" is misleading since the limit is actually increasing from 1000 to 2000 Dash. Consider updating the PR title to accurately reflect the change.
Let's verify the limit values:
packages/rs-platform-version/src/version/v5.rs (2)
34-34
:
Update version number as previously suggested.
As noted in a previous review comment, this should be version 6 instead of 5. This change is necessary to maintain proper versioning sequence.
Consider moving this code to a new file v6.rs
and updating the constants accordingly:
-pub const PROTOCOL_VERSION_5: ProtocolVersion = 5;
-pub const PLATFORM_V5: PlatformVersion = PlatformVersion {
+pub const PROTOCOL_VERSION_6: ProtocolVersion = 6;
+pub const PLATFORM_V6: PlatformVersion = PlatformVersion {
Line range hint 34-65
: Verify version coordination across platform components.
Since this is a platform-wide version change affecting withdrawal limits, please ensure that:
- All dependent components are aware of this version change
- Migration paths are considered for existing deployments
- Documentation is updated to reflect the new withdrawal limits
✅ Verification successful
Let me analyze the findings from the shell script results to generate a final response.
Version change is coordinated and documented across components
The search results show that:
- The version change in
PLATFORM_V5
is properly referenced across the codebase in protocol version management - The withdrawal-related changes are well-structured with clear versioning (v0, v1, v2) and proper implementation across components
- The change introduces a fixed daily withdrawal limit of 2000 DASH (as seen in
daily_withdrawal_limit_v1
) replacing the previous percentage-based calculation
Key observations:
- Version coordination is maintained in protocol_version.rs
- Implementation details are properly versioned in DPP and Drive components
- Metrics and monitoring are in place for withdrawal limits
- Migration path exists with clear version progression
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Check for other components that might need coordination
echo "Checking for version references:"
rg "PLATFORM_V5" --type rust
echo "Checking for withdrawal limit references:"
rg "withdrawal.*limit" --type rust
Length of output: 12223
packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/mod.rs (1)
7-7
: Verify version compatibility and update documentation.
The addition of v5
module suggests significant changes to the ABCI method versions, particularly around withdrawal handling. Since this is part of a withdrawal limits adjustment:
- Ensure backward compatibility is maintained for existing withdrawal processing
- Update relevant documentation to reflect the version changes
- Consider adding migration guides if there are breaking changes
Let's verify the version changes in v5:
✅ Verification successful
Let me gather more information about the v5 implementation and its impact:
Based on the analysis of the code and changelog, I can now provide a final response:
Version 5 module introduces backward-compatible changes for withdrawal handling
The v5 module implementation shows no breaking changes in the ABCI method versions compared to v4. The changes are part of the withdrawal limits functionality introduced in v1.5.0, which maintains backward compatibility with existing withdrawal processing.
Key findings:
- Version comparison shows identical version numbers between v4 and v5 implementations
- Related changes are documented in CHANGELOG.md for v1.5.0 release
- No breaking changes in method signatures or behavior
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Description: Check the version changes in v5 module and related documentation
# Check v5 implementation
echo "Checking v5 implementation..."
rg -p "DRIVE_ABCI_METHOD_VERSIONS_V5" -A 10
# Look for related documentation updates
echo "Checking for documentation updates..."
fd -e md -e rst . | xargs rg -l "withdrawal.*limit|version.*5"
Length of output: 2580
Script:
#!/bin/bash
# Check the complete v5 implementation and compare with v4
echo "Checking complete v5 implementation..."
rg -p "DriveAbciMethodVersions" packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/v5.rs -A 30
echo "Checking v4 implementation for comparison..."
rg -p "DriveAbciMethodVersions" packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/v4.rs -A 30
# Check changelog entries
echo "Checking changelog entries..."
rg -p "## \[.*\]" CHANGELOG.md -A 10
Length of output: 92775
packages/rs-drive-abci/src/execution/platform_events/withdrawals/append_signatures_and_broadcast_withdrawal_transactions/v0/mod.rs (2)
98-99
: LGTM! Comprehensive error handling for asset unlock transactions.
The error handling has been enhanced to cover all asset unlock failure scenarios, including expired transactions and quorum-related issues. The logging is descriptive and will aid in debugging.
4-4
: Update PR title and documentation to match actual changes.
The PR title "reduce withdrawal limits" appears to be misleading as:
- Comments indicate the limit is actually increasing from 1000 to 2000
- The code changes focus on error handling for asset unlock transactions rather than limit modifications
Consider:
- Updating the PR title to accurately reflect the changes (e.g., "chore(drive): enhance asset unlock error handling")
- Adding documentation about the error handling changes
- Clarifying if withdrawal limit changes are coming in a separate commit
packages/rs-drive-abci/src/execution/engine/run_block_proposal/v0/mod.rs (2)
273-276
: Address TODO: Implement core height change check for rebroadcasting.
The comment indicates that rebroadcasting should only occur on core height changes, but this requirement isn't implemented yet. This could lead to unnecessary rebroadcasting of expired withdrawals on every block.
Let's verify the current rebroadcast behavior:
#!/bin/bash
# Search for other rebroadcast implementations to understand the pattern
rg -A 5 "rebroadcast.*withdrawal"
# Look for core height change checks in similar contexts
rg "core.*height.*change"
Would you like help implementing the core height change check for the rebroadcast operation?
277-281
: Verify rebroadcast timing logic with withdrawal expiration.
The code sequence ensures rebroadcasting happens before marking withdrawals as expired, which is crucial for proper operation. However, we should verify that this timing dependency is maintained across all code paths.
Let's verify the sequencing:
✅ Verification successful
Based on the search results, I can now generate the final response since I have enough information to verify the timing logic:
Timing sequence for withdrawal rebroadcasting is correctly implemented
The code explicitly handles the timing sequence correctly:
- The rebroadcast operation is intentionally placed before marking withdrawals as expired, as evidenced by the comments in
run_block_proposal/v0/mod.rs
:
// Rebroadcast expired withdrawals if they exist
// We do that before we mark withdrawals as expired
// to rebroadcast them on the next block but not the same
- The implementation in both v0 and v1 versions maintains this timing dependency:
- V0 adds extra safety checks for quorum position before calling v1
- V1 handles the core rebroadcasting logic while maintaining the same timing sequence
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Search for withdrawal expiration logic to verify timing
rg -A 10 "mark.*withdrawal.*expired|expire.*withdrawal"
# Look for other calls to rebroadcast_expired_withdrawal_documents
ast-grep --pattern 'rebroadcast_expired_withdrawal_documents($$$)'
Length of output: 50340
packages/rs-platform-version/src/version/v6.rs (1)
57-58
: Verify the Change in Withdrawal Limits
The comment indicates that daily_withdrawal_limit
is changed to increase the daily withdrawal limit to 2000 Dash. However, the pull request title suggests reducing withdrawal limits. Please confirm whether the intention is to increase or decrease the withdrawal limit to 2000 Dash, and adjust the comment and implementation accordingly.
packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/v5.rs (2)
82-85
: Well-documented version change
The comment explaining the version increment for pool_withdrawals_into_transactions_queue
is clear and provides valuable context regarding the change due to the Core v21 bug workaround. This level of documentation is helpful for maintainability.
14-124
: LGTM: Version definitions are structured correctly
The method versions are clearly defined and organized, adhering to the project's structure and standards.
pub fn daily_withdrawal_limit_v1() -> Credits { | ||
// 2000 Dash | ||
200_000_000_000_000 | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Consider using named constants for better maintainability.
The magic number could be harder to maintain and verify. Consider breaking it down into named constants that make the calculation clear.
Here's a suggested improvement:
pub fn daily_withdrawal_limit_v1() -> Credits {
- // 2000 Dash
- 200_000_000_000_000
+ const DASH_TO_CREDITS: Credits = 100_000_000_000;
+ const DASH_LIMIT: Credits = 2000;
+ DASH_LIMIT * DASH_TO_CREDITS
}
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
pub fn daily_withdrawal_limit_v1() -> Credits { | |
// 2000 Dash | |
200_000_000_000_000 | |
} | |
pub fn daily_withdrawal_limit_v1() -> Credits { | |
const DASH_TO_CREDITS: Credits = 100_000_000_000; | |
const DASH_LIMIT: Credits = 2000; | |
DASH_LIMIT * DASH_TO_CREDITS | |
} |
@@ -6,13 +6,15 @@ | |||
use crate::version::dpp_versions::dpp_factory_versions::v1::DPP_FACTORY_VERSIONS_V1; | |||
use crate::version::dpp_versions::dpp_identity_versions::v1::IDENTITY_VERSIONS_V1; | |||
use crate::version::dpp_versions::dpp_method_versions::v1::DPP_METHOD_VERSIONS_V1; | |||
use crate::version::dpp_versions::dpp_method_versions::v2::DPP_METHOD_VERSIONS_V2; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
💡 Codebase verification
Remove unused imports
The imports DPP_METHOD_VERSIONS_V2
and DRIVE_ABCI_METHOD_VERSIONS_V3
are not used in this file. The code uses DPP_METHOD_VERSIONS_V1
and DRIVE_ABCI_METHOD_VERSIONS_V4
in the PLATFORM_V5
constant. These imports should be removed to maintain clean code.
🔗 Analysis chain
Verify unused imports.
The newly added imports DPP_METHOD_VERSIONS_V2
and DRIVE_ABCI_METHOD_VERSIONS_V3
appear to be unused in this file, as the code still references V1 and V4 respectively. Are these imports intended for future use?
Also applies to: 17-17
Let me verify if these imports are actually used in the v5.rs file.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Check if these versions are used elsewhere in the codebase
rg "DPP_METHOD_VERSIONS_V2" --type rust
rg "DRIVE_ABCI_METHOD_VERSIONS_V3" --type rust
Length of output: 1172
Script:
#!/bin/bash
# Check the content of v5.rs to see how these versions are used
cat packages/rs-platform-version/src/version/v5.rs
Length of output: 4064
...latform_events/withdrawals/append_signatures_and_broadcast_withdrawal_transactions/v0/mod.rs
Outdated
Show resolved
Hide resolved
packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/v5.rs
Show resolved
Hide resolved
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Outside diff range and nitpick comments (1)
packages/rs-drive-abci/src/execution/platform_events/withdrawals/append_signatures_and_broadcast_withdrawal_transactions/v0/mod.rs (1)
98-99
: Consider enhancing error differentiation in logs.While the error handling is comprehensive, the log message combines different error cases ("expired or has no active quorum") which could make debugging more challenging.
Consider differentiating the log messages:
tracing::debug!( tx_id = transaction.txid().to_string(), tx_index, error = ?e, - "Asset unlock transaction with index {tx_index} is expired or has no active quorum: {}", + "Asset unlock transaction with index {tx_index} failed: {}. Reason: {}", + e.message, + if e.message == CORE_RPC_ERROR_ASSET_UNLOCK_EXPIRED { + "transaction expired" + } else if e.message == CORE_RPC_ERROR_ASSET_UNLOCK_NO_ACTIVE_QUORUM { + "no active quorum" + } else { + "quorum too old" + } );
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
📒 Files selected for processing (1)
packages/rs-drive-abci/src/execution/platform_events/withdrawals/append_signatures_and_broadcast_withdrawal_transactions/v0/mod.rs
(3 hunks)
🔇 Additional comments (3)
packages/rs-drive-abci/src/execution/platform_events/withdrawals/append_signatures_and_broadcast_withdrawal_transactions/v0/mod.rs (3)
4-4
: LGTM!
The import statement is correctly placed and the constant is used in the error handling logic.
1-1
: Consider updating PR title to reflect actual changes.
The PR title "chore(drive): reduce withdrawal limits" doesn't accurately reflect these changes, which focus on improving error handling for withdrawal transactions. This observation aligns with @thephez's comment about the potentially misleading title.
Let's check for actual withdrawal limit changes:
#!/bin/bash
# Search for withdrawal limit related code
rg "withdrawal_limit" --type rust
18-24
: LGTM! Verify Core version compatibility.
The error constants are well-documented and follow a consistent pattern. The comments clearly indicate version-specific changes (Core 21 vs Core 22).
Let's verify these error codes are consistent with Core's error handling:
✅ Verification successful
Let me gather more information about Core version compatibility by searching for any Core version checks or related code.
Let me check how these error codes are actually used in the codebase to verify their implementation.
Let me try a different approach to find the error handling code.
Error constants are correctly implemented and used
The error constants are properly defined and used in the error handling code. The implementation correctly handles both Core 21 and Core 22 error messages, with appropriate error matching in the codebase. The error handling logic properly catches and processes all three error variants (NO_ACTIVE_QUORUM
, TOO_OLD_QUORUM
, and EXPIRED
).
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Search for any other occurrences of these error codes to ensure consistency
rg "bad-assetunlock-" --type rust
Length of output: 5838
Script:
#!/bin/bash
# Search for Core version related code
rg "Core \d+" --type rust -A 2
Length of output: 2909
Script:
#!/bin/bash
# Search for usage of these error constants
ast-grep --pattern 'match $_ {
$$$
$CORE_RPC_ERROR_ASSET_UNLOCK_$_ => $$$
$$$
}'
Length of output: 88
Script:
#!/bin/bash
# Search for error handling code around these constants
rg -B 3 -A 3 "CORE_RPC_ERROR_ASSET_UNLOCK" --type rust
Length of output: 3851
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Outside diff range and nitpick comments (2)
packages/rs-platform-version/src/version/v6.rs (2)
37-40
: LGTM with documentation suggestionThe comment clearly explains the change to allow pool withdrawals on any validator quorums. Consider adding:
- The previous limitation (only first two quorums)
- Reference to the Core v21 bug ticket/documentation
57-59
: Enhance documentationWhile the comment indicates the increase to 2000 Dash, it would be helpful to document:
- The previous limit value
- Rationale for choosing 2000 Dash as the new limit
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
📒 Files selected for processing (1)
packages/rs-platform-version/src/version/v6.rs
(1 hunks)
🔇 Additional comments (2)
packages/rs-platform-version/src/version/v6.rs (2)
29-30
: LGTM!
The protocol version constant is correctly defined and matches the file name.
32-68
: Verify version compatibility and test coverage
Given this is a WIP PR affecting critical financial limits, please ensure:
- All version combinations are compatible
- Comprehensive test coverage for:
- New daily withdrawal limit of 2000 Dash
- Pool withdrawals across all validator quorums
- Documentation updates reflecting these changes
Let's verify the version compatibility:
✅ Verification successful
Based on the extensive search results, I can now provide a final response regarding the withdrawal limit changes:
Withdrawal limit increase to 2000 Dash is properly implemented and tested
The code shows:
- The daily withdrawal limit is increased from 1000 to 2000 Dash in v1 implementation (packages/rs-dpp/src/withdrawal/daily_withdrawal_limit/v1/mod.rs)
- Comprehensive test coverage exists for withdrawal functionality including:
- Daily limit enforcement
- Pool withdrawals across validator quorums
- Transaction processing and status tracking
- Withdrawal expiration and retry mechanisms
- Documentation is updated in CHANGELOG.md reflecting these changes
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Description: Check for potential version mismatches or inconsistencies
# Look for other files referencing the old withdrawal limit
rg -l "daily.?withdrawal.?limit.*1000"
# Check for test files covering the new functionality
fd -g "*test*.rs" | xargs rg -l "daily.?withdrawal.?limit.*2000"
# Look for related documentation that might need updates
fd -g "*.md" | xargs rg -l "daily.?withdrawal.?limit"
Length of output: 163
Script:
#!/bin/bash
# Let's try a broader search to understand the withdrawal limit changes and tests
# Search for withdrawal limit related code
rg -A 5 "daily.?withdrawal.?limit"
# Search for withdrawal related tests
fd -g "*test*.rs" | xargs rg -A 5 "withdrawal"
# Search for version definitions to verify compatibility
rg "VERSION.*_V[0-9]"
# Look for any documentation about withdrawals
fd -g "CHANGELOG.md" -g "README.md" | xargs rg "withdrawal"
Length of output: 492915
…_given_by_identities` (#2309) Co-authored-by: Ivan Shumkov <[email protected]>
Issue being fixed or feature implemented
What was done?
How Has This Been Tested?
Breaking Changes
Checklist:
For repository code-owners and collaborators only
Summary by CodeRabbit
Release Notes
New Features
Bug Fixes
Documentation