mirror of
https://github.com/SagerNet/sing-box-for-android.git
synced 2025-04-03 20:07:38 +03:00
Merge branch 'SagerNet:dev' into dev
This commit is contained in:
commit
ee3a7b233e
4 changed files with 33 additions and 8 deletions
|
@ -150,7 +150,6 @@ class BoxService(
|
|||
}
|
||||
|
||||
DefaultNetworkMonitor.start()
|
||||
Libbox.registerLocalDNSTransport(LocalResolver)
|
||||
Libbox.setMemoryLimit(!Settings.disableMemoryLimit)
|
||||
|
||||
val newService = try {
|
||||
|
@ -263,7 +262,6 @@ class BoxService(
|
|||
}
|
||||
commandServer?.setService(null)
|
||||
boxService = null
|
||||
Libbox.registerLocalDNSTransport(null)
|
||||
DefaultNetworkMonitor.stop()
|
||||
|
||||
commandServer?.apply {
|
||||
|
|
|
@ -10,6 +10,7 @@ import android.util.Log
|
|||
import androidx.annotation.RequiresApi
|
||||
import io.nekohasekai.libbox.InterfaceUpdateListener
|
||||
import io.nekohasekai.libbox.Libbox
|
||||
import io.nekohasekai.libbox.LocalDNSTransport
|
||||
import io.nekohasekai.libbox.NetworkInterfaceIterator
|
||||
import io.nekohasekai.libbox.PlatformInterface
|
||||
import io.nekohasekai.libbox.StringIterator
|
||||
|
@ -20,6 +21,9 @@ import java.net.Inet6Address
|
|||
import java.net.InetSocketAddress
|
||||
import java.net.InterfaceAddress
|
||||
import java.net.NetworkInterface
|
||||
import java.security.KeyStore
|
||||
import kotlin.io.encoding.Base64
|
||||
import kotlin.io.encoding.ExperimentalEncodingApi
|
||||
import io.nekohasekai.libbox.NetworkInterface as LibboxNetworkInterface
|
||||
|
||||
interface PlatformInterfaceWrapper : PlatformInterface {
|
||||
|
@ -169,6 +173,27 @@ interface PlatformInterfaceWrapper : PlatformInterface {
|
|||
return WIFIState(ssid, wifiInfo.bssid)
|
||||
}
|
||||
|
||||
override fun localDNSTransport(): LocalDNSTransport? {
|
||||
return LocalResolver
|
||||
}
|
||||
|
||||
@OptIn(ExperimentalEncodingApi::class)
|
||||
override fun systemCertificates(): StringIterator {
|
||||
val certificates = mutableListOf<String>()
|
||||
val keyStore = KeyStore.getInstance("AndroidCAStore")
|
||||
if (keyStore != null) {
|
||||
keyStore.load(null, null);
|
||||
val aliases = keyStore.aliases()
|
||||
while (aliases.hasMoreElements()) {
|
||||
val cert = keyStore.getCertificate(aliases.nextElement())
|
||||
certificates.add(
|
||||
"-----BEGIN CERTIFICATE-----\n" + Base64.encode(cert.encoded) + "\n-----END CERTIFICATE-----"
|
||||
)
|
||||
}
|
||||
}
|
||||
return StringArray(certificates.iterator())
|
||||
}
|
||||
|
||||
private class InterfaceArray(private val iterator: Iterator<LibboxNetworkInterface>) :
|
||||
NetworkInterfaceIterator {
|
||||
|
||||
|
|
|
@ -138,9 +138,11 @@ class DashboardFragment : Fragment(R.layout.fragment_dashboard) {
|
|||
builder.setPositiveButton(R.string.ok) { _, _ ->
|
||||
loopShowDeprecatedNotes(notes)
|
||||
}
|
||||
builder.setNeutralButton(R.string.service_error_deprecated_warning_documentation) { _, _ ->
|
||||
requireContext().launchCustomTab(note.migrationLink)
|
||||
loopShowDeprecatedNotes(notes)
|
||||
if (!note.migrationLink.isNullOrBlank()) {
|
||||
builder.setNeutralButton(R.string.service_error_deprecated_warning_documentation) { _, _ ->
|
||||
requireContext().launchCustomTab(note.migrationLink)
|
||||
loopShowDeprecatedNotes(notes)
|
||||
}
|
||||
}
|
||||
builder.show()
|
||||
}
|
||||
|
|
|
@ -1,3 +1,3 @@
|
|||
VERSION_CODE=478
|
||||
VERSION_NAME=1.11.3
|
||||
GO_VERSION=go1.23.5
|
||||
VERSION_CODE=484
|
||||
VERSION_NAME=1.12.0-alpha.11
|
||||
GO_VERSION=go1.24.0
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue