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

Bot Races, Scope, the Future of Judging #138

Open
GalloDaSballo opened this issue Jan 8, 2024 · 23 comments
Open

Bot Races, Scope, the Future of Judging #138

GalloDaSballo opened this issue Jan 8, 2024 · 23 comments

Comments

@GalloDaSballo
Copy link

Executive Summary

My argument is that Bot Races are a waste of money, and the experiment should end.

I will argue why and offer a path forward as well

  • End Bot Races
  • Bring Back 4nalyz3r as the only scope altering bot
  • Embrace 4nalyz3r as a Public Good and fund its development via small financial grants ($100 per selector)

I recommend Sponsors and Judges to comment on this issue as a means to clarify whether they have a different opinion

I urge Wardens to send more instances in which Bots have caused issues in judging as a means to learn from past events

Why did Bot Races start?

Bot races where created to:

  • Explore the new possibility of automated audits
  • Give Spammers a way out, instead of spamming the main contest

Did Bot Race Achieve Any of those goals?

New Audits Approach

Bot Races demonstrated that some bot automation can achieve a good enough result, quantifiably (from talking to racers) to between $50 and $1k in value.

That said, most bots are offered as pre-sales to projects, simply because no bot has offered any value that come close to manual review or more refined techniques such as invariant testing.

To this regard, bots have failed in showing a "new way for audits", they are at best a Certik / Source Hat substitute

And more generally, they are just a prettified checklist, something an intern could check given some guidance.

Have bots opened up a new source of offerings for C4?

I don't believe so.

As any offering of such low quality would come with high reputational risk, of giving automated stamps to scams, having a high % of exploits, both of which are not desireable.

Did the Spammers Stop?

Hell no, need I remind you that we've all been judging 1.5k+ findings contests consistently?

The amount of spammers has stabilized to a percentage of wardens, but the amount of spam has grown (in absolute terms), along with the growth of wardens

From ChatGPT crap, to the usual "quick qa scam", we are pretty familiar with the leeches, this is a valid problem

That bots didn't really help with

About Bot Races

Bot Races take, on average, 4 hours to judge

Funnily enough that's longer than the duration of the race itself

Bot Races have, on average a 5%+ of the total pot, many times offering a pot that is greater than the QA and Gas Pot Combined

Negative externalities of Bot Races

The additional work for presorters / judges <- Which is an obfuscated cost to the org, that is more than the Bot Fee

