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

Analysis Run

019b3836-3752-727e-a7df-5e44dd0611d6

complete
Chain ID
1
Address
Block Number
Created
Fri, Dec 19, 2025 8:03 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
2
Validated
2
Source
Bytecode only
Review Backing
Not yet
Best current signal
Untrusted CALL target/value reachable
crit 0 high 2 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
3735 artifact.fetch complete 1 / 3 3 months ago
3736 tool.cast_disasm complete 1 / 3 3 months ago
105225 analysis.bundle complete 1 / 3 1 week ago
105226 capability.graph complete 1 / 3 1 week ago
105227 detector.run complete 1 / 3 1 week ago
105228 validation.fork complete 1 / 3 1 week ago
113899 report.consolidate complete 1 / 6 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
Job Status
complete
Attempts
1 / 6
Findings
0
No findings?
View stderr
OpenAI Codex v0.118.0 (research preview)
--------
workdir: /tmp/codex-0g2uowx3
model: gpt-5.4
provider: openai
approval: never
sandbox: read-only
reasoning effort: high
reasoning summaries: none
session id: 019d5ca2-4a31-7313-bdb5-f71bf378ae15
--------
user
You are a security auditor. You ONLY have runtime bytecode + analysis artifacts.
You MUST read `BYTECODE_BUNDLE.json` before concluding; it contains the bytecode summary,
evidence bundle, callsites, storage slots, and detector findings.

Special cases when reasoning from bytecode (be explicit about uncertainty):
- Selector inference is best-effort; missing selectors are common.
- Fallback/receive paths may be the only entrypoints.
- CALL vs DELEGATECALL semantics differ; DELEGATECALL executes in caller storage.
- Proxy patterns (EIP-1967, minimal proxies, beacon) change which storage is authoritative.
- Storage slots are raw; mappings/arrays appear via keccak patterns, names are unknown.
- Guard detection is heuristic; absence of guards does NOT mean unguarded.
- Returndata checking is unknown unless explicitly shown in evidence.
- Precompiles (0x1..0x9) and common ERC20 transfer selectors may appear; do not over-claim.

Output MUST be valid JSON matching the provided schema.
- If you find nothing meaningful: set no_findings=true and findings=[].
- Otherwise: set no_findings=false and include findings with severity/category/title.
- Locations can be pc references like "pc:0x123" or selectors like "selector:0xa9059cbb".

Focus on: reentrancy, access control, upgradeability/proxy issues, signature validation,
accounting/invariant breaks, dangerous delegatecall, and untrusted external calls.
Be conservative: if evidence is weak, mark severity low/medium and explain why.
warning: Codex could not find system bubblewrap on PATH. Please install bubblewrap with your package manager. Codex will use the vendored bubblewrap in the meantime.
ERROR: You've hit your usage limit. Visit https://chatgpt.com/codex/settings/usage to purchase more credits or try again at Apr 8th, 2026 9:11 AM.
ERROR: You've hit your usage limit. Visit https://chatgpt.com/codex/settings/usage to purchase more credits or try again at Apr 8th, 2026 9:11 AM.
Metadata
{
    "codex": {
        "ran_at": "2026-04-05T07:53:54.579199+00:00",
        "returncode": 1
    },
    "project": {
        "mode": "bytecode",
        "bytecode_length": 2628,
        "bytecode_truncated": false,
        "capability_graph_present": true,
        "analysis_artifact_present": true
    },
    "summary": null,
    "no_findings": null,
    "schema_version": 1
}

Opcode Heuristics

