Bitget App
Trade smarter
Buy cryptoMarketsTradeFuturesCopyBotsEarn
Arbitrary Calls & New Slitherin Detector Release

Arbitrary Calls & New Slitherin Detector Release

Officer's BlogOfficer's Blog2023/10/19 16:15
By:Officer's Blog

Greetings, dear readers! Today we’ll look at the significant news and updates pertaining to our Slitherin project in this article. We assure you that it will be fascinating —  Slitherin , our own set of custom detectors for  Slither , another awesome update!

In recent months we have been actively developing our  own Slither detectors  to help with code  review  and audit process. More recently, we have released several new detectors and we encourage you to use them for your initial internal  audit , but let’s now get back to the point of our  conversation  today.

Simply put, our detectors are a kind of automation of the checks implemented in the  checklist , their main purpose is to look for issues and assist the code auditor. Today we’re going to  break  down our new  Arbitrary  Call detector and generally understand what it is!

We’ve applied some significant updates during this time, and we appreciate all of your love and attention. Please let us know if you have discovered an  issue/bug/vulnerability  via our custom  Slither  detectors. You may contact us via opening a  PR/Issue  or  directly , whichever is more convenient for you!

You can now install a fresh package:  pypi.org/project/slitherin !

If you have any further questions or suggestions, please  join our Discord Server  or  Telegram chat . We hope to see you there, and we intend to support the community and its  initiatives .

Thank you, let’s get it started!

Arbitrary Call: Detector

The  detector  iterates over all low-level calls, checks if the destination or calldata could be tainted(manipulated). All of the information about the detector is provided below.

Detector Structure

  • Check: pess-arbitrary-call

  • Severity: High

  • Confidence: Low

  • Test scenarios

General Recommendation: Do not allow users to make arbitrary calls!

Possible improvements: Filter out  role  protected calls, divide detector to multiple  detectors  with different severity and confidence.

If you have any further questions or suggestions, please  join our Discord Server  or  Telegram chat . We hope to see you there, and we intend to support the community and its initiatives!

Arbitrary Call: While Auditing

General idea: If a contract has arbitrary calls, it should generally not contain transfer/transferFrom/approve  calls . If such calls are in the contract, it means that the  contract  stores either tokens or approvals for them. Thus, they can be stolen via  arbitrary  calls to the token contract.

Below are our audit notes from which you will learn how exactly we came up with the idea of such a detector and what it actually is. Be sure to  study  them carefully!

Arbitrary Calls Breakdown

  • There is a call to a custom address;

  • There is a call with arbitrary calldata.

What You Need to Check

  • You can insert the address of the token and call the function transfer/transferFrom/approve;

  • You can get privileged access;

  • You can perform a  reentrancy ;

  • Other (order fill, strange/atypical staking, etc.)

Security Assumptions

  • Solidity offers convenient high-level syntax for  calling  functions in other contracts, but this high-level syntax is only available when the target contract’s  interface  is known at compile time,  read more here ;

  • Malicious contracts may withdraw the contract’s balance in response to external calls to arbitrary  addresses , resulting in a loss of funds. Due to this flaw,  attackers  can use the contract’s  capabilities  to their advantage and run  malicious  or unauthorized code that can extract assets from the contract or can break the working mechanism of the contract,  read more here .

Requires Special Care

  • In our audits, we’ve seen different methods like ActionOnBehalfOf — they require all sorts of approvals, but allow you to manage other people’s staking funds. This is quite a rare thing and it requires special care!

  • Besides the usual transfertransferFromapprove, it is necessary to check call scripts/scenarios into the same contract; for example, in one of the project’s code there was token staking (transferFrom(msg.sender, address(this), x)), but when withdrawing it was possible to specify receiver and withdraw there!

  • Call on behalf of the contract itself. For example, you can get into “protected” code (bypass access control)3+4. You can call yourself to make msg.sender == this. For example, transferFrom(msg.sender, this, N);

  • Transfer and approve may allow to  withdraw  tokens from the balance of the contract. And transferFrom may allow you to steal someone else’s tokens (using approvals for this contract).

What You Should Do

  • If possible, do not use  arbitrary  call ;

  • If there is an arbitrary call, the contract should not store token approves;

  • It is also better to make a layer to which approve is given.and the necessary tokens are thrown to the router;

  • Optionally the layer can be made  pausable  or add selfdestruct;

  • Try to minimize the number of “last minute” edits!

  • Try to filter function signatures that user provides!

Calls to “Custom” Addresses

  • Through an arbitrary call in a C1 contract, C2 can be called, which cares that it is C1 that calls it. This bypasses the msg.sender checks in C2. For example, let there be a system of two contracts C1 and C2:

a) C1.foo() makes an arbitrary call (in addition to possibly something else);

b) C1.bar() does all sorts of checks and calls C2.xyz();

