mirror of
				https://github.com/house-of-vanity/OutFleet.git
				synced 2025-10-24 17:29:08 +00:00 
			
		
		
		
	
		
			
	
	
		
			151 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
		
		
			
		
	
	
			151 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
|   | # Xray Client URI Generation
 | ||
|  | 
 | ||
|  | ## VMess URI Format
 | ||
|  | 
 | ||
|  | VMess URIs use two formats: | ||
|  | 
 | ||
|  | ### 1. Query Parameter Format
 | ||
|  | ``` | ||
|  | vmess://uuid@hostname:port?parameters#alias | ||
|  | ``` | ||
|  | 
 | ||
|  | **Parameters:** | ||
|  | - `encryption=auto` - Encryption method | ||
|  | - `security=tls|none` - Security layer (TLS or none) | ||
|  | - `sni=domain` - Server Name Indication for TLS | ||
|  | - `fp=chrome|firefox|safari` - TLS fingerprint | ||
|  | - `type=ws|tcp|grpc|http` - Transport type | ||
|  | - `path=/path` - WebSocket/HTTP path | ||
|  | - `host=domain` - Host header for WebSocket | ||
|  | 
 | ||
|  | **Example:** | ||
|  | ``` | ||
|  | vmess://2c981164-9b93-4bca-94ff-b78d3f8498d7@v2ray.codefyinc.com:443?encryption=auto&security=tls&sni=example.com&fp=chrome&type=ws&path=/ws&host=v2ray.codefyinc.com#MyServer | ||
|  | ``` | ||
|  | 
 | ||
|  | ### 2. Base64 JSON Format
 | ||
|  | ``` | ||
|  | vmess://base64(json_config)#alias | ||
|  | ``` | ||
|  | 
 | ||
|  | **JSON Structure:** | ||
|  | ```json | ||
|  | { | ||
|  |   "v": "2", | ||
|  |   "ps": "Server Name", | ||
|  |   "add": "hostname", | ||
|  |   "port": "443", | ||
|  |   "id": "uuid", | ||
|  |   "aid": "0", | ||
|  |   "scy": "auto", | ||
|  |   "net": "ws", | ||
|  |   "type": "none", | ||
|  |   "host": "domain", | ||
|  |   "path": "/path", | ||
|  |   "tls": "tls", | ||
|  |   "sni": "domain", | ||
|  |   "alpn": "", | ||
|  |   "fp": "chrome" | ||
|  | } | ||
|  | ``` | ||
|  | 
 | ||
|  | ## VLESS URI Format
 | ||
|  | 
 | ||
|  | ``` | ||
|  | vless://uuid@hostname:port?parameters#alias | ||
|  | ``` | ||
|  | 
 | ||
|  | **Key Parameters:** | ||
|  | - `encryption=none` - VLESS uses no encryption | ||
|  | - `security=tls|reality|none` - Security layer | ||
|  | - `type=ws|tcp|grpc|http|httpupgrade|xhttp` - Transport type | ||
|  | - `flow=xtls-rprx-vision` - Flow control (for XTLS) | ||
|  | - `headerType=none|http` - Header type for TCP | ||
|  | - `mode=auto|gun|stream-one` - Transport mode | ||
|  | - `serviceName=name` - gRPC service name | ||
|  | - `authority=domain` - gRPC authority | ||
|  | - `spx=/path` - Split HTTP path (for xhttp) | ||
|  | 
 | ||
|  | **REALITY Parameters:** | ||
|  | - `pbk=public_key` - Public key | ||
|  | - `sid=short_id` - Short ID | ||
|  | - `fp=chrome|firefox|safari` - TLS fingerprint | ||
|  | - `sni=domain` - Server Name Indication | ||
|  | 
 | ||
|  | **Examples:** | ||
|  | ``` | ||
|  | vless://uuid@server.com:443?type=tcp&security=none&headerType=none#Basic | ||
|  | vless://uuid@server.com:443?type=ws&security=tls&path=/ws&host=example.com#WebSocket | ||
|  | vless://uuid@server.com:443?type=grpc&security=reality&serviceName=grpcService&pbk=key&sid=id#gRPC-Reality | ||
|  | ``` | ||
|  | 
 | ||
