Bug #15657
closedState table entries printed on ``diag_dump_states.php`` may contain an unexpected interface
100%
Description
When route-to sends traffic out of a different gateway from the default route, the state's interface is set according to the new gateway/path and the original default route's interface is kept in the origif value. In the following example, igc3 is WAN1 (default gateway) and igc2 is WAN2. The state is a ping sourced from WAN2's address (using the if-bound state policy):
igc2 icmp 192.168.1.253:10514 -> 1.1.1.1:8 0:0 age 00:00:07, expires in 00:00:09, 7:7 pkts, 588:588 bytes, rule 166, allow-opts id: f86ccf6600000000 creatorid: dc608246 route-to: 192.168.1.254@igc2 origif: igc3
Currently, the diagnostics page lists origif for the interface; instead it should show the "real" interface.
       Updated by Marcos M about 1 year ago
      Updated by Marcos M about 1 year ago
      
    
    The state info is retrieved by calling pfSense_get_pf_states() which in turn populates state info by calling pfSense_append_state(). The following is an example of the state info retrieved:
  array(17) {
    ["if"]=>
    string(4) "igc3" 
    ["proto"]=>
    string(4) "icmp" 
    ["direction"]=>
    string(3) "out" 
    ["src"]=>
    string(18) "192.168.1.253:8717" 
    ["dst"]=>
    string(14) "1.1.1.1:8" 
    ["state"]=>
    string(3) "0:0" 
    ["age"]=>
    string(8) "00:00:07" 
    ["expires in"]=>
    string(8) "00:00:10" 
    ["packets total"]=>
    float(14)
    ["packets in"]=>
    float(7)
    ["packets out"]=>
    float(7)
    ["bytes total"]=>
    float(1176)
    ["bytes in"]=>
    float(588)
    ["bytes out"]=>
    float(588)
    ["rule"]=>
    int(166)
    ["id"]=>
    string(16) "f9cecf6600000000" 
    ["creatorid"]=>
    string(8) "dc608246" 
  }
	To resolve the issue, if should contain the "real" interface, and a new origif value can be set when it exists on the state.
       Updated by Marcos M about 1 year ago
      Updated by Marcos M about 1 year ago
      
    
    - Status changed from New to Pull Request Review
- Assignee set to Marcos M
- Target version set to 2.8.0
- Plus Target Version set to 24.08
       Updated by Jim Pingle about 1 year ago
      Updated by Jim Pingle about 1 year ago
      
    
    - Status changed from Pull Request Review to Feedback
- % Done changed from 0 to 100
This was merged a couple months ago
       Updated by Jim Pingle about 1 year ago
      Updated by Jim Pingle about 1 year ago
      
    
    - Plus Target Version changed from 24.08 to 24.11
       Updated by Jim Pingle about 1 year ago
      Updated by Jim Pingle about 1 year ago
      
    
    - Subject changed from Unexpected interface can be listed in Diagnostics > States to State table entries printed on ``diag_dump_states.php`` may contain an unexpected interface
       Updated by Georgiy Tyutyunnik about 1 year ago
      Updated by Georgiy Tyutyunnik about 1 year ago
      
    
    tested, reproduced on 
24.03-RELEASE (amd64)
built on Wed Aug 21 17:32:00 CEST 2024
FreeBSD 15.0-CURRENT
currently fixed, tested on
24.11-ALPHA (amd64)
built on Fri Oct 18 8:00:00 CEST 2024
FreeBSD 15.0-CURRENT
       Updated by Georgiy Tyutyunnik about 1 year ago
      Updated by Georgiy Tyutyunnik about 1 year ago
      
    
    - Status changed from Feedback to Resolved