Content pfp
Content
@
0 reply
0 recast
0 reaction

gilbert pfp
gilbert
@0xgib
Security question: If deploying a contract can take 100-1000x transactions, then how does upgrading a contract work for that same number of transactions? Will the contract still function? As its old version? Or do you upload to a buffer and switch to it in 1 tx instead?
1 reply
0 recast
0 reaction

shazow pfp
shazow
@shazow.eth
I believe it's the latter, you upload it into storage buffers then swap the pointer in the final transaction.
1 reply
0 recast
1 reaction

gilbert pfp
gilbert
@0xgib
That would be the sensible option, right? Still trying to find docs on it Might have to dig into the source code
3 replies
0 recast
0 reaction

shazow pfp
shazow
@shazow.eth
https://docs.solanalabs.com/cli/examples/deploy-a-program#using-an-intermediary-buffer-account Also the final section in these docs about how to do this offline.
2 replies
0 recast
0 reaction

shazow pfp
shazow
@shazow.eth
Also discussed here: https://solana.com/docs/programs/deploying#how-solana-program-deploy-works
1 reply
0 recast
0 reaction

gilbert pfp
gilbert
@0xgib
I did see the docs on buffers, but not on how upgrading works specifically. I did end up finding these docs on the upgrade instruction, which does turn out to require a buffer account, and also interestingly a "spill" account http://tinyurl.com/38ufph3f
1 reply
0 recast
0 reaction

shazow pfp
shazow
@shazow.eth
Sounds like the spill account is equivalent to the SELFDESTRUCT target address which sends remaining balance to it.
3 replies
0 recast
1 reaction

gilbert pfp
gilbert
@0xgib
Same mechanism, with the different purpose of making it easier to pay for storage
0 reply
0 recast
0 reaction

gilbert pfp
gilbert
@0xgib
Same mechanism, with the different purpose of making it easier to pay for storage
0 reply
0 recast
0 reaction

gilbert pfp
gilbert
@0xgib
Same mechanism, with the different purpose of making it easier to pay for storage
0 reply
0 recast
0 reaction