|  | ## Generation Algorithm
 | ||
|  | 
 | ||
|  | 1. **UUID**: Use `inbound_users.xray_user_id` | ||
|  | 2. **Hostname**: From `servers.hostname` | ||
|  | 3. **Port**: From `server_inbounds.port_override` or template default | ||
|  | 4. **Transport**: From inbound template `stream_settings` | ||
|  | 5. **Security**: Based on certificate configuration | ||
|  | 6. **Path**: From WebSocket stream settings | ||
|  | 7. **Alias**: User name + server name | ||
|  | 
 | ||
|  | ## Shadowsocks URI Format
 | ||
|  | 
 | ||
|  | ``` | ||
|  | ss://password@hostname:port?parameters#alias | ||
|  | ``` | ||
|  | 
 | ||
|  | **Parameters:** | ||
|  | - `encryption=none` - Usually none for modern configs | ||
|  | - `security=tls|reality|none` - Security layer | ||
|  | - `type=ws|tcp|grpc|xhttp` - Transport type | ||
|  | - `path=/path` - WebSocket/HTTP path | ||
|  | - `host=domain` - Host header | ||
|  | - `mode=auto|gun|stream-one` - Transport mode | ||
|  | - `headerType=none|http` - Header type for TCP | ||
|  | - `flow=xtls-rprx-vision` - Flow control (for REALITY) | ||
|  | - `pbk=key` - Public key (for REALITY) | ||
|  | - `sid=id` - Short ID (for REALITY) | ||
|  | 
 | ||
|  | **Example:** | ||
|  | ``` | ||
|  | ss://my-password@server.com:443?type=ws&security=tls&path=/ws&host=example.com#MyServer | ||
|  | ``` | ||
|  | 
 | ||
|  | ## Trojan URI Format
 | ||
|  | 
 | ||
|  | ``` | ||
|  | trojan://password@hostname:port?parameters#alias | ||
|  | ``` | ||
|  | 
 | ||
|  | **Parameters:** | ||
|  | - `security=tls|reality|none` - Security layer | ||
|  | - `type=ws|tcp|grpc` - Transport type | ||
|  | - `sni=domain` - Server Name Indication | ||
|  | - `fp=chrome|firefox|randomized` - TLS fingerprint | ||
|  | - `flow=xtls-rprx-vision` - Flow control | ||
|  | - `allowInsecure=1` - Allow insecure connections | ||
|  | - `headerType=http|none` - Header type for TCP | ||
|  | - `mode=gun` - gRPC mode | ||
|  | - `serviceName=name` - gRPC service name | ||
|  | 
 | ||
|  | **WebSocket Parameters:** | ||
|  | - `path=/path` - WebSocket path | ||
|  | - `host=domain` - Host header | ||
|  | - `alpn=http/1.1|h2` - ALPN protocols | ||
|  | 
 | ||
|  | **Examples:** | ||
|  | ``` | ||
|  | trojan://password@server.com:443?type=tcp&security=tls&sni=example.com#Basic | ||
|  | trojan://password@server.com:443?type=ws&security=tls&path=/ws&host=example.com&sni=example.com#WebSocket | ||
|  | trojan://password@server.com:443?type=grpc&security=tls&serviceName=grpcService&mode=gun&sni=example.com#gRPC | ||
|  | ``` | ||
|  | 
 | ||
|  | ## Implementation Notes
 | ||
|  | 
 | ||
|  | - VMess requires `aid=0` for modern clients | ||
|  | - VLESS doesn't use `aid` parameter | ||
|  | - Shadowsocks uses password instead of UUID | ||
|  | - Base64 encoding required for VMess JSON format | ||
|  | - URL encoding needed for special characters in parameters | ||
|  | - REALITY parameters: `pbk`, `sid`, `fp`, `sni` |