TW
Tripwire
Find contracts. Test them. Review real vulns.

Analysis Run

019b3844-93e1-73ac-96c3-f3749b4eb3d7

complete
Chain ID
1
Address
Block Number
Created
Fri, Dec 19, 2025 8:19 PM
Review Summary

What survived the funnel

Open this run to answer one question: is this real attacker-relevant behavior with real impact, or just normal contract plumbing?

Confirmed
0
Validated
0
Source
Bytecode only
Review Backing
Not yet
Best current signal
Authorization based on tx.origin
crit 0 high 0 direct contract
Review Checklist
1. Read the findings table first. Ignore raw jobs until the result looks real.
2. Confirm attacker control, not just the existence of a sink.
3. Confirm money or privilege impact.
4. Keep it if the behavior is real. Kill it if this is normal proxy, admin, or upgrade plumbing.

Processing Jobs

Status & attempts
ID Type Status Attempts Heartbeat
13115 artifact.fetch complete 1 / 3 3 months ago
13116 tool.cast_disasm complete 1 / 3 3 months ago
111770 analysis.bundle complete 1 / 3 1 week ago
111771 capability.graph complete 1 / 3 1 week ago
111772 detector.run complete 1 / 3 1 week ago
111773 validation.fork complete 1 / 3 1 week ago

Artifact

Runtime bytecode: available
Creation TX:
Deployer:
Proxy: no
Implementation:
Verified Source: no

Slither

tool.slither

No slither job recorded yet.

Codex

report.consolidate

No codex job recorded yet.

Opcode Heuristics

