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

solana: Add SPL multisig support #568

Merged
merged 19 commits into from
Jan 20, 2025
Merged

solana: Add SPL multisig support #568

merged 19 commits into from
Jan 20, 2025

Conversation

nvsriram
Copy link
Collaborator

@nvsriram nvsriram commented Dec 3, 2024

This PR adds:

  • initialize_multisig and release_inbound_multisig_mint to act as multisig variants of initialize and release_inbound_mint respectively
  • Refactor out common structs and function logic to avoid duplication
  • Update test to verify independent minting capability after transferring authority to multisig
  • Update IDL

@nvsriram nvsriram linked an issue Dec 3, 2024 that may be closed by this pull request
@nvsriram nvsriram marked this pull request as ready for review December 3, 2024 19:27
Copy link
Contributor

@kcsongor kcsongor left a comment

Choose a reason for hiding this comment

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

overall looks good, but most of the code is duplication from the original versions. I wonder if we could refactor to share the logic?

@nvsriram
Copy link
Collaborator Author

overall looks good, but most of the code is duplication from the original versions. I wonder if we could refactor to share the logic?

I tried refactoring out the common structs and code logic to form a "clean" solution (the latest WIP commit). However, with this, we break the ABI as the accounts are now passed in differently for the original initialize and release_inbound_mint instructions.

If I were to preserve the ABI, there is minimal/no refactoring possible for the structs. This makes it difficult to use refactored code logic as there is no common shared struct that can be used; instead every required account has to be passed explicitly. Although I prefer the "clean" solution as it reduces code duplication and makes the -multisig variants/ any future variants easy to follow, its downside of breaking ABI makes it not super viable.

Ideally, we'd want to refactor code without breaking the ABI.

nonergodic
nonergodic previously approved these changes Dec 13, 2024
Copy link
Collaborator

@nonergodic nonergodic left a comment

Choose a reason for hiding this comment

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

Only nits.

nonergodic
nonergodic previously approved these changes Dec 23, 2024
Copy link
Collaborator

@nonergodic nonergodic left a comment

Choose a reason for hiding this comment

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

Again, only nits. If you decide to address them, I promise I'll be quick with rubberstamping those changes this time around.

Copy link
Collaborator

@nonergodic nonergodic left a comment

Choose a reason for hiding this comment

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

Two more remarks.

nonergodic
nonergodic previously approved these changes Dec 24, 2024
Copy link
Collaborator

@nonergodic nonergodic left a comment

Choose a reason for hiding this comment

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

👍

kcsongor
kcsongor previously approved these changes Jan 17, 2025
nonergodic
nonergodic previously approved these changes Jan 17, 2025
@nvsriram nvsriram dismissed stale reviews from nonergodic and kcsongor via f49e1f4 January 20, 2025 02:37
@nvsriram nvsriram merged commit 3311787 into main Jan 20, 2025
9 checks passed
@nvsriram nvsriram deleted the solana/multisig branch January 20, 2025 20:36
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Solana: adding support for minting via SPL multisig program
3 participants