Skip to content
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

Closed
wants to merge 17 commits into from

Conversation

shumkov
Copy link
Member

@shumkov shumkov commented Oct 29, 2024

Issue being fixed or feature implemented

What was done?

How Has This Been Tested?

Breaking Changes

Checklist:

  • I have performed a self-review of my own code
  • I have commented my code, particularly in hard-to-understand areas
  • I have added or updated relevant unit/integration/functional/e2e tests
  • I have added "!" to the title and described breaking changes in the corresponding section if my code contains any
  • I have made corresponding changes to the documentation if needed

For repository code-owners and collaborators only

  • I have assigned this pull request to a milestone

Summary by CodeRabbit

Release Notes

  • New Features

    • Introduced a new daily withdrawal limit versioning system, allowing for enhanced withdrawal functionality.
    • Added support for a constant daily withdrawal limit of 2000 Dash.
    • Implemented a new protocol version (v6) with updated features across various components.
  • Bug Fixes

    • Improved error handling for withdrawal transactions and asset unlock scenarios.
  • Documentation

    • Updated comments and clarifications in the codebase for better understanding of withdrawal processes and error handling.

Copy link
Contributor

coderabbitai bot commented Oct 29, 2024

Important

Review skipped

Auto reviews are disabled on base/target branches other than the default branch.

Please check the settings in the CodeRabbit UI or the .coderabbit.yaml file in this repository. To trigger a single review, invoke the @coderabbitai review command.

You can disable this status message by setting the reviews.review_status to false in the CodeRabbit configuration file.

Walkthrough

The changes introduce a new versioning system for the daily withdrawal limit functionality, adding a v1 module and updating the existing daily_withdrawal_limit function to handle multiple versions. A new function, daily_withdrawal_limit_v1, is implemented to return a constant withdrawal limit. Additionally, various modules are updated to reflect new constants and methods related to error handling and transaction processing, including the introduction of v2 and v5 modules for method versioning.

Changes

File Path Change Summary
packages/rs-dpp/src/withdrawal/daily_withdrawal_limit/mod.rs Added module v1 and updated daily_withdrawal_limit to call v1::daily_withdrawal_limit_v1() for version 1.
packages/rs-dpp/src/withdrawal/daily_withdrawal_limit/v1/mod.rs Introduced daily_withdrawal_limit_v1 function returning a constant value of 2000 Dash in credits.
packages/rs-drive-abci/src/execution/engine/run_block_proposal/v0/mod.rs Updated logic in run_block_proposal_v0 for withdrawal transactions and refined error handling.
packages/rs-drive-abci/src/execution/platform_events/withdrawals/append_signatures_and_broadcast_withdrawal_transactions/v0/mod.rs Modified error handling constants and logic for asset unlock transactions.
packages/rs-drive-abci/src/rpc/core.rs Updated CoreRPCLike trait methods for transaction retrieval and removed obsolete error constants.
packages/rs-platform-version/src/version/dpp_versions/dpp_method_versions/mod.rs Added new module v2 for method versioning.
packages/rs-platform-version/src/version/dpp_versions/dpp_method_versions/v2.rs Introduced constant DPP_METHOD_VERSIONS_V2 with new version parameters.
packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/mod.rs Added new module v5 for method versioning.
packages/rs-platform-version/src/version/drive_abci_versions/drive_abci_method_versions/v5.rs Introduced constant DRIVE_ABCI_METHOD_VERSIONS_V5 encapsulating various method version structures.
packages/rs-platform-version/src/version/mod.rs Added module v6 and updated LATEST_VERSION to reference PROTOCOL_VERSION_6.
packages/rs-platform-version/src/version/v6.rs Introduced PROTOCOL_VERSION_6 and PLATFORM_V6 with updated versioning for various components.
packages/rs-platform-version/src/version/protocol_version.rs Updated LATEST_PLATFORM_VERSION to reference PLATFORM_V6 and modified PLATFORM_VERSIONS array to include it.

Possibly related PRs