tool.cast_disasm
Delegatecall
0
Selfdestruct
0
CREATE2
0
CALL-family (heavy)
5
EXT*/BALANCE
5
Total opcodes
945
Flags
heavy_ext_balance_usage
View cast disassembly output
00000000: PUSH1 0x80
00000002: PUSH1 0x40
00000004: MSTORE
00000005: PUSH1 0x04
00000007: CALLDATASIZE
00000008: LT
00000009: PUSH2 0x0070
0000000c: JUMPI
0000000d: PUSH1 0x00
0000000f: CALLDATALOAD
00000010: PUSH1 0xe0
00000012: SHR
00000013: DUP1
00000014: PUSH4 0x74e7493b
00000019: GT
0000001a: PUSH2 0x004e
0000001d: JUMPI
0000001e: DUP1
0000001f: PUSH4 0x74e7493b
00000024: EQ
00000025: PUSH2 0x0224
00000028: JUMPI
00000029: DUP1
0000002a: PUSH4 0x8da5cb5b
0000002f: EQ
00000030: PUSH2 0x024e
00000033: JUMPI
00000034: DUP1
00000035: PUSH4 0xa6f9dae1
0000003a: EQ
0000003b: PUSH2 0x027f
0000003e: JUMPI
0000003f: DUP1
00000040: PUSH4 0xb69ef8a8
00000045: EQ
00000046: PUSH2 0x02b2
00000049: JUMPI
0000004a: PUSH2 0x0070
0000004d: JUMP
0000004e: JUMPDEST
0000004f: DUP1
00000050: PUSH4 0x06b091f9
00000055: EQ
00000056: PUSH2 0x019a
00000059: JUMPI
0000005a: DUP1
0000005b: PUSH4 0x2c4e722e
00000060: EQ
00000061: PUSH2 0x01d3
00000064: JUMPI
00000065: DUP1
00000066: PUSH4 0x2e1a7d4d
0000006b: EQ
0000006c: PUSH2 0x01fa
0000006f: JUMPI
00000070: JUMPDEST
00000071: CALLER
00000072: ORIGIN
00000073: EQ
00000074: PUSH2 0x0079
00000077: JUMPI
00000078: INVALID
00000079: JUMPDEST
0000007a: PUSH1 0x00
0000007c: SLOAD
0000007d: PUSH1 0x01
0000007f: PUSH1 0x01
00000081: PUSH1 0xa0
00000083: SHL
00000084: SUB
00000085: AND
00000086: CALLER
00000087: EQ
00000088: ISZERO
00000089: PUSH2 0x0091
0000008c: JUMPI
0000008d: PUSH2 0x0198
00000090: JUMP
00000091: JUMPDEST
00000092: PUSH1 0x00
00000094: PUSH2 0x00a8
00000097: PUSH1 0x02
00000099: SLOAD
0000009a: CALLVALUE
0000009b: PUSH2 0x02e0
0000009e: SWAP1
0000009f: SWAP2
000000a0: SWAP1
000000a1: PUSH4 0xffffffff
000000a6: AND
000000a7: JUMP
000000a8: JUMPDEST
000000a9: PUSH1 0x01
000000ab: SLOAD
000000ac: PUSH1 0x40
000000ae: DUP1
000000af: MLOAD
000000b0: PUSH4 0x70a08231
000000b5: PUSH1 0xe0
000000b7: SHL
000000b8: DUP2
000000b9: MSTORE
000000ba: ADDRESS
000000bb: PUSH1 0x04
000000bd: DUP3
000000be: ADD
000000bf: MSTORE
000000c0: SWAP1
000000c1: MLOAD
000000c2: SWAP3
000000c3: SWAP4
000000c4: POP
000000c5: PUSH1 0x01
000000c7: PUSH1 0x01
000000c9: PUSH1 0xa0
000000cb: SHL
000000cc: SUB
000000cd: SWAP1
000000ce: SWAP2
000000cf: AND
000000d0: SWAP2
000000d1: PUSH4 0x70a08231
000000d6: SWAP2
000000d7: PUSH1 0x24
000000d9: DUP1
000000da: DUP3
000000db: ADD
000000dc: SWAP3
000000dd: PUSH1 0x20
000000df: SWAP3
000000e0: SWAP1
000000e1: SWAP2
000000e2: SWAP1
000000e3: DUP3
000000e4: SWAP1
000000e5: SUB
000000e6: ADD
000000e7: DUP2
000000e8: DUP7
000000e9: DUP1
000000ea: EXTCODESIZE
000000eb: ISZERO
000000ec: DUP1
000000ed: ISZERO
000000ee: PUSH2 0x00f6
000000f1: JUMPI
000000f2: PUSH1 0x00
000000f4: DUP1
000000f5: REVERT
000000f6: JUMPDEST
000000f7: POP
000000f8: GAS
000000f9: STATICCALL
000000fa: ISZERO
000000fb: DUP1
000000fc: ISZERO
000000fd: PUSH2 0x010a
00000100: JUMPI
00000101: RETURNDATASIZE
00000102: PUSH1 0x00
00000104: DUP1
00000105: RETURNDATACOPY
00000106: RETURNDATASIZE
00000107: PUSH1 0x00
00000109: REVERT
0000010a: JUMPDEST
0000010b: POP
0000010c: POP
0000010d: POP
0000010e: POP
0000010f: PUSH1 0x40
00000111: MLOAD
00000112: RETURNDATASIZE
00000113: PUSH1 0x20
00000115: DUP2
00000116: LT
00000117: ISZERO
00000118: PUSH2 0x0120
0000011b: JUMPI
0000011c: PUSH1 0x00
0000011e: DUP1
0000011f: REVERT
00000120: JUMPDEST
00000121: POP
00000122: MLOAD
00000123: DUP2
00000124: GT
00000125: ISZERO
00000126: PUSH2 0x012b
00000129: JUMPI
0000012a: INVALID
0000012b: JUMPDEST
0000012c: PUSH1 0x01
0000012e: SLOAD
0000012f: PUSH1 0x40
00000131: DUP1
00000132: MLOAD
00000133: PUSH4 0xa9059cbb
00000138: PUSH1 0xe0
0000013a: SHL
0000013b: DUP2
0000013c: MSTORE
0000013d: CALLER
0000013e: PUSH1 0x04
00000140: DUP3
00000141: ADD
00000142: MSTORE
00000143: PUSH1 0x24
00000145: DUP2
00000146: ADD
00000147: DUP5
00000148: SWAP1
00000149: MSTORE
0000014a: SWAP1
0000014b: MLOAD
0000014c: PUSH1 0x01
0000014e: PUSH1 0x01
00000150: PUSH1 0xa0
00000152: SHL
00000153: SUB
00000154: SWAP1
00000155: SWAP3
00000156: AND
00000157: SWAP2
00000158: PUSH4 0xa9059cbb
0000015d: SWAP2
0000015e: PUSH1 0x44
00000160: DUP1
00000161: DUP3
00000162: ADD
00000163: SWAP3
00000164: PUSH1 0x00
00000166: SWAP3
00000167: SWAP1
00000168: SWAP2
00000169: SWAP1
0000016a: DUP3
0000016b: SWAP1
0000016c: SUB
0000016d: ADD
0000016e: DUP2
0000016f: DUP4
00000170: DUP8
00000171: DUP1
00000172: EXTCODESIZE
00000173: ISZERO
00000174: DUP1
00000175: ISZERO
00000176: PUSH2 0x017e
00000179: JUMPI
0000017a: PUSH1 0x00
0000017c: DUP1
0000017d: REVERT
0000017e: JUMPDEST
0000017f: POP
00000180: GAS
00000181: CALL
00000182: ISZERO
00000183: DUP1
00000184: ISZERO
00000185: PUSH2 0x0192
00000188: JUMPI
00000189: RETURNDATASIZE
0000018a: PUSH1 0x00
0000018c: DUP1
0000018d: RETURNDATACOPY
0000018e: RETURNDATASIZE
0000018f: PUSH1 0x00
00000191: REVERT
00000192: JUMPDEST
00000193: POP
00000194: POP
00000195: POP
00000196: POP
00000197: POP
00000198: JUMPDEST
00000199: STOP
0000019a: JUMPDEST
0000019b: CALLVALUE
0000019c: DUP1
0000019d: ISZERO
0000019e: PUSH2 0x01a6
000001a1: JUMPI
000001a2: PUSH1 0x00
000001a4: DUP1
000001a5: REVERT
000001a6: JUMPDEST
000001a7: POP
000001a8: PUSH2 0x0198
000001ab: PUSH1 0x04
000001ad: DUP1
000001ae: CALLDATASIZE
000001af: SUB
000001b0: PUSH1 0x40
000001b2: DUP2
000001b3: LT
000001b4: ISZERO
000001b5: PUSH2 0x01bd
000001b8: JUMPI
000001b9: PUSH1 0x00
000001bb: DUP1
000001bc: REVERT
000001bd: JUMPDEST
000001be: POP
000001bf: PUSH1 0x01
000001c1: PUSH1 0x01
000001c3: PUSH1 0xa0
000001c5: SHL
000001c6: SUB
000001c7: DUP2
000001c8: CALLDATALOAD
000001c9: AND
000001ca: SWAP1
000001cb: PUSH1 0x20
000001cd: ADD
000001ce: CALLDATALOAD
000001cf: PUSH2 0x0342
000001d2: JUMP
000001d3: JUMPDEST
000001d4: CALLVALUE
000001d5: DUP1
000001d6: ISZERO
000001d7: PUSH2 0x01df
000001da: JUMPI
000001db: PUSH1 0x00
000001dd: DUP1
000001de: REVERT
000001df: JUMPDEST
000001e0: POP
000001e1: PUSH2 0x01e8
000001e4: PUSH2 0x03c2
000001e7: JUMP
000001e8: JUMPDEST
000001e9: PUSH1 0x40
000001eb: DUP1
000001ec: MLOAD
000001ed: SWAP2
000001ee: DUP3
000001ef: MSTORE
000001f0: MLOAD
000001f1: SWAP1
000001f2: DUP2
000001f3: SWAP1
000001f4: SUB
000001f5: PUSH1 0x20
000001f7: ADD
000001f8: SWAP1
000001f9: RETURN
000001fa: JUMPDEST
000001fb: CALLVALUE
000001fc: DUP1
000001fd: ISZERO
000001fe: PUSH2 0x0206
00000201: JUMPI
00000202: PUSH1 0x00
00000204: DUP1
00000205: REVERT
00000206: JUMPDEST
00000207: POP
00000208: PUSH2 0x0198
0000020b: PUSH1 0x04
0000020d: DUP1
0000020e: CALLDATASIZE
0000020f: SUB
00000210: PUSH1 0x20
00000212: DUP2
00000213: LT
00000214: ISZERO
00000215: PUSH2 0x021d
00000218: JUMPI
00000219: PUSH1 0x00
0000021b: DUP1
0000021c: REVERT
0000021d: JUMPDEST
0000021e: POP
0000021f: CALLDATALOAD
00000220: PUSH2 0x03c8
00000223: JUMP
00000224: JUMPDEST
00000225: CALLVALUE
00000226: DUP1
00000227: ISZERO
00000228: PUSH2 0x0230
0000022b: JUMPI
0000022c: PUSH1 0x00
0000022e: DUP1
0000022f: REVERT
00000230: JUMPDEST
00000231: POP
00000232: PUSH2 0x0198
00000235: PUSH1 0x04
00000237: DUP1
00000238: CALLDATASIZE
00000239: SUB
0000023a: PUSH1 0x20
0000023c: DUP2
0000023d: LT
0000023e: ISZERO
0000023f: PUSH2 0x0247
00000242: JUMPI
00000243: PUSH1 0x00
00000245: DUP1
00000246: REVERT
00000247: JUMPDEST
00000248: POP
00000249: CALLDATALOAD
0000024a: PUSH2 0x0419
0000024d: JUMP
0000024e: JUMPDEST
0000024f: CALLVALUE
00000250: DUP1
00000251: ISZERO
00000252: PUSH2 0x025a
00000255: JUMPI
00000256: PUSH1 0x00
00000258: DUP1
00000259: REVERT
0000025a: JUMPDEST
0000025b: POP
0000025c: PUSH2 0x0263
0000025f: PUSH2 0x0432
00000262: JUMP
00000263: JUMPDEST
00000264: PUSH1 0x40
00000266: DUP1
00000267: MLOAD
00000268: PUSH1 0x01
0000026a: PUSH1 0x01
0000026c: PUSH1 0xa0
0000026e: SHL
0000026f: SUB
00000270: SWAP1
00000271: SWAP3
00000272: AND
00000273: DUP3
00000274: MSTORE
00000275: MLOAD
00000276: SWAP1
00000277: DUP2
00000278: SWAP1
00000279: SUB
0000027a: PUSH1 0x20
0000027c: ADD
0000027d: SWAP1
0000027e: RETURN
0000027f: JUMPDEST
00000280: CALLVALUE
00000281: DUP1
00000282: ISZERO
00000283: PUSH2 0x028b
00000286: JUMPI
00000287: PUSH1 0x00
00000289: DUP1
0000028a: REVERT
0000028b: JUMPDEST
0000028c: POP
0000028d: PUSH2 0x0198
00000290: PUSH1 0x04
00000292: DUP1
00000293: CALLDATASIZE
00000294: SUB
00000295: PUSH1 0x20
00000297: DUP2
00000298: LT
00000299: ISZERO
0000029a: PUSH2 0x02a2
0000029d: JUMPI
0000029e: PUSH1 0x00
000002a0: DUP1
000002a1: REVERT
000002a2: JUMPDEST
000002a3: POP
000002a4: CALLDATALOAD
000002a5: PUSH1 0x01
000002a7: PUSH1 0x01
000002a9: PUSH1 0xa0
000002ab: SHL
000002ac: SUB
000002ad: AND
000002ae: PUSH2 0x0441
000002b1: JUMP
000002b2: JUMPDEST
000002b3: CALLVALUE
000002b4: DUP1
000002b5: ISZERO
000002b6: PUSH2 0x02be
000002b9: JUMPI
000002ba: PUSH1 0x00
000002bc: DUP1
000002bd: REVERT
000002be: JUMPDEST
000002bf: POP
000002c0: PUSH2 0x02c7
000002c3: PUSH2 0x0477
000002c6: JUMP
000002c7: JUMPDEST
000002c8: PUSH1 0x40
000002ca: DUP1
000002cb: MLOAD
000002cc: SWAP3
000002cd: DUP4
000002ce: MSTORE
000002cf: PUSH1 0x20
000002d1: DUP4
000002d2: ADD
000002d3: SWAP2
000002d4: SWAP1
000002d5: SWAP2
000002d6: MSTORE
000002d7: DUP1
000002d8: MLOAD
000002d9: SWAP2
000002da: DUP3
000002db: SWAP1
000002dc: SUB
000002dd: ADD
000002de: SWAP1
000002df: RETURN
000002e0: JUMPDEST
000002e1: PUSH1 0x00
000002e3: DUP3
000002e4: PUSH2 0x02ef
000002e7: JUMPI
000002e8: POP
000002e9: PUSH1 0x00
000002eb: PUSH2 0x033c
000002ee: JUMP
000002ef: JUMPDEST
000002f0: DUP3
000002f1: DUP3
000002f2: MUL
000002f3: DUP3
000002f4: DUP5
000002f5: DUP3
000002f6: DUP2
000002f7: PUSH2 0x02fc
000002fa: JUMPI
000002fb: INVALID
000002fc: JUMPDEST
000002fd: DIV
000002fe: EQ
000002ff: PUSH2 0x0339
00000302: JUMPI
00000303: PUSH1 0x40
00000305: MLOAD
00000306: PUSH3 0x461bcd
0000030a: PUSH1 0xe5
0000030c: SHL
0000030d: DUP2
0000030e: MSTORE
0000030f: PUSH1 0x04
00000311: ADD
00000312: DUP1
00000313: DUP1
00000314: PUSH1 0x20
00000316: ADD
00000317: DUP3
00000318: DUP2
00000319: SUB
0000031a: DUP3
0000031b: MSTORE
0000031c: PUSH1 0x21
0000031e: DUP2
0000031f: MSTORE
00000320: PUSH1 0x20
00000322: ADD
00000323: DUP1
00000324: PUSH2 0x04fc
00000327: PUSH1 0x21
00000329: SWAP2
0000032a: CODECOPY
0000032b: PUSH1 0x40
0000032d: ADD
0000032e: SWAP2
0000032f: POP
00000330: POP
00000331: PUSH1 0x40
00000333: MLOAD
00000334: DUP1
00000335: SWAP2
00000336: SUB
00000337: SWAP1
00000338: REVERT
00000339: JUMPDEST
0000033a: SWAP1
0000033b: POP
0000033c: JUMPDEST
0000033d: SWAP3
0000033e: SWAP2
0000033f: POP
00000340: POP
00000341: JUMP
00000342: JUMPDEST
00000343: PUSH1 0x00
00000345: SLOAD
00000346: PUSH1 0x01
00000348: PUSH1 0x01
0000034a: PUSH1 0xa0
0000034c: SHL
0000034d: SUB
0000034e: AND
0000034f: CALLER
00000350: EQ
00000351: PUSH2 0x0356
00000354: JUMPI
00000355: INVALID
00000356: JUMPDEST
00000357: PUSH1 0x00
00000359: DUP1
0000035a: SLOAD
0000035b: PUSH1 0x40
0000035d: DUP1
0000035e: MLOAD
0000035f: PUSH4 0xa9059cbb
00000364: PUSH1 0xe0
00000366: SHL
00000367: DUP2
00000368: MSTORE
00000369: PUSH1 0x01
0000036b: PUSH1 0x01
0000036d: PUSH1 0xa0
0000036f: SHL
00000370: SUB
00000371: SWAP3
00000372: DUP4
00000373: AND
00000374: PUSH1 0x04
00000376: DUP3
00000377: ADD
00000378: MSTORE
00000379: PUSH1 0x24
0000037b: DUP2
0000037c: ADD
0000037d: DUP6
0000037e: SWAP1
0000037f: MSTORE
00000380: SWAP1
00000381: MLOAD
00000382: SWAP2
00000383: DUP6
00000384: AND
00000385: SWAP3
00000386: PUSH4 0xa9059cbb
0000038b: SWAP3
0000038c: PUSH1 0x44
0000038e: DUP1
0000038f: DUP5
00000390: ADD
00000391: SWAP4
00000392: DUP3
00000393: SWAP1
00000394: SUB
00000395: ADD
00000396: DUP2
00000397: DUP4
00000398: DUP8
00000399: DUP1
0000039a: EXTCODESIZE
0000039b: ISZERO
0000039c: DUP1
0000039d: ISZERO
0000039e: PUSH2 0x03a6
000003a1: JUMPI
000003a2: PUSH1 0x00
000003a4: DUP1
000003a5: REVERT
000003a6: JUMPDEST
000003a7: POP
000003a8: GAS
000003a9: CALL
000003aa: ISZERO
000003ab: DUP1
000003ac: ISZERO
000003ad: PUSH2 0x03ba
000003b0: JUMPI
000003b1: RETURNDATASIZE
000003b2: PUSH1 0x00
000003b4: DUP1
000003b5: RETURNDATACOPY
000003b6: RETURNDATASIZE
000003b7: PUSH1 0x00
000003b9: REVERT
000003ba: JUMPDEST
000003bb: POP
000003bc: POP
000003bd: POP
000003be: POP
000003bf: POP
000003c0: POP
000003c1: JUMP
000003c2: JUMPDEST
000003c3: PUSH1 0x02
000003c5: SLOAD
000003c6: DUP2
000003c7: JUMP
000003c8: JUMPDEST
000003c9: PUSH1 0x00
000003cb: SLOAD
000003cc: PUSH1 0x01
000003ce: PUSH1 0x01
000003d0: PUSH1 0xa0
000003d2: SHL
000003d3: SUB
000003d4: AND
000003d5: CALLER
000003d6: EQ
000003d7: PUSH2 0x03dc
000003da: JUMPI
000003db: INVALID
000003dc: JUMPDEST
000003dd: PUSH1 0x00
000003df: DUP1
000003e0: SLOAD
000003e1: PUSH1 0x40
000003e3: MLOAD
000003e4: PUSH1 0x01
000003e6: PUSH1 0x01
000003e8: PUSH1 0xa0
000003ea: SHL
000003eb: SUB
000003ec: SWAP1
000003ed: SWAP2
000003ee: AND
000003ef: SWAP2
000003f0: DUP4
000003f1: ISZERO
000003f2: PUSH2 0x08fc
000003f5: MUL
000003f6: SWAP2
000003f7: DUP5
000003f8: SWAP2
000003f9: DUP2
000003fa: DUP2
000003fb: DUP2
000003fc: DUP6
000003fd: DUP9
000003fe: DUP9
000003ff: CALL
00000400: SWAP4
00000401: POP
00000402: POP
00000403: POP
00000404: POP
00000405: ISZERO
00000406: DUP1
00000407: ISZERO
00000408: PUSH2 0x0415
0000040b: JUMPI
0000040c: RETURNDATASIZE
0000040d: PUSH1 0x00
0000040f: DUP1
00000410: RETURNDATACOPY
00000411: RETURNDATASIZE
00000412: PUSH1 0x00
00000414: REVERT
00000415: JUMPDEST
00000416: POP
00000417: POP
00000418: JUMP
00000419: JUMPDEST
0000041a: PUSH1 0x00
0000041c: SLOAD
0000041d: PUSH1 0x01
0000041f: PUSH1 0x01
00000421: PUSH1 0xa0
00000423: SHL
00000424: SUB
00000425: AND
00000426: CALLER
00000427: EQ
00000428: PUSH2 0x042d
0000042b: JUMPI
0000042c: INVALID
0000042d: JUMPDEST
0000042e: PUSH1 0x02
00000430: SSTORE
00000431: JUMP
00000432: JUMPDEST
00000433: PUSH1 0x00
00000435: SLOAD
00000436: PUSH1 0x01
00000438: PUSH1 0x01
0000043a: PUSH1 0xa0
0000043c: SHL
0000043d: SUB
0000043e: AND
0000043f: DUP2
00000440: JUMP
00000441: JUMPDEST
00000442: PUSH1 0x00
00000444: SLOAD
00000445: PUSH1 0x01
00000447: PUSH1 0x01
00000449: PUSH1 0xa0
0000044b: SHL
0000044c: SUB
0000044d: AND
0000044e: CALLER
0000044f: EQ
00000450: PUSH2 0x0455
00000453: JUMPI
00000454: INVALID
00000455: JUMPDEST
00000456: PUSH1 0x00
00000458: DUP1
00000459: SLOAD
0000045a: PUSH1 0x01
0000045c: PUSH1 0x01
0000045e: PUSH1 0xa0
00000460: SHL
00000461: SUB
00000462: NOT
00000463: AND
00000464: PUSH1 0x01
00000466: PUSH1 0x01
00000468: PUSH1 0xa0
0000046a: SHL
0000046b: SUB
0000046c: SWAP3
0000046d: SWAP1
0000046e: SWAP3
0000046f: AND
00000470: SWAP2
00000471: SWAP1
00000472: SWAP2
00000473: OR
00000474: SWAP1
00000475: SSTORE
00000476: JUMP
00000477: JUMPDEST
00000478: PUSH1 0x01
0000047a: SLOAD
0000047b: PUSH1 0x40
0000047d: DUP1
0000047e: MLOAD
0000047f: PUSH4 0x70a08231
00000484: PUSH1 0xe0
00000486: SHL
00000487: DUP2
00000488: MSTORE
00000489: ADDRESS
0000048a: PUSH1 0x04
0000048c: DUP3
0000048d: ADD
0000048e: DUP2
0000048f: SWAP1
00000490: MSTORE
00000491: SWAP2
00000492: MLOAD
00000493: SWAP2
00000494: BALANCE
00000495: SWAP3
00000496: PUSH1 0x00
00000498: SWAP3
00000499: PUSH1 0x01
0000049b: PUSH1 0x01
0000049d: PUSH1 0xa0
0000049f: SHL
000004a0: SUB
000004a1: SWAP1
000004a2: SWAP2
000004a3: AND
000004a4: SWAP2
000004a5: PUSH4 0x70a08231
000004aa: SWAP2
000004ab: PUSH1 0x24
000004ad: DUP1
000004ae: DUP4
000004af: ADD
000004b0: SWAP3
000004b1: PUSH1 0x20
000004b3: SWAP3
000004b4: SWAP2
000004b5: SWAP1
000004b6: DUP3
000004b7: SWAP1
000004b8: SUB
000004b9: ADD
000004ba: DUP2
000004bb: DUP7
000004bc: DUP1
000004bd: EXTCODESIZE
000004be: ISZERO
000004bf: DUP1
000004c0: ISZERO
000004c1: PUSH2 0x04c9
000004c4: JUMPI
000004c5: PUSH1 0x00
000004c7: DUP1
000004c8: REVERT
000004c9: JUMPDEST
000004ca: POP
000004cb: GAS
000004cc: STATICCALL
000004cd: ISZERO
000004ce: DUP1
000004cf: ISZERO
000004d0: PUSH2 0x04dd
000004d3: JUMPI
000004d4: RETURNDATASIZE
000004d5: PUSH1 0x00
000004d7: DUP1
000004d8: RETURNDATACOPY
000004d9: RETURNDATASIZE
000004da: PUSH1 0x00
000004dc: REVERT
000004dd: JUMPDEST
000004de: POP
000004df: POP
000004e0: POP
000004e1: POP
000004e2: PUSH1 0x40
000004e4: MLOAD
000004e5: RETURNDATASIZE
000004e6: PUSH1 0x20
000004e8: DUP2
000004e9: LT
000004ea: ISZERO
000004eb: PUSH2 0x04f3
000004ee: JUMPI
000004ef: PUSH1 0x00
000004f1: DUP1
000004f2: REVERT
000004f3: JUMPDEST
000004f4: POP
000004f5: MLOAD
000004f6: SWAP2
000004f7: SWAP3
000004f8: SWAP1
000004f9: POP
000004fa: JUMP
000004fb: INVALID
000004fc: MSTORE8
000004fd: PUSH2 0x6665
00000500: UNKNOWN(0x4D)
00000501: PUSH2 0x7468
00000504: GASPRICE
00000505: KECCAK256
00000506: PUSH14 0x756c7469706c69636174696f6e20
00000515: PUSH16 0x766572666c6f77a265627a7a72305820
00000526: UNKNOWN(0x4C)
00000527: SELFBALANCE
00000528: PUSH24 0x12f9d7d478e070e9e97b658a66848d193aa121eb1095fb89
00000541: GASPRICE
00000542: PUSH28
View stderr
Warning: This is a nightly build of Foundry. It is recommended to use the latest stable version. To mute this warning set `FOUNDRY_DISABLE_NIGHTLY_WARNING` in your environment.

