This project is a Magisk, Kernelsu, APatch module for Clash/mihomo, sing-box, v2ray, xray, hysteria. It supports REDIRECT (TCP only), TPROXY (TCP + UDP) transparent proxy, TUN (TCP + UDP), and hybrid mode REDIRECT (TCP) + TUN (UDP) proxy.
Based on upstream integration for one-stop service, ready to use. Suitable for:
- Lazy people
- Beginners
The project's theme and configuration focus on Clash/mihomo.Meta.
This module needs to be used in a Magisk/Kernelsu environment. If you don't know how to configure the required environment, you might need applications like ClashForAndroid, v2rayNG, surfboard, SagerNet, AnXray.
Welcome to use Surfing. Before using this project, please carefully read and understand the following statements and disclaimers. By using this project, you agree to accept the following terms and conditions. Hereinafter referred to as Surfing.
- 
This project is an open-source project for learning and research purposes only and does not provide any form of guarantee. Users must bear full responsibility for the risks and consequences of using this project. 
- 
This project is only for the convenience of simplifying the installation and configuration of Surfing for Clash services in the Android Magisk environment. It does not make any guarantees about the functionality and performance of Surfing. The developer of this project is not responsible for any problems or losses. 
- 
The use of this projects Surfing module may violate the laws and regulations of your region or the terms of service of service providers. You need to bear the risks of using this project on your own. The developer of this project is not responsible for your actions or the consequences of use. 
- 
The developer of this project is not responsible for any direct or indirect losses or damages resulting from the use of this project, including but not limited to data loss, device damage, service interruption, personal privacy leaks, etc. 
- 
Before using the Surfing module, please make sure you have carefully read and understood the usage instructions and related documents of Clash and Magisk and comply with their rules and terms. 
- 
Before using this project, back up your device data and related settings to prevent unexpected situations. The developer of this project is not responsible for your data loss or damage. 
- 
Please comply with local laws and regulations and respect the legitimate rights and interests of other users when using this project. It is forbidden to use this project for illegal, abusive, or infringing activities. 
- 
If you encounter any problems or have any suggestions when using this project, you are welcome to provide feedback to the developer of this project, but the developer is not obligated to resolve issues or respond to feedback. 
Please decide whether to use the Surfing module only after clearly understanding and accepting the above statements and disclaimers. If you do not agree or cannot accept the above terms, please stop using this project immediately.
During the use of this project, you must comply with the laws and regulations of your region. In case of any disputes, interpretation and resolution should be carried out in accordance with local laws and regulations.
- Download the module zip file from the Release page and install it via Magisk Manager, KernelSU Manager, or APatch.
- Version changes: 📲log
- Simply uninstall this module from Magisk Manager, Kernelsu Manager, or APatch app 👉🏻Uninstall Script
Uninstalling this module via a manager will remove all associated service data. Web-related tiles or APKs may need to be uninstalled manually.
1. First-Time Use
- 
After the module is installed for the first time, please first add your subscription URL in /data/adb/box_bll/clash/config.yaml, then manually reboot your device once.
- 
After rebooting, toggle the module switch once, open the Web app on your desktop, and you can start using it. 
- 
Due to network issues, not all rules/subscriptions may download automatically; please manually refresh them in the panel. 
- 
If subscriptions fail to load, try switching the Ua in the configuration file. 
- 
If the above fails, ensure your network environment is normal. 
- 
Web App: - Used for portable browsing and managing backend routing data
- Automatically updates core files on startup
 
2. Controlling Operation
- You can control start/stop via WiFi SSID.
- You can control service in real-time using the module toggle switch.
- You can add the module's control tile to the system status bar. If the tile switch cannot be found after installing the module and rebooting, you can manually install the APK Download Source
3. Routing Rules
GitHub Actions automatically builds every day at 6 AM Beijing time to ensure the rules are up-to-date.
All routing rules use online links and update automatically 24/7.
4. Future Updates
- If you are using all default configurations, updates will be seamless.
- Supports online updates from the client; reboot is not required but still recommended.
- During updates, configuration files will be backed up to:
- config.yaml.bak
 
- User configuration files will be backed up to:
- box.config.bak
 
- Subscription URLs will be automatically extracted and backed up to:
- proxies/subscribe_urls_backup.txt
- The backup will be automatically restored into the new configuration, suitable for default configuration usage.
 
Note: Updates mainly follow upstream changes and may push some configuration adjustments.
5. Usage Issues
1. Proxy Specific Apps (Blacklist/Whitelist)
- 
To proxy all apps except certain ones, open /data/adb/box_bll/scripts/box.config, setproxy_modetoblacklist(default), and add elements to theuser_packages_listarray in the formatid:package_name, separated by spaces. These apps will not be proxied. Example:user_packages_list=("id:package_name" "id:package_name")
- 
To proxy only specific apps, open /data/adb/box_bll/scripts/box.config, setproxy_modetowhitelist, and add elements to theuser_packages_listarray in the formatid:package_name, separated by spaces. Only these apps will be proxied. Example:user_packages_list=("id:package_name" "id:package_name")
Android user group IDs:
| User Type | ID | 
|---|---|
| Owner | 0 | 
| Phone Clone | 10 | 
| Multiple Apps | 999 | 
You can usually find all user group IDs and app package names under
/data/user/.
2. Tun Mode
- Enabled by default
- Better traffic management
- When using blacklist/whitelist, exclude the corresponding package names
Can be disabled via configuration if needed.
3. Routing Rules
- Optimized for Mainland China
- Meets most daily usage requirements
With increasingly robust routing rules, blacklist/whitelist may become less necessary.
4. Panel Management
- Magisk font modules
May affect proper display of panel fonts.
5. LAN Sharing
- Enable hotspot to allow other devices to connect
- Tun Gateway: 172.20.0.1
To access the backend console from other devices:
http://<CurrentWiFi>/172.20.0.1:9090/ui
6. Host File
- No need to mount: just delete the file
- To remount: create a new one in the etc folder
- All changes take effect immediately
- During update/installation, you can use volume keys Up(Mount) / Down(Unmount) to choose whether to mount
Local IP redirection for domains, forced binding
    
    
    CHIZI-0618
  
> Thanks for providing valuable foundation for the implementation of this project. <