tool.cast_disasm
Delegatecall
0
Selfdestruct
0
CREATE2
0
CALL-family (heavy)
4
EXT*/BALANCE
1
Total opcodes
752
Flags
No heuristic flags raised.
View cast disassembly output
00000000: PUSH1 0x60
00000002: PUSH1 0x40
00000004: MSTORE
00000005: CALLDATASIZE
00000006: ISZERO
00000007: PUSH2 0x006c
0000000a: JUMPI
0000000b: PUSH1 0xe0
0000000d: PUSH1 0x02
0000000f: EXP
00000010: PUSH1 0x00
00000012: CALLDATALOAD
00000013: DIV
00000014: PUSH4 0x01cb3b20
00000019: DUP2
0000001a: EQ
0000001b: PUSH2 0x0082
0000001e: JUMPI
0000001f: DUP1
00000020: PUSH4 0x29dcb0cf
00000025: EQ
00000026: PUSH2 0x0131
00000029: JUMPI
0000002a: DUP1
0000002b: PUSH4 0x38af3eed
00000030: EQ
00000031: PUSH2 0x013a
00000034: JUMPI
00000035: DUP1
00000036: PUSH4 0x6e66f6e9
0000003b: EQ
0000003c: PUSH2 0x014c
0000003f: JUMPI
00000040: DUP1
00000041: PUSH4 0x7a3a0e84
00000046: EQ
00000047: PUSH2 0x015e
0000004a: JUMPI
0000004b: DUP1
0000004c: PUSH4 0x7b3e5e7b
00000051: EQ
00000052: PUSH2 0x0167
00000055: JUMPI
00000056: DUP1
00000057: PUSH4 0xa035b1fe
0000005c: EQ
0000005d: PUSH2 0x0170
00000060: JUMPI
00000061: DUP1
00000062: PUSH4 0xdc0d3dff
00000067: EQ
00000068: PUSH2 0x0179
0000006b: JUMPI
0000006c: JUMPDEST
0000006d: PUSH2 0x01ed
00000070: PUSH1 0x07
00000072: SLOAD
00000073: PUSH1 0x00
00000075: SWAP1
00000076: PUSH1 0xff
00000078: AND
00000079: ISZERO
0000007a: PUSH2 0x0310
0000007d: JUMPI
0000007e: PUSH2 0x0002
00000081: JUMP
00000082: JUMPDEST
00000083: PUSH2 0x01ed
00000086: PUSH1 0x03
00000088: SLOAD
00000089: PUSH1 0x00
0000008b: SWAP1
0000008c: TIMESTAMP
0000008d: LT
0000008e: PUSH2 0x030d
00000091: JUMPI
00000092: PUSH1 0x02
00000094: SLOAD
00000095: PUSH1 0x01
00000097: SLOAD
00000098: SWAP1
00000099: LT
0000009a: PUSH2 0x03b8
0000009d: JUMPI
0000009e: PUSH1 0x02
000000a0: SLOAD
000000a1: DUP2
000000a2: SLOAD
000000a3: PUSH1 0x01
000000a5: PUSH1 0xa0
000000a7: PUSH1 0x02
000000a9: EXP
000000aa: SUB
000000ab: AND
000000ac: SWAP1
000000ad: DUP3
000000ae: SWAP1
000000af: PUSH1 0x60
000000b1: DUP3
000000b2: DUP2
000000b3: DUP2
000000b4: DUP2
000000b5: DUP6
000000b6: DUP9
000000b7: DUP4
000000b8: CALL
000000b9: POP
000000ba: PUSH1 0x40
000000bc: DUP1
000000bd: MLOAD
000000be: SWAP5
000000bf: DUP6
000000c0: MSTORE
000000c1: PUSH1 0x20
000000c3: DUP6
000000c4: ADD
000000c5: SWAP3
000000c6: SWAP1
000000c7: SWAP3
000000c8: MSTORE
000000c9: DUP4
000000ca: DUP3
000000cb: ADD
000000cc: SWAP3
000000cd: SWAP1
000000ce: SWAP3
000000cf: MSTORE
000000d0: MLOAD
000000d1: PUSH32 0xe842aea7a5f1b01049d752008c53c52890b1a6daf660cf39e8eec506112bbdf6
000000f2: SWAP3
000000f3: DUP2
000000f4: SWAP1
000000f5: SUB
000000f6: SWAP1
000000f7: SWAP2
000000f8: ADD
000000f9: SWAP1
000000fa: LOG1
000000fb: JUMPDEST
000000fc: PUSH1 0x40
000000fe: MLOAD
000000ff: PUSH1 0x00
00000101: DUP1
00000102: SLOAD
00000103: PUSH1 0x01
00000105: PUSH1 0xa0
00000107: PUSH1 0x02
00000109: EXP
0000010a: SUB
0000010b: SWAP1
0000010c: DUP2
0000010d: AND
0000010e: SWAP3
0000010f: ADDRESS
00000110: SWAP1
00000111: SWAP2
00000112: AND
00000113: BALANCE
00000114: SWAP1
00000115: DUP3
00000116: DUP2
00000117: DUP2
00000118: DUP2
00000119: DUP6
0000011a: DUP9
0000011b: DUP4
0000011c: CALL
0000011d: POP
0000011e: POP
0000011f: PUSH1 0x07
00000121: DUP1
00000122: SLOAD
00000123: PUSH1 0xff
00000125: NOT
00000126: AND
00000127: PUSH1 0x01
00000129: OR
0000012a: SWAP1
0000012b: SSTORE
0000012c: POP
0000012d: POP
0000012e: POP
0000012f: POP
00000130: JUMP
00000131: JUMPDEST
00000132: PUSH2 0x038e
00000135: PUSH1 0x03
00000137: SLOAD
00000138: DUP2
00000139: JUMP
0000013a: JUMPDEST
0000013b: PUSH2 0x0398
0000013e: PUSH1 0x00
00000140: SLOAD
00000141: PUSH1 0x01
00000143: PUSH1 0xa0
00000145: PUSH1 0x02
00000147: EXP
00000148: SUB
00000149: AND
0000014a: DUP2
0000014b: JUMP
0000014c: JUMPDEST
0000014d: PUSH2 0x0398
00000150: PUSH1 0x05
00000152: SLOAD
00000153: PUSH1 0x01
00000155: PUSH1 0xa0
00000157: PUSH1 0x02
00000159: EXP
0000015a: SUB
0000015b: AND
0000015c: DUP2
0000015d: JUMP
0000015e: JUMPDEST
0000015f: PUSH2 0x038e
00000162: PUSH1 0x01
00000164: SLOAD
00000165: DUP2
00000166: JUMP
00000167: JUMPDEST
00000168: PUSH2 0x038e
0000016b: PUSH1 0x02
0000016d: SLOAD
0000016e: DUP2
0000016f: JUMP
00000170: JUMPDEST
00000171: PUSH2 0x038e
00000174: PUSH1 0x04
00000176: SLOAD
00000177: DUP2
00000178: JUMP
00000179: JUMPDEST
0000017a: PUSH2 0x03ab
0000017d: PUSH1 0x04
0000017f: CALLDATALOAD
00000180: PUSH1 0x06
00000182: DUP1
00000183: SLOAD
00000184: DUP3
00000185: SWAP1
00000186: DUP2
00000187: LT
00000188: ISZERO
00000189: PUSH2 0x0002
0000018c: JUMPI
0000018d: POP
0000018e: PUSH1 0x00
00000190: MSTORE
00000191: PUSH1 0x02
00000193: MUL
00000194: PUSH32 0xf652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d3f
000001b5: DUP2
000001b6: ADD
000001b7: SLOAD
000001b8: PUSH32 0xf652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d40
000001d9: SWAP2
000001da: SWAP1
000001db: SWAP2
000001dc: ADD
000001dd: SLOAD
000001de: PUSH1 0x01
000001e0: PUSH1 0xa0
000001e2: PUSH1 0x02
000001e4: EXP
000001e5: SUB
000001e6: SWAP2
000001e7: SWAP1
000001e8: SWAP2
000001e9: AND
000001ea: SWAP1
000001eb: DUP3
000001ec: JUMP
000001ed: JUMPDEST
000001ee: STOP
000001ef: JUMPDEST
000001f0: POP
000001f1: POP
000001f2: POP
000001f3: DUP2
000001f4: SLOAD
000001f5: DUP2
000001f6: LT
000001f7: ISZERO
000001f8: PUSH2 0x0002
000001fb: JUMPI
000001fc: SWAP1
000001fd: PUSH1 0x00
000001ff: MSTORE
00000200: PUSH1 0x20
00000202: PUSH1 0x00
00000204: KECCAK256
00000205: SWAP1
00000206: PUSH1 0x02
00000208: MUL
00000209: ADD
0000020a: PUSH1 0x00
0000020c: POP
0000020d: PUSH1 0x00
0000020f: DUP3
00000210: ADD
00000211: MLOAD
00000212: DUP2
00000213: PUSH1 0x00
00000215: ADD
00000216: PUSH1 0x00
00000218: PUSH2 0x0100
0000021b: EXP
0000021c: DUP2
0000021d: SLOAD
0000021e: DUP2
0000021f: PUSH1 0x01
00000221: PUSH1 0xa0
00000223: PUSH1 0x02
00000225: EXP
00000226: SUB
00000227: MUL
00000228: NOT
00000229: AND
0000022a: SWAP1
0000022b: DUP4
0000022c: MUL
0000022d: OR
0000022e: SWAP1
0000022f: SSTORE
00000230: POP
00000231: PUSH1 0x20
00000233: DUP3
00000234: ADD
00000235: MLOAD
00000236: DUP2
00000237: PUSH1 0x01
00000239: ADD
0000023a: PUSH1 0x00
0000023c: POP
0000023d: SSTORE
0000023e: SWAP1
0000023f: POP
00000240: POP
00000241: DUP1
00000242: PUSH1 0x02
00000244: PUSH1 0x00
00000246: DUP3
00000247: DUP3
00000248: DUP3
00000249: POP
0000024a: SLOAD
0000024b: ADD
0000024c: SWAP3
0000024d: POP
0000024e: POP
0000024f: DUP2
00000250: SWAP1
00000251: SSTORE
00000252: POP
00000253: PUSH1 0x05
00000255: PUSH1 0x00
00000257: SWAP1
00000258: SLOAD
00000259: SWAP1
0000025a: PUSH2 0x0100
0000025d: EXP
0000025e: SWAP1
0000025f: DIV
00000260: PUSH1 0x01
00000262: PUSH1 0xa0
00000264: PUSH1 0x02
00000266: EXP
00000267: SUB
00000268: AND
00000269: PUSH1 0x01
0000026b: PUSH1 0xa0
0000026d: PUSH1 0x02
0000026f: EXP
00000270: SUB
00000271: AND
00000272: PUSH4 0xa9059cbb
00000277: CALLER
00000278: PUSH1 0x04
0000027a: PUSH1 0x00
0000027c: POP
0000027d: SLOAD
0000027e: DUP5
0000027f: DIV
00000280: PUSH1 0x40
00000282: MLOAD
00000283: DUP4
00000284: PUSH1 0xe0
00000286: PUSH1 0x02
00000288: EXP
00000289: MUL
0000028a: DUP2
0000028b: MSTORE
0000028c: PUSH1 0x04
0000028e: ADD
0000028f: DUP1
00000290: DUP4
00000291: PUSH1 0x01
00000293: PUSH1 0xa0
00000295: PUSH1 0x02
00000297: EXP
00000298: SUB
00000299: AND
0000029a: DUP2
0000029b: MSTORE
0000029c: PUSH1 0x20
0000029e: ADD
0000029f: DUP3
000002a0: DUP2
000002a1: MSTORE
000002a2: PUSH1 0x20
000002a4: ADD
000002a5: SWAP3
000002a6: POP
000002a7: POP
000002a8: POP
000002a9: PUSH1 0x00
000002ab: PUSH1 0x40
000002ad: MLOAD
000002ae: DUP1
000002af: DUP4
000002b0: SUB
000002b1: DUP2
000002b2: PUSH1 0x00
000002b4: DUP8
000002b5: PUSH2 0x61da
000002b8: GAS
000002b9: SUB
000002ba: CALL
000002bb: ISZERO
000002bc: PUSH2 0x0002
000002bf: JUMPI
000002c0: POP
000002c1: POP
000002c2: PUSH1 0x40
000002c4: DUP1
000002c5: MLOAD
000002c6: PUSH1 0x01
000002c8: PUSH1 0xa0
000002ca: PUSH1 0x02
000002cc: EXP
000002cd: SUB
000002ce: CALLER
000002cf: AND
000002d0: DUP2
000002d1: MSTORE
000002d2: PUSH1 0x20
000002d4: DUP2
000002d5: ADD
000002d6: DUP5
000002d7: SWAP1
000002d8: MSTORE
000002d9: PUSH1 0x01
000002db: DUP2
000002dc: DUP4
000002dd: ADD
000002de: MSTORE
000002df: SWAP1
000002e0: MLOAD
000002e1: PUSH32 0xe842aea7a5f1b01049d752008c53c52890b1a6daf660cf39e8eec506112bbdf6
00000302: SWAP3
00000303: POP
00000304: SWAP1
00000305: DUP2
00000306: SWAP1
00000307: SUB
00000308: PUSH1 0x60
0000030a: ADD
0000030b: SWAP1
0000030c: LOG1
0000030d: JUMPDEST
0000030e: POP
0000030f: JUMP
00000310: JUMPDEST
00000311: POP
00000312: PUSH1 0xa0
00000314: PUSH1 0x40
00000316: MSTORE
00000317: CALLER
00000318: PUSH1 0x60
0000031a: SWAP1
0000031b: DUP2
0000031c: MSTORE
0000031d: CALLVALUE
0000031e: PUSH1 0x80
00000320: DUP2
00000321: SWAP1
00000322: MSTORE
00000323: PUSH1 0x06
00000325: DUP1
00000326: SLOAD
00000327: PUSH1 0x01
00000329: DUP2
0000032a: ADD
0000032b: DUP1
0000032c: DUP4
0000032d: SSTORE
0000032e: SWAP3
0000032f: SWAP4
00000330: SWAP3
00000331: DUP3
00000332: SWAP1
00000333: DUP3
00000334: DUP1
00000335: ISZERO
00000336: DUP3
00000337: SWAP1
00000338: GT
00000339: PUSH2 0x01ef
0000033c: JUMPI
0000033d: PUSH1 0x02
0000033f: MUL
00000340: DUP2
00000341: PUSH1 0x02
00000343: MUL
00000344: DUP4
00000345: PUSH1 0x00
00000347: MSTORE
00000348: PUSH1 0x20
0000034a: PUSH1 0x00
0000034c: KECCAK256
0000034d: SWAP2
0000034e: DUP3
0000034f: ADD
00000350: SWAP2
00000351: ADD
00000352: PUSH2 0x01ef
00000355: SWAP2
00000356: SWAP1
00000357: JUMPDEST
00000358: DUP1
00000359: DUP3
0000035a: GT
0000035b: ISZERO
0000035c: PUSH2 0x038a
0000035f: JUMPI
00000360: DUP1
00000361: SLOAD
00000362: PUSH20 0xffffffffffffffffffffffffffffffffffffffff
00000377: NOT
00000378: AND
00000379: DUP2
0000037a: SSTORE
0000037b: PUSH1 0x00
0000037d: PUSH1 0x01
0000037f: SWAP2
00000380: SWAP1
00000381: SWAP2
00000382: ADD
00000383: SWAP1
00000384: DUP2
00000385: SSTORE
00000386: PUSH2 0x0357
00000389: JUMP
0000038a: JUMPDEST
0000038b: POP
0000038c: SWAP1
0000038d: JUMP
0000038e: JUMPDEST
0000038f: PUSH1 0x60
00000391: SWAP1
00000392: DUP2
00000393: MSTORE
00000394: PUSH1 0x20
00000396: SWAP1
00000397: RETURN
00000398: JUMPDEST
00000399: PUSH1 0x01
0000039b: PUSH1 0xa0
0000039d: PUSH1 0x02
0000039f: EXP
000003a0: SUB
000003a1: AND
000003a2: PUSH1 0x60
000003a4: SWAP1
000003a5: DUP2
000003a6: MSTORE
000003a7: PUSH1 0x20
000003a9: SWAP1
000003aa: RETURN
000003ab: JUMPDEST
000003ac: PUSH1 0x60
000003ae: SWAP2
000003af: DUP3
000003b0: MSTORE
000003b1: PUSH1 0x80
000003b3: MSTORE
000003b4: PUSH1 0x40
000003b6: SWAP1
000003b7: RETURN
000003b8: JUMPDEST
000003b9: JUMPDEST
000003ba: PUSH1 0x06
000003bc: SLOAD
000003bd: DUP2
000003be: LT
000003bf: ISZERO
000003c0: PUSH2 0x00fb
000003c3: JUMPI
000003c4: PUSH1 0x06
000003c6: DUP1
000003c7: SLOAD
000003c8: DUP3
000003c9: SWAP1
000003ca: DUP2
000003cb: LT
000003cc: ISZERO
000003cd: PUSH2 0x0002
000003d0: JUMPI
000003d1: PUSH1 0x00
000003d3: SWAP2
000003d4: DUP3
000003d5: MSTORE
000003d6: PUSH1 0x02
000003d8: MUL
000003d9: PUSH32 0xf652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d3f
000003fa: ADD
000003fb: SWAP1
000003fc: SWAP1
000003fd: SLOAD
000003fe: PUSH1 0x06
00000400: DUP1
00000401: SLOAD
00000402: PUSH1 0x01
00000404: PUSH1 0xa0
00000406: PUSH1 0x02
00000408: EXP
00000409: SUB
0000040a: SWAP3
0000040b: SWAP1
0000040c: SWAP3
0000040d: AND
0000040e: SWAP3
0000040f: SWAP2
00000410: DUP5
00000411: SWAP1
00000412: DUP2
00000413: LT
00000414: ISZERO
00000415: PUSH2 0x0002
00000418: JUMPI
00000419: PUSH1 0x02
0000041b: MUL
0000041c: PUSH32 0xf652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d40
0000043d: ADD
0000043e: SLOAD
0000043f: PUSH1 0x40
00000441: MLOAD
00000442: SWAP1
00000443: SWAP2
00000444: POP
00000445: DUP3
00000446: DUP2
00000447: DUP2
00000448: DUP2
00000449: DUP6
0000044a: DUP9
0000044b: DUP4
0000044c: CALL
0000044d: SWAP4
0000044e: POP
0000044f: POP
00000450: POP
00000451: POP
00000452: POP
00000453: PUSH32 0xe842aea7a5f1b01049d752008c53c52890b1a6daf660cf39e8eec506112bbdf6
00000474: PUSH1 0x06
00000476: PUSH1 0x00
00000478: POP
00000479: DUP3
0000047a: DUP2
0000047b: SLOAD
0000047c: DUP2
0000047d: LT
0000047e: ISZERO
0000047f: PUSH2 0x0002
00000482: JUMPI
00000483: PUSH1 0x00
00000485: SWAP2
00000486: DUP3
00000487: MSTORE
00000488: PUSH1 0x02
0000048a: MUL
0000048b: PUSH32 0xf652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d3f
000004ac: ADD
000004ad: SWAP1
000004ae: POP
000004af: PUSH1 0x06
000004b1: DUP1
000004b2: SLOAD
000004b3: SWAP2
000004b4: SLOAD
000004b5: PUSH1 0x01
000004b7: PUSH1 0xa0
000004b9: PUSH1 0x02
000004bb: EXP
000004bc: SUB
000004bd: AND
000004be: SWAP2
000004bf: DUP5
000004c0: SWAP1
000004c1: DUP2
000004c2: LT
000004c3: ISZERO
000004c4: PUSH2 0x0002
000004c7: JUMPI
000004c8: PUSH1 0x02
000004ca: MUL
000004cb: PUSH32 0xf652222313e28459528d920b65115c16c04f3efc82aaedc97be59f3f377c0d40
000004ec: ADD
000004ed: SLOAD
000004ee: PUSH1 0x40
000004f0: DUP1
000004f1: MLOAD
000004f2: PUSH1 0x01
000004f4: PUSH1 0xa0
000004f6: PUSH1 0x02
000004f8: EXP
000004f9: SUB
000004fa: SWAP5
000004fb: SWAP1
000004fc: SWAP5
000004fd: AND
000004fe: DUP5
000004ff: MSTORE
00000500: PUSH1 0x20
00000502: DUP5
00000503: ADD
00000504: SWAP2
00000505: SWAP1
00000506: SWAP2
00000507: MSTORE
00000508: PUSH1 0x00
0000050a: DUP4
0000050b: DUP3
0000050c: ADD
0000050d: MSTORE
0000050e: MLOAD
0000050f: SWAP2
00000510: DUP3
00000511: SWAP1
00000512: SUB
00000513: PUSH1 0x60
00000515: ADD
00000516: SWAP2
00000517: SWAP1
00000518: POP
00000519: LOG1
0000051a: PUSH1 0x01
0000051c: ADD
0000051d: PUSH2 0x03b9
00000520: JUMP
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 other detector Untrusted CALL target/value reachable 60 yes yes
view
trace_id: 0xd1447677b38efd694db2b98d0b3199a143e9699f97eb89fde819d49df09feca7
call_targets: 0x5030916fd73cffb2dab9ca7249d48fe38de543dc, 0xa8202adce1a43f42459da62a86211c45fcdb7081
target_varies: yes
classification: target_varies
validation_json
{
    "sink": "CALL",
    "errors": 0,
    "status": "confirmed",
    "attempts": 1,
    "trace_id": "0xd1447677b38efd694db2b98d0b3199a143e9699f97eb89fde819d49df09feca7",
    "confirmed": true,
    "trace_mode": "callTracer",
    "call_targets": [
        "0x5030916fd73cffb2dab9ca7249d48fe38de543dc",
        "0xa8202adce1a43f42459da62a86211c45fcdb7081"
    ],
    "matched_probe": null,
    "target_varies": true,
    "classification": "target_varies"
}
witness_json
{
    "notes": "heuristic witness; entrypoints are best-effort selectors with zeroed calldata",
    "constraints": [],
    "entrypoints": [
        {
            "calldata": "0x01cb3b20",
            "selector": "0x01cb3b20",
            "calldata_variants": [
                "0x01cb3b20",
                "0x01cb3b200000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x29dcb0cf",
            "selector": "0x29dcb0cf",
            "calldata_variants": [
                "0x29dcb0cf",
                "0x29dcb0cf0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x38af3eed",
            "selector": "0x38af3eed",
            "calldata_variants": [
                "0x38af3eed",
                "0x38af3eed0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x6e66f6e9",
            "selector": "0x6e66f6e9",
            "calldata_variants": [
                "0x6e66f6e9",
                "0x6e66f6e90000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x7a3a0e84",
            "selector": "0x7a3a0e84",
            "calldata_variants": [
                "0x7a3a0e84",
                "0x7a3a0e840000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x7b3e5e7b",
            "selector": "0x7b3e5e7b",
            "calldata_variants": [
                "0x7b3e5e7b",
                "0x7b3e5e7b0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0xa035b1fe",
            "selector": "0xa035b1fe",
            "calldata_variants": [
                "0xa035b1fe",
                "0xa035b1fe0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0xdc0d3dff",
            "selector": "0xdc0d3dff",
            "calldata_variants": [
                "0xdc0d3dff",
                "0xdc0d3dff0000000000000000000000000000000000000000000000000000000000000000"
            ]
        }
    ]
}
evidence_json
{
    "examples": [
        {
            "pc": 184,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        },
        {
            "pc": 284,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        },
        {
            "pc": 698,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        }
    ],
    "call_count": 4,
    "guards_detected": [],
    "untrusted_call_count": 4
}
high other detector ETH value transfer possible 55 yes yes
view
trace_id: 0xd1447677b38efd694db2b98d0b3199a143e9699f97eb89fde819d49df09feca7
call_targets: 0x5030916fd73cffb2dab9ca7249d48fe38de543dc, 0xa8202adce1a43f42459da62a86211c45fcdb7081
target_varies: yes
classification: target_varies
validation_json
{
    "sink": "CALL",
    "errors": 0,
    "status": "confirmed",
    "attempts": 1,
    "trace_id": "0xd1447677b38efd694db2b98d0b3199a143e9699f97eb89fde819d49df09feca7",
    "confirmed": true,
    "trace_mode": "callTracer",
    "call_targets": [
        "0x5030916fd73cffb2dab9ca7249d48fe38de543dc",
        "0xa8202adce1a43f42459da62a86211c45fcdb7081"
    ],
    "matched_probe": null,
    "target_varies": true,
    "classification": "target_varies"
}
witness_json
{
    "notes": "heuristic witness; entrypoints are best-effort selectors with zeroed calldata",
    "constraints": [],
    "entrypoints": [
        {
            "calldata": "0x01cb3b20",
            "selector": "0x01cb3b20",
            "calldata_variants": [
                "0x01cb3b20",
                "0x01cb3b200000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x29dcb0cf",
            "selector": "0x29dcb0cf",
            "calldata_variants": [
                "0x29dcb0cf",
                "0x29dcb0cf0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x38af3eed",
            "selector": "0x38af3eed",
            "calldata_variants": [
                "0x38af3eed",
                "0x38af3eed0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x6e66f6e9",
            "selector": "0x6e66f6e9",
            "calldata_variants": [
                "0x6e66f6e9",
                "0x6e66f6e90000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x7a3a0e84",
            "selector": "0x7a3a0e84",
            "calldata_variants": [
                "0x7a3a0e84",
                "0x7a3a0e840000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0x7b3e5e7b",
            "selector": "0x7b3e5e7b",
            "calldata_variants": [
                "0x7b3e5e7b",
                "0x7b3e5e7b0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0xa035b1fe",
            "selector": "0xa035b1fe",
            "calldata_variants": [
                "0xa035b1fe",
                "0xa035b1fe0000000000000000000000000000000000000000000000000000000000000000"
            ]
        },
        {
            "calldata": "0xdc0d3dff",
            "selector": "0xdc0d3dff",
            "calldata_variants": [
                "0xdc0d3dff",
                "0xdc0d3dff0000000000000000000000000000000000000000000000000000000000000000"
            ]
        }
    ]
}
evidence_json
{
    "examples": [
        {
            "pc": 184,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        },
        {
            "pc": 284,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        },
        {
            "pc": 698,
            "opcode": "CALL",
            "returndata_checked": null,
            "value_expression_category": "computed",
            "target_expression_category": "computed"
        }
    ],
    "eth_value_calls": 4,
    "guards_detected": []
}