Suggested labels

cleanup

Suggested reviewers

  • QuantumExplorer

🐰 In the meadow, changes bloom,
New limits set, dispelling gloom.
With versions fresh, we hop along,
To handle withdrawals, we sing our song!
A dash of code, a sprinkle of cheer,
In our rabbit hole, progress is near! 🐇✨


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?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

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)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

@shumkov shumkov changed the base branch from v1.4-dev to v1.5-dev October 29, 2024 05:36
@shumkov shumkov added this to the v1.5.0 milestone Oct 29, 2024
@shumkov shumkov changed the title chore(drive): reduce withdrawal limits chore(drive): reduce withdrawal limits [WIP] Oct 29, 2024
@shumkov shumkov marked this pull request as ready for review October 29, 2024 07:00
@shumkov shumkov self-assigned this Oct 29, 2024
pub const PROTOCOL_VERSION_5: ProtocolVersion = 5;

/// This version contains some fixes for withdrawals.
pub const PLATFORM_V5: PlatformVersion = PlatformVersion {
Copy link
Member Author

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

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nope

@thephez
Copy link
Collaborator

thephez commented Oct 30, 2024

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? 🤪

@shumkov shumkov changed the base branch from v1.5-dev to v1.6-dev November 1, 2024 01:53
…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
Copy link
Contributor

@coderabbitai coderabbitai bot left a 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:

  1. No protocol version 6 specific documentation was found in README files or docs directories
  2. The CHANGELOG entries mention withdrawal limit changes but don't specifically document protocol version 6 impacts
  3. No migration guide updates were found for the new protocol version
  4. 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 Updates

Since this introduces a new protocol version that affects withdrawal limits, ensure that:

  1. Release notes document the protocol version change
  2. Migration guides are updated
  3. 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.md

Length 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 increments

For 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 for pool_withdrawals_into_transactions_queue.

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between feacde2 and 61f3ce7.

📒 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:

  1. Updating the PR title to "chore(drive): increase withdrawal limit to 2000 Dash"
  2. 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: ⚠️ Breaking Change: Protocol Version Update

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: ⚠️ Potential issue

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:

  1. All dependent components are aware of this version change
  2. Migration paths are considered for existing deployments
  3. 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:

  1. The version change in PLATFORM_V5 is properly referenced across the codebase in protocol version management
  2. The withdrawal-related changes are well-structured with clear versioning (v0, v1, v2) and proper implementation across components
  3. 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:

  1. Ensure backward compatibility is maintained for existing withdrawal processing
  2. Update relevant documentation to reflect the version changes
  3. 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:

  1. Comments indicate the limit is actually increasing from 1000 to 2000
  2. 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.

Comment on lines +9 to +12
pub fn daily_withdrawal_limit_v1() -> Credits {
// 2000 Dash
200_000_000_000_000
}
Copy link
Contributor

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.

Suggested change
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;
Copy link
Contributor

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

packages/rs-platform-version/src/version/v6.rs Outdated Show resolved Hide resolved
Copy link
Contributor

@coderabbitai coderabbitai bot left a 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

📥 Commits

Reviewing files that changed from the base of the PR and between 61f3ce7 and 95b1b75.

📒 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

Copy link
Contributor

@coderabbitai coderabbitai bot left a 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 suggestion

The comment clearly explains the change to allow pool withdrawals on any validator quorums. Consider adding:

  1. The previous limitation (only first two quorums)
  2. Reference to the Core v21 bug ticket/documentation

57-59: Enhance documentation

While the comment indicates the increase to 2000 Dash, it would be helpful to document:

  1. The previous limit value
  2. Rationale for choosing 2000 Dash as the new limit
📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 95b1b75 and b21b4f1.

📒 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:

  1. All version combinations are compatible
  2. Comprehensive test coverage for:
    • New daily withdrawal limit of 2000 Dash
    • Pool withdrawals across all validator quorums
  3. 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

@shumkov shumkov closed this Dec 12, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

4 participants