-
Notifications
You must be signed in to change notification settings - Fork 1k
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
Adding Scheduler and Cron Job Functionality #2903
Comments
I remember there was similar idea from @Liaojinghui |
Duplicates #2817, which in turn duplicates a set of older issues mentioned there (but those are closed). |
I believe this post is more fleshed out in scope, I also commented on #672 in my case, I have a function where people will provide NFTs and tokens and if my off-chain server is offline, crashed, or down for any reason, those users assets are locked in limbo because the contract has no way to auto timeout or cancel that operation after X hours. additionally: simply invoking a contract that updates values daily or weekly without an RPC hook would be amazing for large scale contracts. end of the day, discussion needs to happen around some form of autonomation on the platform. even if its some sort of CRON scheduler on the NVM |
I remember to close mine #672 |
do u really want a million threads or timers running on a handful of nodes? Yes, there is many way of doing this, But bottom line is someone is going to have to pay the server resource cost. Having consensus doing it or having every node doing it; isn't practical. One practical solution is to make your plugin for neo-cli and do things that way or write your own |
that's what gas is for? we already do this with oracle, only difference is we introduce a custom delay. and the meta doesn't need to rely on egress. it's easily an extension of that or something that gets passed onto the parent infrastructure. not sure how the scalability would result in millions of threads as you could easily run this on a single service. Code you provided looks like a great starting point, I don't run a node personally but this could be standardized with idempotency. are there other options within the tech stack to register events onto a single thread? |
Your forgetting about something needs to run 24/7 to see the time and would have to potentially run tons of operations (invokeinng tasks). so who will be responsible for 100% Fault tolerance and never going down or never miss a schedule. There is no refund process (besides the gas you get for holding NEO). I'm not saying it's a bad idea or not possible. The way things in code function need to be revamped.... NEO 5.0
Just need some re-structure in code. Neo need to meet the architect, if u know what i mean.
The VM isn't anything more than a calculator (scientific one at that). But currently what i have drawn up is the simplest form to integrate with Neo. I have been for a while now building a system that does just that; what you are asking for. But this would be a 3rd party service...mostly free if not free at the start. Neo would need a system for refunds; if jobs are missed or delayed... among other things. |
the server structure that runs the node/chain is live in parallel with the chain and could talk to the contracts. being time related, its not essential to be within a single block but can be invoked at a later point. I am highly tempted to make something myself but I am not a block chain/node dev - my area is Javascript/Typescript |
@cschuchardt88 not that heavy load as you expected, leader checks it when a new consensus starts, even its time based, its block index based, cant be some |
@Liaojinghui You could convert my Crontab Plugin into service like that of oracle service. You would have to add the interop service. Than add something like "if crontab job successful than send transaction for contract invoking, than send payment for the service transaction". I think that would be the best the solution. So this way people that install the |
In general, I prefer keeping the oldest one open and closing duplicates, even if they add something, they're not going away after closure and can be referred to/discussed. But hey, I don't even have any buttons to press here, so. Let me throw some random thoughts in:
At the same time an idea from #672 (comment) can be implemented with NVBs (#1992) safely now even with a single third-party entity. A service can accept transactions that transfer some GAS to its account (in a regular way) and do whatever they want to do with regular witnesses. A user can send a set of transactions to it with NVB fields set to 100, 200, 300, etc and service couldn't send these transactions before NVB. But it's still economically motivated to hold them in the queue and release when time comes (caveat: transaction can fail and in this case the service would get nothing). Not exactly the perfect solution, but a solution that can be implemented with 3.6 right now. |
Summary:
Despite significant advancements in blockchain technology, native support for scheduling and executing functions at specific time intervals, including both one-time and repeating events, remains lacking. Many blockchain applications currently rely on external solutions for time-based events, which can be complex, less secure, and unreliable. This proposal addresses this gap by introducing a native scheduler and cron job functionality within Neo smart contracts.
Proposal:
The primary goal of this proposal is to innovate Neo smart contracts by introducing a built-in scheduler. This empowers contracts to autonomously schedule and execute functions at custom intervals, enhancing reliability and self-sufficiency. Additionally, it underscores the necessity of unique identifiers to ensure idempotency on the blockchain and to facilitate the management of previously scheduled events.
Features:
Scheduler Functionality:
Neo smart contracts will include a native scheduler to automate the execution of functions at specific time intervals, enabling both one-time and repeating events. Developers can configure the timing of function executions. For example, "1 hour" can be used for a one-time event, while "every 6 hours" can be employed for a repeating event. Timezone offsets from -12 to +12 can be applied. If a schedule uses "0" as the interval, it will fire on the next block.
(specifics of the intervals should not emulate cron jobs directly but be sculpted to the requirements of the blockchain per its needs)
Unique Identifiers:
Each scheduled event is associated with a unique identifier generated by the contract. This identifier enables the management of scheduled events, including updates and deletions. It ensures that scheduled events are idempotent and can be tracked and managed efficiently.
Benefits:
Enhanced Neo smart contract versatility with native support for both one-time and repeating event scheduling.
Reduced reliance on external off-chain solutions for time-based events.
Improved transparency and auditing through dedicated event logging, separate from normal invocations.
Ensured idempotency and reliability with unique identifiers that facilitate scheduler management.
Provision for fallback invocations to handle cases when off-chain requests may have failed, ensuring robustness and continuity of contract actions.
Neo Version
Where in the software does this update applies to?
The text was updated successfully, but these errors were encountered: