-
Notifications
You must be signed in to change notification settings - Fork 5.4k
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
Spending gas from contract's balance - proposed optional opcode for a contract #61
Comments
ehhh...sounds like you'd need a very good reputation system involved inherently in the contract and it would make them quite complicated. I don't think I'd support this. |
Not necessarily. The contract could maintain its own list of member to whom it covers the costs. E.g. if you do something monetized, then the more transactions you do with the contract the more it could take off your costs, possibly reaching almost only the call cost. I think this idea has merits but probably needs to be thought through well :) Edit: The reason this might not be essential is because we could "emulate" this behavior by the contract refunding its processing costs before returning. Though that's quite hackish. |
Okay @karalabe so what you're saying is that it could choose different members to siphon off of in future calls and build up a kind of debt based system to enable cheaper calls to newcomers of a Dapp? Am I understanding you correctly? Is that the use case you had in mind or ones like it? |
I've been thinking about this problem for a while and I came up with the following solution. What if the miners maintained a list of contracts that would pay the No need for additional opcodes or alteration to the protocol, just need to persuade miners to run certain "trusted" contracts of which they know will pay them regardless of gas price. |
that'll be dangerous if implemented incorrectly...has to be done perfectly. |
@VoR0220 feel free to list your concerns. One possible obstacle is if you'd use real ether (i.e. ether from the contract). Please note that it doesn't need to be, it could be anything. It could some pegged (or not) to some (sub)currency. That's the beauty of it all, we can implement whatever we want. |
I think that with the abstraction EIP, all miners have to have a whitelist of entry-level contract code (patterns) they want to execute. My guess would be that it is safer to extend this whitelist with patterns like this over time, but it might be that this will not work for all use cases. |
I could even partner up with a mining pool to execute transactions for free to my contract and I'll pay them in cash off Ethereum :) |
if my understanding is correct, these trusted contracts would essentially be creating a credit system. If that credit system fails under any circumstance miners get shafted, but remember miners aren't one body coming debating with each other whether or not to raise or accept something from somebody, they are a body of machines just saying we agree that these transactions have been processed and this code has been executed. Per reputation systems, and whether or not to accept certain ones, that could leave a healthy portion of miners getting the shaft in their decision if a large set of miners decide to take on the risk...and should they fail there's an attack on the miners who chose not to take the risk as the losses are effectively socialized. |
these are just my ramblings and thoughts currently. If somebody wants to explain how this could be sheltered from this form of attack I'm open to suggestions. |
@VoR0220 it is entirely optional and this behaviour is turned off by default, no need for reputation databases. If the author of the contract deems that certain addresses (knowing by the time of writing the contract, or programatically deciding on what conditions lead to an address earning trust) are trustable, it can turn off this feature for calls originating from them. The current proposal is that happens via an opcode, e.g. the sender still has to have enough gas to execute the contract up to the point this opcode is executed. No one outside of the contract can execute that opcode on behalf of it and the contract needs to have enough balance to cover it. |
So essentially having it so that rather than the user paying for it out of their account, the contract creates a store of ether, and from there, executes the code from its stockpile rather than the callers account? Is that what you're saying? |
@VoR0220 but the contract still has a store of ether, doesn't it? Is that being removed? |
depends. I'd think you'd have to have a special balance tied to contracts that is completely separated from other balances of the contract for these purposes. You don't want contracts suddenly raiding your funds that you've entrusted it with (see modifiers). But I could see that being useful. |
@VoR0220 that's why the limit must accompany the opcode. It is up to the contract then to decide when and how much limit he gives to a certain incoming transaction. |
interesting. But that only accounts for gas costs...you'd still need to put it as its own "reserve" so to speak. Or atleast enable ways to sequester that payment ability from other functions of the contract. |
As an intermediate solution, @gavofyork suggested that a contract owner could have:
While this is definitely doable, it is only a workaround. |
@axic I agree. That sounds like the pain in the dick method. Isn't there a way we could make this a trustless solution? |
I still think the original proposal (which might have been slightly misinterpreted) makes sense. As a concept take the following Solidity code. It is the fallback function, which is called when no data is being sent (i.e. regular value transfer):
The above code could also decide to use different gas values based on what gas limit was provided by the caller. If paygas > totalgas, that means the contract is paying in full. It also means that there must be enough gas limit supplied to reach and execute the code until and including the |
I completely agree. I think this should be doable. |
main issue with this is putting 10 ether in a contract and sending a tx that runs:
it will run OOG only after 4.7m (or whatever block gas limit is) of miner compute time is spent, yet nobody will end up paying anything since it'll be reverted. basically, PAYGAS needs checkpointing to work safely. |
Well that's to be expected, yes. Any other specifics you might have in mind? |
I'm also running into this issue. |
I believe the contract-sponsored transactions will have an enormous impact on overall user experience and can potentially widen the Ethereum adoption. As you don't have to have ETH to call certain methods in the contract if your address is white-listed in the contract. I'm still a noob in Ethereum, so please tell me if the following proposal is possible. Essentially it is an incentive model for miners to include zero-gas-price transactions in a block.
Is it possible in theory? |
This is exactly what I was thinking, i.e to charge user a fixed cost for services, and price services as per custom business model instead of data and execution cost. The contract will be responsible for managing transaction cost. The difference between cost charged and spent will be profit. This also encourages devs to design optimal contracts to maximise gains |
There has been no activity on this issue for two months. It will be closed in a week if no further activity occurs. If you would like to move this EIP forward, please respond to any outstanding feedback or add a comment indicating that you have addressed all required feedback and are ready for a review. |
This issue was closed due to inactivity. If you are still pursuing it, feel free to reopen it and respond to any feedback or request a review in a comment. |
chore: fixes and improvements to solana caip10 and caip2
Currently the gas limit is defined and paid by the caller. This proposal is about adding an option to the VM to set an alternate gas limit and gas source (the contract) by means of executing a special opcode within the contract, e.g.
PAYGAS <limit>
A simple use case: the contract decides that the caller is on the list of trusted sources (for example it is a token holder) and takes over paying the gas. Alternatively the gas limit provided by the caller is used until exhausted, before using the contract's balance. This would be especially useful at fallback entry points enabling simple transactions to interact with a contract.
As you can see this idea is a a very early stage and comments are more than welcome.
The text was updated successfully, but these errors were encountered: