mirror of
https://github.com/MHSanaei/3x-ui.git
synced 2026-04-16 12:35:54 +00:00
1. **Fixed XPadding Placement Dropdown**: - Added the missing `cookie` and `query` options to `xPaddingPlacement` (`stream_xhttp.html`). - *Why:* Previously, users wanting `cookie` obfuscation were forced to use the `header` placement string. This caused Xray-core to blindly intercept the entire monolithic HTTP Cookie header, failing internal padding-length validations and causing the inbound to silently drop the connection. 2. **Fixed Uplink Data Placement Validation**: - Replaced the unsupported `query` option with `cookie` in `uplinkDataPlacement`. - *Why:* Xray-core's `transport_internet.go` explicitly forbids `query` as an uplink placement option. Selecting it from the UI previously sent a payload that would cause Xray-core to instantly throw an `unsupported uplink data placement: query` panic. Adding `cookie` perfectly aligns the UI with Xray-core restrictions. ### Related Issues - Resolves #3992
50 lines
1,008 B
Go
50 lines
1,008 B
Go
package buf_test
|
|
|
|
import (
|
|
"crypto/tls"
|
|
"io"
|
|
"testing"
|
|
|
|
. "github.com/xtls/xray-core/common/buf"
|
|
"github.com/xtls/xray-core/common/net"
|
|
"github.com/xtls/xray-core/testing/servers/tcp"
|
|
)
|
|
|
|
func TestWriterCreation(t *testing.T) {
|
|
tcpServer := tcp.Server{}
|
|
dest, err := tcpServer.Start()
|
|
if err != nil {
|
|
t.Fatal("failed to start tcp server: ", err)
|
|
}
|
|
defer tcpServer.Close()
|
|
|
|
conn, err := net.Dial("tcp", dest.NetAddr())
|
|
if err != nil {
|
|
t.Fatal("failed to dial a TCP connection: ", err)
|
|
}
|
|
defer conn.Close()
|
|
|
|
{
|
|
writer := NewWriter(conn)
|
|
if _, ok := writer.(*BufferToBytesWriter); !ok {
|
|
t.Fatal("writer is not a BufferToBytesWriter")
|
|
}
|
|
|
|
writer2 := NewWriter(writer.(io.Writer))
|
|
if writer2 != writer {
|
|
t.Fatal("writer is not reused")
|
|
}
|
|
}
|
|
|
|
tlsConn := tls.Client(conn, &tls.Config{
|
|
InsecureSkipVerify: true,
|
|
})
|
|
defer tlsConn.Close()
|
|
|
|
{
|
|
writer := NewWriter(tlsConn)
|
|
if _, ok := writer.(*SequentialWriter); !ok {
|
|
t.Fatal("writer is not a SequentialWriter")
|
|
}
|
|
}
|
|
}
|