c) C2.xyz() does something very important and is protected by onlyC1then the checks from C1.bar can be bypassed via C1.foo()->C2.xyz() (onlyC1 will not notice the trick;

  • If contract A has assets (ether or tokens) on contract A and contract A makes a delegatecall to “user” contract B, contract B can withdraw assets from contract A’s balance sheet;

  • We cannot rule out the case where there are no tokens, but there is a native currency. If the project is located on a specific chain where the native currency is a precompiled contract (e.g. Moonbeam and MOVR GLMR tokens), then a delegatecall can also be performed to it.  Vulnerability example ;

  • The use of fallback()-function in the contract code should be very careful. Thus, the presence of fallback()-function without revert and conditions allows to execute for this contract a function with any signature that is not presented in the source code of the contract (may be malicious);

  • Potential DoS: the address can simply drop or “eat” all the gas, the calling contract should not somehow lag or freeze from this (relevant for the State Machine pattern). Also relevant for `.send()`, `.transfer()`. ;

  • Delegatecall to a spoofed address can remove the calling contract or break storage completely;

  • Starting with 0.5, the compiler inserts a check of the called address (that it is a  contract and not EoA ). But for low-level calls (.call, .delegatecall and others) and assembly there is no such check. Calling a non-contract address will not create any errors, but the logic will not even start.

We finished our own research a few months ago; please read it if you haven’t already:

Slitherin X AuditWizard.io Collaboration

Recently, a specialized IDE was  released  — and it incorporates our  Slitherin  tool!

Arbitrary Calls & New Slitherin Detector Release image 0

Audit Wizard is an all-in-one  platform  for auditing smart contracts. Scan for  vulnerabilities , leverage AI for security insights, generate audit reports, and more. Read more about it in the  following  article by  Johnny Time !

Try our new detector locally or  via  the  auditwizard.io  alternative (and actually amazing!) UI:

In  auditwizard.io , results from dependencies have also been filtered out from Slither to remove unnecessary results.  Slitherin , an extended version of  Slither  with  even  more  vulnerability  detectors, has also been added to increase scanner coverage:

Arbitrary Calls & New Slitherin Detector Release image 1

We are very excited about this collaboration and hope to see Slitherin used in even more ways! In the near future, we intend to pitch  Slitherin    Spotter  at a significant number of  conferences , also:

  • Optimizations to our detectors are coming soon;

  • More detectors to be released soon as well;

  • Don’t forget to pull the changes:  github.com/pessimistic-io/slitherin ;

  • You can now install a fresh package:  pypi.org/project/slitherin !

We’ve also applied for specialized detectors through the Arbitrum grant ecosystem, and we’re planning two more projects. If you are interested, please contact us!

Slitherin Timeline 3.0

We’ve applied some significant updates during this time, and we appreciate all of your love and attention. Please let us know if you have discovered an  issue/bug/vulnerability  via our custom  Slither  detectors.

You may contact us via opening a  PR/Issue  or  directly , whichever is more convenient for you!

Slitherin  3.0 Updates

Major updates, reworks, additions, minor fixes optimization:

  1. pess-arbitrary-call detector: New detector. Thx  Yhtiyar ;

  2. pess-strange-setter detector: Functions with no parameters are no longer detected. Thx  @Yhtiyar ;

  3. pess-unprotected-setter detector: Now has a separate test file;

  4. Release Note .

If you have any further questions or suggestions, please  join our Discord Server  or  Telegram chat . We hope to see you there, and we intend to support the community and its initiatives. Thank you!

Our team would also like to express our deepest gratitude to the  Slither tool  creators:  Josselin Feist, Gustavo Grieco, and Alex Groce , as well as  Crytic ,  Trail of Bits’  blockchain security division, and all the people who believe in the  original  tool and its evolution!

We sincerely hope you find our work useful and appreciate any feedback, so please do not hesitate to  contact us ! The best answers and questions may be included in the next  blog  post. We hope that this article was informative and useful for you!

Stay safe!

Support is very important to me, with it I can do what I love — educating users!

  • Check out my GitHub

  • Follow my Twitter

  • Track all my activities

  • All my Socials

  • Join my TG channel

If you want to support my work, please, consider donating me:

  • 0xB25C5E8fA1E53eEb9bE3421C59F6A66B786ED77A  or  officercia.eth  — ETH, BSC, Polygon, Optimism, Zk, Fantom, etc

  • 17Ydx9m7vrhnx4XjZPuGPMqrhw3sDviNTU  — BTC

  • 4AhpUrDtfVSWZMJcRMJkZoPwDSdVG6puYBE3ajQABQo6T533cVvx5vJRc5fX7sktJe67mXu1CcDmr7orn1CrGrqsT3ptfds — Monero XMR

  • DeFi Roadmap grant page

Stay safe!

0

Disclaimer: The content of this article solely reflects the author's opinion and does not represent the platform in any capacity. This article is not intended to serve as a reference for making investment decisions.

PoolX: Locked for new tokens.
APR up to 10%. Always on, always get airdrop.
Lock now!

You may also like

Pro-crypto Pierre Poilievre leads Polymarket odds to become Canada's next prime minister, replacing Justin Trudeau

Users of the decentralized prediction platform Polymarket are giving 89% odds in favor of Pierre Poilievre becoming Canada’s next elected prime minister.The total trading volume on who will become Canada’s prime minister hit $412,095 on Monday, as Justin Trudeau tendered his resignation.

The Block2025/01/06 22:55