The cost to the sponsor <- Which is not in line with the value, for example auditbase would cost $150 / month (let's say $150), for 80% of the value provided by all bots

The constant change of scoping <- Many important findings have been either made OOS or in Scope because of Bot "mistakes"

The additional complexity in judging and scoring <- Changes to the baseline "known findings" imply a re-adjustment in judging all other reports

Scamming as a profession

There have been multiple instances of Bot omitting "obvious findings"

Some examples are (Please send more examples in the comments):

  • Delegate Omission as a direct "scam" of the pot
  • Admin Privilege brought back (Missing Finding)
  • Unitialized Proxies Scam

Some of the time it was possible to even see the Warden that "omitted" the finding, submit it in the main contest

This is an example of conflict of interest that stops working the second we question the morality of some wardens

We all understand that it is in the interest of the Bot Racer to omit a finding and then submit it in the main race

Examples of this have happened many times in the past, since the community get's used to something like admin privilege or fot always being QAs, they stop sending them.

Investigations

DELEGATE - Omissions - Abused afaict

https://gist.github.com/GalloDaSballo/378b21840f1ce063a5126f9785f920bc

IMPACT:

  • Time wasted
  • $1k / $5k in EV stolen from Wardens

ENS - False negative - Not abused afaict

Bot missed the lack of safe transfer, actually saying it was disputed

code-423n4/2023-10-ens-findings#91

https://github.com/code-423n4/2023-10-ens-findings/issues/

IMPACT:

  • Massive time waste (check the discussions)
  • 100% of the pot

NEXT GEN - Mitigation would cause critical issue

code-423n4/2023-10-nextgen-findings#1045

In this instance, implementing the suggested fix at face value would open up the sponsor to a critical issue

IMPACT:

  • Dangerous fix opens up to critical issues
  • Waste of time in arguing about hypotheticals

Conclusions

Bot Races introduce an issue related to the agency of the Sponsor

Some mitigations from Bot Races may be considered "obvious", others not so much

Because of the strict cadence between Bot Races and the Main Contest, this issue of agency is accentuated.

They create further complexity in an already complex judging environment

Solving the Problems

The real problems for C4 are:

  • Scope
  • Spam
  • Long term meta changes

Solving Scope

We can instantly solve scoping issues by falling back to 4nalyz3r

This will ensure that all contests have the same scope

All of the same OOS

We can change 4nalyz3r every 3 months or so (seasons if you will)

In which the bot will change

Spam

With the Supreme Court we defined a very lax QA judging process, that allows a Judge to skip many low quality spam submissions, as well as punish low inventiveness QA reports at their discretion.

This rule would entirely replace the need for a bot race output, ultimately the judge could "set the bar" as high as they see fit, and then score reports that surpass that base level

In lack of any evidence that bot races have removed spam, we already are using this heuristic, so no change is required

Long Term Meta Changes

This is the only reason why bots may have been a good idea, they could adapt and improve over time

In reality they have hit a cul de sac and some have even regressed

The path forward that I see is to take a very small amount from the C4 fee, something like $300 / $1000 per contest, and put it as a "public good pot"

This pot could be stewarded by 4nalyz3r maintainers and used to fund a few selectors over time.

For example, each new selector that is uniqu and is merged could be paid $100

This would require the work of the maintainer and 10 seconds of any competent judges time

There are many criticism for this.

But the alternative has been spending close to $200k for NOTHING.

ZERO.

NADA.

Bot racers have been paid to create their own moat, for this privilege to be abused, to no advantage to the organization, judging and the sponsor.

It's time we take the power back and give the money back to the main pot.

Conclusion

No longer offer bot races

Have Masons run 4nalyz3r, at no extra charge

Collect $300 / $1000 per contest

Define a simple $100 per selector, paid only on PR system and iterate on it

@0xA5DF
Copy link

0xA5DF commented Jan 8, 2024

I'd like to bring up something I've suggested in the past

  • Create a public wiki/list of all common QA/gas issues
  • Give one bot crew the opportunity to find those issues, in exchange for ~30% of the QA and Gas pots
  • If wardens find any instances that the bot missed - that would be deducted from the payment to the bot crew (we'll have to think of a formula that's fair and reasonable)

This would be much more efficient, since the ev for each bot crew is much higher. Currently the payout is split between 10-20 crews, in my suggestion one bot crew gets all of the payout.

@alex-ppg
Copy link

alex-ppg commented Jan 8, 2024

TL;DR

I am a huge proponent of a public goods static analyzer as I believe a collective open-source community is the best way to grow a viable static analyzer that can reliably detect a lot of cases. Ultimately, an open-source static analyzer would excel and overshadow any privately developed project in the long term and be a net positive for the security community.

Points of Discussion

The main problems I see with this particular proposal that are not directly addressed are as follows:

Problem 1: What happens to existing bot racer tools?

The experiment has spawned multiple bots that will ultimately end up in a graveyard. This seems to be a bit unfair to bot racers who have worked on their projects from scratch. I understand they have been rewarded via the bot races, but I think there will be major pushback due to this point not being addressed.

Solution 1: Priority of Detector Integration

A potential solution to this problem would be to provide bot racers with a priority in integrating their detectors to the 4nalyz3r (or whichever detector ends up being the base for C4). In turn, this will allow them to have their detectors rewarded by the scheme described in the proposal before other wardens can contribute, effectively converting their invested effort into real value for both C4 as well as themselves.

Problem 2: Reward per selector

I believe that a $100 reward per selector is low, especially when factoring in complex detection cases that should also eliminate false positives. A selector will most likely require a few hours to create and this would in turn make the hourly rate of wardens contributing to these selectors very low.

Solution 2: Incremental reward per selector

A curve should be defined for the "reward model" of selector implementations for the analyzer. As more selectors are added, the reward increases organically. This would ensure that "quick" selectors are added first with a lower price-per-selector while more complex selectors are added later as the simple cases are covered closer to 100%.

Problem 3: Who implements the selectors?

Presently, bot races led to the creation of the same detector across multiple codebases each with varying results. This would translate into a real problem for this initiative whereby a single selector would have multiple proposals as implementations for the reward pool.

Solution 3: Maintainer System

I think a maintainer system should be put in place similar to bot races whereby a subset of wardens is eligible for submitting their detectors for the 4nalyzer. This pool of users can begin with the existing bot racers, and open calls can follow whereby wardens can apply to become maintainers by producing a valid detector of sufficient quality.

After the maintainer system is established, a similar system to judging and presorting can be set in place whereby the maintainer with the least rewards is selected as the next implementor as long as they illustrate willingness and so on.

Conclusion

I ultimately think this is the way forward for C4 to minimize the burden on judges and pre-sorters while actively contributing to the security community as a whole. While some problems exist in killing the bot race program directly, I believe we can come up with incentives for existing bot racers to offset these problems and thus create a fair path forward for C4 and this experiment's conclusion.

Should we proceed with this path, a different organization issue should be opened to discuss the right way to judge selectors, how they should be rewarded, etc. I think this issue should contain itself to discussions around killing the experiment and how that would be perceived by the community, C4, as well as C4-affiliated members (judges, pre-sorters, bot racers, etc.).

@GalloDaSballo
Copy link
Author

I'd like to bring up something I've suggested in the past

  • Create a public wiki/list of all common QA/gas issues
  • Give one bot crew the opportunity to find those issues, in exchange for ~30% of the QA and Gas pots
  • If wardens find any instances that the bot missed - that would be deducted from the payment to the bot crew (we'll have to think of a formula that's fair and reasonable)

This would be much more efficient, since the ev for each bot crew is much higher. Currently the payout is split between 10-20 crews, in my suggestion one bot crew gets all of the payout.

I disagree with offering moats for no clear outcome
This would be a variation of bot races, and as I argued above it wouldn't resolve the spam issue, so there's no clear reason why one bot would be better than 0

The same logic could be solved at the 4nalyz3r level by rewarding contributors for open source work, which helps C4 (removes spam issues), and helps the community for a fraction of the cost

@GalloDaSballo
Copy link
Author

TL;DR

I am a huge proponent of a public goods static analyzer as I believe a collective open-source community is the best way to grow a viable static analyzer that can reliably detect a lot of cases. Ultimately, an open-source static analyzer would excel and overshadow any privately developed project in the long term and be a net positive for the security community.

I don't believe that C4 has any obligations towards Bot Racers, just like they have no obligations towards Wardens and Judge

I'd be happy to hear more thoughts around how to make OSS fair and paid in a way that incentivizes them, without causing the same issue of leeching.

@alex-ppg
Copy link

alex-ppg commented Jan 8, 2024

I don't believe that C4 has any obligations towards Bot Racers, just like they have no obligations towards Wardens and Judge

I'd be happy to hear more thoughts around how to make OSS fair and paid in a way that incentivizes them, without causing the same issue of leeching.

I believe the main problem with this train of thought is the assumptions around the lifetime of bot races. A better analogy here would be the announcement of a C4 contest of a specified pot, multiple wardens contributing their findings, and the contest ultimately being canceled with no rewards.

The above would be unfair because the wardens participated in anticipation of receiving (or at least participating in the chance to) a reward. Similarly, bot racers have been developing their tools to capture value and acquire income.

While we can argue that bot racers have been compensated via the races themselves by receiving rewards, we would not be accommodating to prospective bot racers who never had a chance to compete but did develop their tools. These individuals would have the entirety of their work dismissed with no form of compensation even though they anticipated one.

I proposed two ways we can fairly incentivize these individuals, ensuring that they can convert their effort into OSS value while being compensated for it:

  • Provide priority to these bot racers to integrate their detectors to the public goods C4 tool (i.e. 4nalyz3r in this discussion)
  • Implement a "contributor" member list which is initialized with the bot racers and open calls are routinely performed to introduce more members as well as remove the most inactive ones

In any case, I think we should offer some form of advantage to bot racers over normal individuals who want to contribute to the 4nalyzer to ensure that the bot racers can in some way "convert" the effort they have invested for bot races into the new approach C4 will implement in this regard.

@0xA5DF
Copy link

0xA5DF commented Jan 8, 2024

The same logic could be solved at the 4nalyz3r level by rewarding contributors for open source work, which helps C4 (removes spam issues), and helps the community for a fraction of the cost

You have a point, as long as we don't care for having lots of false positives then the 4nalyz3r is good enough.
I was for keeping a low percentage of false positives in the past, but I guess the sponsor can just go over it and filter them out.

Btw, if we're going to build a public analyzer then maybe we should base it on Slither, which does actual parsing of the code. But that might be more difficult to maintain.

@alex-ppg
Copy link

alex-ppg commented Jan 8, 2024

Btw, if we're going to build a public analyzer then maybe we should base it on Slither, which does actual parsing of the code. But that might be more difficult to maintain.

I think the 4nalyz3r is an ideal candidate as it is based on TypeScript (much more approachable), supports both RegEx as well as AST detectors (which parse the code and traverse it), and generally supports a flexible structure from a brief review.

Slither is already an open-source initiative but it is seldomly contributed to not only due to the absence of a reward but also due to the fact that its code is hard to grasp.

@trust1995
Copy link

First of all, I agree that the experiment failed. Overall, the costs in time and money associated with the bot race outweight any advantage gained from the bot (more work for judges, smaller pot for wardens, no novel findings introduced etc...)

It seems incentives are not there for bots to reach the next level of complexity, while the mechanics make bots converge to the same spam finds.

There would be more value to everyone if the sponsor just gets a pre-audit QA report which you can get off the shelf for $500.

The suggestion to revert to analyzer is a good one to have a baseline reduction of spam, more broadly the concept of a QA master / Gas master in charge of the respective races needs to be incorporated to allow the highly qualified judge role to focus on the main race.

@IllIllI000
Copy link

IllIllI000 commented Jan 8, 2024

I agree that the mechanic has been broken for a long time. If you look at the first ~10 races, I was adding new and useful unique findings almost every race. Suddenly when Alex stopped being the judge, and judges unfamiliar with findings were scoring things, my ranking dropped, and from then on, I've had to redirect significant effort, not only to tooling for judges (which C4 is reluctant to endorse despite judges actually using and liking it), but to writing extra 'dispute' rules, in order to compensate for C4's unwillingness to directly address bots with a lot of invalid findings. Bots were winning by overloading judges with a smattering of invalid findings which I was excluding, rather than actually winning on real findings. It appears from this org issue that I've wasted my time. As I've said before, I won't be contributing to any open source tools/lists, and I suspect a chunk of the other racers won't either.

@montyly
Copy link

montyly commented Jan 8, 2024

Sad to see the experiment's result, this was an interesting one to follow.

I would argue that Slither should be used here (full disclosure, I am Slither's author). Slither has significantly more capabilities than any other existing static analysis tools. It is more than an AST visitor: it has its own intermediate representation, inbuilt data dependencies, and has already 90+ detectors. Slither has been open source for years, and is already largely used by the community, with +100 contributors to it.

We (slither's team) would be more than happy to make its integration with code4rena easier, and increase its documentation for external contributions (if it's a blocker). We could even develop private capabilities for projects going through cod4rena if cod4rena is looking for it (ex: to ease the triage).

The reality is that maintaining a static analyzer is a huge effort, and something like "$300 / $1000 per contest" / "$100" per selector, is nowhere close to what is needed to maintain such a tool beyond the MVP phase. Relying on Slither, which is already maintained, is a better long term solution for the community imho.

@DadeKuma
Copy link

DadeKuma commented Jan 8, 2024

Current Issues

I agree that bot races are currently broken, but removing them entirely will not fix these issues.

Most of the best QAs before bot races existed, were actually submitted by bots. Now that bots are so advanced, no warden will be able to earn any money from QAs due to the sheer amount of issues submitted by bots.

Most of the "abuse" cited is due to the lack of rules for bot crews. There are a lot of controversial things happening, including:

  • Sponsors can decide to not have a bot race for a contest, but bots can submit their report as QA, nonetheless. This seems very wrong but it's within the rules, as they are just tools; with their sheer amount of submitted issues, they will likely get an A-rank, taking a huge chunk of the QA pool.
  • When we have a bot race, non-winning bots can re-submit their report as QA (by removing everything that was included in the winning report), so they get a double reward (from the bot race, and the contest QA pot).

These might be considered abuse, but they are actually expected by C4 and within the rules; most bot crews are already doing it.

My Opinion on Proposed Solutions

  • Having $100/selector as a grant for 4nalyz3r is ridiculously low, and very few people will ever do that. Building a good bot takes a huge amount of time, and in my opinion, it's barely worth it even with the current bot crew pot.

  • Hiring an external company/third party to do the pre-contest filtering seems very wrong. Imagine if C4 eliminates wardens, hires an external company to do the audit, and judges check only this report. While efficient, it destroys the very nature of C4 (decentralized audits).

Possible Solutions to Fix Bot Races

The main goals here are to cut judging time, improve the value added to the sponsor, reduce spam, and enhance the competitiveness of the bot races.

  • Remove the NonCritical and Refactoring issues from reports. While some might be useful, most of them are minor adjustments, or spam. This is a security review, and reports should focus on finding vulnerabilities. (This solution alone should cut judging time by ~75%).

  • Reduce the number of available slots. 20 is too many, and the sponsor will read only the best report. If we have only 10 spots, for example, judging time will be cut by ~50%. This will also improve the competitiveness of bots, as the bot pot will be less diluted, while the H/M pot for wardens will remain the same.

  • Penalize copy-paste detectors that have the same root cause. For example, IERC20 interface does not support decimals/name/symbol should be one single issue and not 3 separate ones. Bots are currently "farming" points by submitting as many issues as possible because they are rewarded for doing so. If some issues are obviously the same, rewritten with a minor variant, they should be penalized.

@dmvt
Copy link

dmvt commented Jan 9, 2024

I agree with @GalloDaSballo that bot races are a failed experiment and with his suggestions on how to fix / replace it. Let's not get lost in the weeds or specifics. The goal of bot races was to decrease spam and overall judging effort. This has not materialized and it's time for us to declare the experiment complete.

@0xEVom
Copy link

0xEVom commented Jan 9, 2024

I have an idea that attempts to find a sweet spot between incentivizing the development of powerful automated analysis and greatly reducing the associated costs, regardless of the tool that ends up being used.

I agree incentivizing new detectors upfront will not work for the reasons already mentioned unless we can offer larger grant-like incentives, and even then these efforts would have to be manually coordinated and the process would not benefit from the competitive incentive model that has brought Code4rena where it is today.

Instead, I propose we still keep a portion of the bot races budget and award it to valid bot findings from one canonical tool to which people contribute their detectors. The bot report would still be judged and its findings assessed as to their validity and awarded shares of the pot according to their severity, as with the H/M pot. Rewards would be paid out to the author of the detector, which would turn the task of contributing detectors from pro bono work to a nice passive income generating opportunity with upside potential (as the number of contests on code4rena increases)

I imagine this would incentivize the development of new detectors early on as the payout will likely be concentrated on fewer findings. It would also have the effect of creating a race to be the first to implement detectors that most bot racers have already developed. As far as I can tell, both of these effects are desirable.

Lastly, there's the problem of disicentivizing spam findings, which an approach like this would immensely exacerbate. One idea is to define a cumulative total false positive rate $r_f$ accross contests for each detector and to scale shares by this rate, which would incentivize the development of detectors which are as accurate as possible. The final shares received for a valid finding could be:

$S_h = 3$
$S_m = 2$
$S_l = 1$

$n_{\text{shares}} = S_{\text{severity}} \times (1 - r_f)$

@Superpassteque
Copy link

I'm currently writing my own bot, and I think ending the bot race will create a lot more spam than you expect, especially from partially implemented bots like mine.

I find it really annoying how many incorrect submissions and spam come from the winning bots, and everyone agrees they should definitely be penalized, not rewarded, for this. Both bot racers and judges are wasting time here.

I truly believe bot races are a step in the right direction, and I don't believe in a community-based approach. Instead, I think we should standardize bots and detectors: known detectors should have an ID, a title, and a description defined by C4, and some tools should be used to do 95% of the judging and scoring. While some may argue that this could help less advanced bots, I believe it will drastically improve the quality of submissions and foster competition for very accurate and innovative detectors, rather than just the number of submissions.

@Picodes
Copy link

Picodes commented Jan 9, 2024

We could debate endlessly on this. On my end, I fully support @GalloDaSballo's proposal.

The consensus is clearly that this experiment has failed, so let's not waste any more time and call it a day.

As suggested let's use 4nalyz3r or slither and pay $100-200 per merged selector and advise in a few months. In the worst case, it will be another interesting experiment that has failed; in the best case, we'll have contributed to a cool public good.

@adamavenir
Copy link
Contributor

adamavenir commented Jan 9, 2024

I think this is an interesting conversation and I hope it continues.

Even though the post is polemic, I agree with many of the critiques. At the same time, I’m not sure I agree with the conclusion and I disagree with at least four of the assumptions:

  1. Bot races were not solely introduced as a single solution to a single problem. Like many things Code4rena has done, they were the culmination of multiple threads.

  2. Bots have indeed reduced duplicate effort and spam. Maybe not as much as we’d want and maybe not at a great ROI, and undoubtedly we have other issues to deal with on those fronts, but they have had an impact.

  3. We can’t get rid of bots—they were here before bot races, they’d be here after. They’ll just be elsewhere, and increasingly so as time goes on. Far better to figure out a way to give them their own lane.

  4. In the three year history of Code4rena, there are paid findings that have easily contributed less value for far more than an aggregate $200k.

This thread is driving at closure and conclusions, but from the big picture of Code4rena, I am not presently convinced of any specific solution.

We’re not going to make a reactive change here. We’re going to be deliberate, listening to fact-based pros and cons people share rather than any specific conclusion or suggestion.

What would be extremely helpful is to see two new issues started and linked to this one:

  1. Bot problems
  2. Bot benefits

Both should be focused as much as possible on brief statements of facts and evidence, minimizing duplicate comments as much as practical.

Then we will have something useful from which to proceed.

Some important asides:

As an interdependent community, I don’t think anyone is served well by viewing this oppositionally or through the lens of factions.

I don’t think it’s appropriate or correct to label bot racers as professional scammers.

I apologize that I didn’t say that when you shared this with me before posting it, Alex. I have respect for the people doing this work, and this forum is not an acceptable place for this kind of labeling of fellow community members or their motivations. I didn’t fully understand your intent was to immediately post this, but I should have given you that feedback and for your sake as well as bot crews, I’m sorry to all that I didn’t. I take responsibility for that.

I think as lllll points out and dade agrees that there are some perverse incentives in bot races that have never been adjusted. Changes requested directly by bot racers to score penalties haven’t been implemented largely due to a combination of consent (judges/lookouts have a right to consent to what they’re being asked to do) and the sustainability question that underlies that.

@ryanjshaw
Copy link

We’re not going to make a reactive change here. We’re going to be deliberate, listening to fact-based pros and cons people share rather than any specific conclusion or suggestion.

Really glad to read this. There are some valid points being raised, but I think there's room for different recommendations and conclusions.

Because so many issues are being presented simultaneously here, and given it is much easier to dismiss something than to build a compelling case for that same thing, the time to provide thoughtful feedback is much appreciated.

@ihtisham-sudo
Copy link

ihtisham-sudo commented Jan 10, 2024

Woah, alot of critics and suggestions here. I'm not just proposing a solution i'm just pointing out what would be better for C4, Bot racers, protocols and community.

One of the competitive audit platform has introduced their own bot which is run on every audit by the platform itself.

If c4 had applied the same technique it would have been so much better.

As pointed out by other bot racers here that the current bot race mechanisms are broken and it's true.

How can we get rid of this broken mechainism and find a way that's better for everyone?

I'm partially agree with Gallo that C4 should have dedicated bot but not with the idea of getting rid of bot racers.

How can we acheive this by having a dedicated c4 bot and incentivize existing bot racers as well for the time they've invested.

The proposed suggestion would be c4 should work upon their dedicated c4 bot, whether its 4naly3er, Slither or a bot built from scratch, and hire only existing bot racers to sharpen c4 bot with their powerful detectors and get incentivized on detectors based like whenever there's bot race for new contest bot racers get incentivized for their detectors if their detectors found bug, and then open a Bot for everyone to contribute after some time when C4 bot reach to the level of exisitng top notch Bots.

The reason i'm emphasazing on dedicated c4 bot is because every protocol deserves a fair bot race.

What's mean by fair bot race? Let me explain....

Suppose there a unique detector to catch a unique bug in staking protocol in one of the great bot racer's bot let's assume it's lllll's bot as he said above that he was introduing unique detectors in every race.

But next time, he couldn't find time to participate in the next staking protocol and that unique bug that could be found by a Bot would now fall into HM's category and Pot and I think it's unfair with the protocol that tha bug that could be covered in Bot Race Pot now will be allocated from Protocol's HM Pot.

And MiloTruck also mentioned in his blog that one of the reason he quit bot racing was just because of unmatching time co-ordinates.

Suppose, again, Milo's Bot is one of the best in the town but he just can't participate due to time constraints.

Possible Suggestions

  • C4 should start working on their dedicated bot, and incentivize existing bot racers, by hiring them to contribute to the the Bot and get paid on detectors based they write.
  • Bot race would entirely be operated by C4, to just get fair with the protocol and not just spamming with more findings as addressed by lllll above that Bot racers are doing that.
  • Bot race operated by C4 would be unbaised as C4 dedicated Bot Race team will filter out spam finding and not include it in final reports as Exisitng Bot Racers are doing again referencing lllll point above.

Possible Outcomes

  • C4 has dedicated bot
  • Bot has same detectors running or every Contest Race, Fair with protocol and it doesn't exist now because Top racers are not participating in every contest. So a fair Race for every protocols.
  • C4 not getting rid of Bot race and bot racers, just reshaping it for the betterment. Bot racers were previously getting paid on their reports but now will get paid on the detectors they add. It's that simple.
  • C4 Bot will get unique and powerful detectors as everyone can't get their ++i will consume less gas detector merged in c4 Bot. Contributors will try to produce more unique detectors to get their detector merged in C4 Bot.
  • Time constraint for bot racers will be solved. Now you don't have to wake up at 4 A.M to participate in a bot race. Just make a detector, merge it in a dedicated C4 bot and sleep. You will get your money in your wallet every time c4 bot is run on a contest and your detector found a bug.
  • A win win for C4 (as it will have it's dedicated bot), Win Win for Bot racers (as they would be getting paid without having time constraints), A Win Win for protocol (as every protocol would get a fair bot race with same detectors)

Last Note For Bot Racers

As there were contradicts from bot racers that they won't be contributing to any other tool, so C4 couldn't get stick to anything that is not working and will get improvements. (Full disclosure, I'm not againt bot racers and I respect for their work)
Improvements come with changes and to acheive that C4 should have to make changes what's best for everyone.
C4 should welcome every exisiting bot racer to participate in their dedicated C4 bot. Whoever want to board in, Board in. And who doesn't want it's their choice. Because the Bot will be getting Top open source community to contribute.

@Superpassteque
Copy link

The proposed suggestion would be c4 should work upon their dedicated c4 bot, whether its 4naly3er, Slither or a bot built from scratch,

Not to mention the debate between Python and TypeScript, how are core changes compensated? Imagine implementing or enhancing Object/Graph/comment parsing capabilities in 4naly3er, maintaining over 1,000 detectors, or adding Vyper parsing.

A cost of $100 for each of the 1,000 detectors amounts to $100,000. This does not account for multiple iterations on the same detector, core changes, complex detectors I wouldn't implement for $100, and the proposed hypothetical passive income.

C4 Bot will get unique and powerful detectors as everyone can't get their ++i will consume less gas detector merged in c4 Bot. Contributors will try to produce more unique detectors to get their detector merged in C4 Bot.

You will get your money in your wallet every time c4 bot is run on a contest and your detector found a bug.

  1. This will give a lot of money to the actual bot racers for easy detectors everyone can do. It also screw best bot for worst one in the top 20 as winners take most disapear.
  2. As a bot racer, if this system were implemented, I would likely collect the last bit of income or passive income from my current detectors and retire, using my bot only for high/medium complexity issues that require manual selection. Like most bot racers, anything earning less than $500 for a day's work isn't worthwhile.
  3. Conversely, as a newcomer, I would have to directly aim for extremely challenging detectors that rarely trigger and might be improved by others. What then? Do I lose ownership? A detector is constantly refined through iterations as more data or new libraries comes in.
  4. C4 would need to be trusted with source code access, as this provides an advantage in fixing or improving a detector, thereby establishing ownership.
  5. The problem of farming detectors stay: more detectors = more money.

C4 is a competitive place and many are here of us for this: winner and hard workers take most. If I want to do pay for detector jobs I would go to Fiveer.

That's why I would prefer advocating for normalization and C4 tooling for merging/judging findings, which ultimately creates the same result: a competitive C4 bot based on external bots competing against each other. This can start small with common issues and probably all NC

@Alireza-Razavi
Copy link

Alireza-Razavi commented Jan 17, 2024

Hello everyone, I hope you are all doing well.
First of all, I apologize because my English is not very good.

Here i want to say my opinion about the bot-races.
The main idea is: We need to plan the bot-race pot in such a way that we get the most return from the racers.

How can we get the most return from the bot-racers ?

  1. The bot-race pot should be splitted exactly like the contest-pot.

Let's say 1 medium issue found in the race, and 20 low issues.
Only the racers who have found that medium should receive the award for that issue.
Also the same for that 20 lows, The low issues pot will be splitted between that 20 issues, then we check who found how many number of that 20 issues ?!

This motivates the racers to implement more Highs, Mediums and Lows.
Because if a racer finds a unique Medium for example, He will receive the whole pot for Medium issues.
So the racers try to implement more and more lows, mediums and highs and try to implement new detectors.

  1. NC (Non-critical) and similars should be removed from the bot-race, If you think we can't remove them from the bot-race so we can consider a very small pot for them (very small pot will prevent the racers to implement such spam detectors and spam findings).

Now the racers tries to implement more and more NCs to get higher ranking, but if we have a specific and small pot for NCs, then the racers will stop adding NC's and they will focus on Lows, Mediums and Highs.

@0xBinChook
Copy link

@GalloDaSballo an excellent write up there!

Bring Back 4nalyz3r as the only scope altering bot
Embrace 4nalyz3r as a Public Good and fund its development via small financial grants ($100 per selector)

Any open source proponent will whole heartily agree, supporting an open source static analyzer is great for the common good.

Due to the competitive nature, bot races can only incentivize the private development of closed source bots, with C4 currently provides both direct (via rewards) and indirect (judge / finding feedback) funding.

It make sense that C4 being an enterprise, would review/evaluate the cost/benefits of the product offering, and @sockdrawermoney outlines a sound approach for data gathering for a data driven decision

What would be extremely helpful is to see two new issues started and linked to this one:
Bot problems
Bot benefits

Looking forward to see the followup actions to this discussion 👍

@Alireza-Razavi
Copy link

@GalloDaSballo @Picodes @trust1995 @alex-ppg
If you remove the bot-race and use the 4naly3er as the main pre-analysis bot, i can promise you that i will implement all the detectors for free in 4naly3er.
Now my bot includes 90% of others detectors and i will push all of them into 4naly3er for free and i will add future detectors into 4naly3er as well.
Implementing such detectors/algorithms like other racers is something 5 minutes per detector.
Just tell me your opinion and if you ok, i will push and update all the detectors into 4naly3er.

The only motivation for me is to remove the ridiculous bot-race.

@PFAhard
Copy link

PFAhard commented Jan 20, 2024

I finally read most of this thread.

I would just like to add that many here make their claims based on the assumption that bot racers do not provide value of their own free will. But in reality this is not so, I created my bot even before bot racing, and my goal was to create an effective scanner capable of finding complex repetitive vulnerabilities.

But later I joined the bot race and was forced to abandon my goal, because the economic initiative, controlled by the judges, forces me to add useless copy-paste checks, 20 NatSpec instances, etc.

Only this allows you to stay in the upper half of the 20s. I and other wardens have complained multiple times on discord that judging results in reports that provide less benefit to the sponsor.

At the moment, I'm just tired of having to add useless, copy-paste checks, and I'm currently not putting much effort into improving the bot.

This was referenced Feb 29, 2024
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

No branches or pull requests