From ab34881ca6ce83cd033103f9cd6e81321ea79017 Mon Sep 17 00:00:00 2001 From: Yhtyyar Sahatov Date: Mon, 27 May 2024 15:11:46 +0300 Subject: [PATCH 1/2] added SafeCast to whitelist --- slitherin/detectors/dubious_typecast.py | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/slitherin/detectors/dubious_typecast.py b/slitherin/detectors/dubious_typecast.py index 1c4e1aa..c030016 100644 --- a/slitherin/detectors/dubious_typecast.py +++ b/slitherin/detectors/dubious_typecast.py @@ -71,6 +71,8 @@ class DubiousTypecast(AbstractDetector): ) WIKI_RECOMMENDATION = "Use clear constants" + WHITELIST = ["SafeCast", "SignedMath"] # OZ + def analyze_irs(self, irs: List[Operation]) -> List[Tuple[str, str]]: results = [] for i in irs: @@ -98,6 +100,8 @@ def get_dubious_typecasts(self, fun: FunctionContract, params=None): def _detect(self): results = [] for contract in self.compilation_unit.contracts_derived: + if contract.name in self.WHITELIST: + continue for f in contract.functions: func_res = self.get_dubious_typecasts(f) if func_res: From cd55ff3ac4673ad0ab008c0db3a91515a97d8451 Mon Sep 17 00:00:00 2001 From: Yhtyyar Sahatov Date: Tue, 28 May 2024 12:34:44 +0300 Subject: [PATCH 2/2] updated docs --- docs/dubious_typecast.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/dubious_typecast.md b/docs/dubious_typecast.md index 1f94df4..70d1e81 100644 --- a/docs/dubious_typecast.md +++ b/docs/dubious_typecast.md @@ -8,7 +8,7 @@ ## Description -Highlights nonstandard typecasts. E.g: `uint256(uint8(K))` +Highlights explicit typecasts, where the result value can differ from the original one. E.g., `uint8(uint256(1e18))`, `uint256(int256(-1))`. ## Vulnerable Scenario