Findings

validated = confirmed for call sinks; sink observed for others
Severity Category Tool Title Confidence Validated Confirmed Details
high auth detector Authorization based on tx.origin 70 no
view
validation_json
{
    "reason": "missing sink mapping",
    "status": "no_sink"
}
witness_json
{
    "notes": "heuristic witness; entrypoints are best-effort selectors with zeroed calldata",
    "constraints": [],
    "entrypoints": [
        {
            "calldata": "0x74e7493b",
            "selector": "0x74e7493b",
            "calldata_variants": [
                "0x74e7493b",
                "0x74e7493b0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x8da5cb5b",
            "selector": "0x8da5cb5b",
            "calldata_variants": [
                "0x8da5cb5b",
                "0x8da5cb5b0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0xa6f9dae1",
            "selector": "0xa6f9dae1",
            "calldata_variants": [
                "0xa6f9dae1",
                "0xa6f9dae10000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0xb69ef8a8",
            "selector": "0xb69ef8a8",
            "calldata_variants": [
                "0xb69ef8a8",
                "0xb69ef8a80000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x06b091f9",
            "selector": "0x06b091f9",
            "calldata_variants": [
                "0x06b091f9",
                "0x06b091f90000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x2c4e722e",
            "selector": "0x2c4e722e",
            "calldata_variants": [
                "0x2c4e722e",
                "0x2c4e722e0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x2e1a7d4d",
            "selector": "0x2e1a7d4d",
            "calldata_variants": [
                "0x2e1a7d4d",
                "0x2e1a7d4d0000000000000000000000000000000000000000000000000000000000000000"
            ]
        }
    ]
}
evidence_json
{
    "guards_detected": [
        {
            "pc": 115,
            "type": "tx_origin_used"
        },
        {
            "pc": 114,
            "type": "tx_origin_used"
        }
    ]
}
medium other detector Untrusted CALL target/value reachable 45 no no
view
trace_id: 0x494436f75997f3f551069df5e0791fd445fa65eb8accecd921671152c72ed846
call_targets: 0xbb27cdd72fc42a538727f29f23d47972b8dfa405
target_varies: no
classification: constant_target
validation_json
{
    "sink": "CALL",
    "errors": 0,
    "status": "sink_reached",
    "attempts": 1,
    "trace_id": "0x494436f75997f3f551069df5e0791fd445fa65eb8accecd921671152c72ed846",
    "confirmed": false,
    "trace_mode": "callTracer",
    "call_targets": [
        "0xbb27cdd72fc42a538727f29f23d47972b8dfa405"
    ],
    "matched_probe": null,
    "target_varies": false,
    "classification": "constant_target"
}
witness_json
{
    "notes": "heuristic witness; entrypoints are best-effort selectors with zeroed calldata",
    "constraints": [],
    "entrypoints": [
        {
            "calldata": "0x74e7493b",
            "selector": "0x74e7493b",
            "calldata_variants": [
                "0x74e7493b",
                "0x74e7493b0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x8da5cb5b",
            "selector": "0x8da5cb5b",
            "calldata_variants": [
                "0x8da5cb5b",
                "0x8da5cb5b0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0xa6f9dae1",
            "selector": "0xa6f9dae1",
            "calldata_variants": [
                "0xa6f9dae1",
                "0xa6f9dae10000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0xb69ef8a8",
            "selector": "0xb69ef8a8",
            "calldata_variants": [
                "0xb69ef8a8",
                "0xb69ef8a80000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x06b091f9",
            "selector": "0x06b091f9",
            "calldata_variants": [
                "0x06b091f9",
                "0x06b091f90000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x2c4e722e",
            "selector": "0x2c4e722e",
            "calldata_variants": [
                "0x2c4e722e",
                "0x2c4e722e0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x2e1a7d4d",
            "selector": "0x2e1a7d4d",
            "calldata_variants": [
                "0x2e1a7d4d",
                "0x2e1a7d4d0000000000000000000000000000000000000000000000000000000000000000"
            ]
        }
    ]
}
evidence_json
{
    "examples": [
        {
            "pc": 385,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        },
        {
            "pc": 937,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        },
        {
            "pc": 1023,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        }
    ],
    "call_count": 3,
    "guards_detected": [
        {
            "pc": 115,
            "type": "tx_origin_used"
        },
        {
            "pc": 114,
            "type": "tx_origin_used"
        }
    ],
    "untrusted_call_count": 3
}
medium other detector ETH value transfer possible 40 no no
view
trace_id: 0x494436f75997f3f551069df5e0791fd445fa65eb8accecd921671152c72ed846
call_targets: 0xbb27cdd72fc42a538727f29f23d47972b8dfa405
target_varies: no
classification: constant_target
validation_json
{
    "sink": "CALL",
    "errors": 0,
    "status": "sink_reached",
    "attempts": 1,
    "trace_id": "0x494436f75997f3f551069df5e0791fd445fa65eb8accecd921671152c72ed846",
    "confirmed": false,
    "trace_mode": "callTracer",
    "call_targets": [
        "0xbb27cdd72fc42a538727f29f23d47972b8dfa405"
    ],
    "matched_probe": null,
    "target_varies": false,
    "classification": "constant_target"
}
witness_json
{
    "notes": "heuristic witness; entrypoints are best-effort selectors with zeroed calldata",
    "constraints": [],
    "entrypoints": [
        {
            "calldata": "0x74e7493b",
            "selector": "0x74e7493b",
            "calldata_variants": [
                "0x74e7493b",
                "0x74e7493b0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x8da5cb5b",
            "selector": "0x8da5cb5b",
            "calldata_variants": [
                "0x8da5cb5b",
                "0x8da5cb5b0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0xa6f9dae1",
            "selector": "0xa6f9dae1",
            "calldata_variants": [
                "0xa6f9dae1",
                "0xa6f9dae10000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0xb69ef8a8",
            "selector": "0xb69ef8a8",
            "calldata_variants": [
                "0xb69ef8a8",
                "0xb69ef8a80000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x06b091f9",
            "selector": "0x06b091f9",
            "calldata_variants": [
                "0x06b091f9",
                "0x06b091f90000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x2c4e722e",
            "selector": "0x2c4e722e",
            "calldata_variants": [
                "0x2c4e722e",
                "0x2c4e722e0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x2e1a7d4d",
            "selector": "0x2e1a7d4d",
            "calldata_variants": [
                "0x2e1a7d4d",
                "0x2e1a7d4d0000000000000000000000000000000000000000000000000000000000000000"
            ]
        }
    ]
}
evidence_json
{
    "examples": [
        {
            "pc": 385,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        },
        {
            "pc": 937,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        },
        {
            "pc": 1023,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        }
    ],
    "eth_value_calls": 3,
    "guards_detected": [
        {
            "pc": 115,
            "type": "tx_origin_used"
        },
        {
            "pc": 114,
            "type": "tx_origin_used"
        }
    ]
}