forked from PeterCxy/OpenEUICC
Compare commits
1 commit
f167d059dc
...
813eedc564
Author | SHA1 | Date | |
---|---|---|---|
813eedc564 |
34 changed files with 182 additions and 370 deletions
|
@ -33,23 +33,14 @@ jobs:
|
||||||
uses: https://gitea.angry.im/actions/setup-android@v3
|
uses: https://gitea.angry.im/actions/setup-android@v3
|
||||||
|
|
||||||
- name: Build Debug APKs
|
- name: Build Debug APKs
|
||||||
run: ./gradlew --no-daemon assembleDebug :app:assembleDebugMagiskModuleDir
|
run: ./gradlew --no-daemon assembleDebug
|
||||||
|
|
||||||
- name: Copy Artifacts
|
- name: Copy Artifacts
|
||||||
run: |
|
run: find . -name 'app*-debug.apk' -exec cp {} . \;
|
||||||
find . -name 'app*-debug.apk' -exec cp {} . \;
|
|
||||||
cp -r app/build/magisk/debug ./magisk-debug
|
|
||||||
|
|
||||||
- name: Upload APK Artifacts
|
- name: Upload Artifacts
|
||||||
uses: https://gitea.angry.im/actions/upload-artifact@v3
|
uses: https://gitea.angry.im/actions/upload-artifact@v3
|
||||||
with:
|
with:
|
||||||
name: Debug APKs
|
name: Debug APKs
|
||||||
compression-level: 0
|
compression-level: 0
|
||||||
path: app*-debug.apk
|
path: app*-debug.apk
|
||||||
|
|
||||||
- name: Upload Magisk Artifacts
|
|
||||||
uses: https://gitea.angry.im/actions/upload-artifact@v3
|
|
||||||
with:
|
|
||||||
name: magisk-debug
|
|
||||||
compression-level: 0
|
|
||||||
path: magisk-debug
|
|
||||||
|
|
2
.idea/.gitignore
generated
vendored
2
.idea/.gitignore
generated
vendored
|
@ -2,7 +2,7 @@
|
||||||
/caches
|
/caches
|
||||||
/libraries
|
/libraries
|
||||||
/assetWizardSettings.xml
|
/assetWizardSettings.xml
|
||||||
/deploymentTarget*.xml
|
/deploymentTargetDropDown.xml
|
||||||
/gradle.xml
|
/gradle.xml
|
||||||
/misc.xml
|
/misc.xml
|
||||||
/modules.xml
|
/modules.xml
|
||||||
|
|
37
.idea/deploymentTargetSelector.xml
generated
Normal file
37
.idea/deploymentTargetSelector.xml
generated
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="deploymentTargetSelector">
|
||||||
|
<selectionStates>
|
||||||
|
<SelectionState runConfigName="app-unpriv">
|
||||||
|
<option name="selectionMode" value="DROPDOWN" />
|
||||||
|
</SelectionState>
|
||||||
|
<SelectionState runConfigName="app">
|
||||||
|
<option name="selectionMode" value="DROPDOWN" />
|
||||||
|
</SelectionState>
|
||||||
|
<SelectionState runConfigName="app-unpriv.androidTest">
|
||||||
|
<option name="selectionMode" value="DROPDOWN" />
|
||||||
|
</SelectionState>
|
||||||
|
<SelectionState runConfigName="app-unpriv.main">
|
||||||
|
<option name="selectionMode" value="DROPDOWN" />
|
||||||
|
</SelectionState>
|
||||||
|
<SelectionState runConfigName="app-unpriv.unitTest">
|
||||||
|
<option name="selectionMode" value="DROPDOWN" />
|
||||||
|
</SelectionState>
|
||||||
|
<SelectionState runConfigName="app.unitTest">
|
||||||
|
<option name="selectionMode" value="DROPDOWN" />
|
||||||
|
</SelectionState>
|
||||||
|
<SelectionState runConfigName="app.androidTest">
|
||||||
|
<option name="selectionMode" value="DROPDOWN" />
|
||||||
|
</SelectionState>
|
||||||
|
<SelectionState runConfigName="app.main">
|
||||||
|
<option name="selectionMode" value="DROPDOWN" />
|
||||||
|
</SelectionState>
|
||||||
|
<SelectionState runConfigName="workspace.OpenEUICC.app-unpriv">
|
||||||
|
<option name="selectionMode" value="DROPDOWN" />
|
||||||
|
</SelectionState>
|
||||||
|
<SelectionState runConfigName="workspace.OpenEUICC.app">
|
||||||
|
<option name="selectionMode" value="DROPDOWN" />
|
||||||
|
</SelectionState>
|
||||||
|
</selectionStates>
|
||||||
|
</component>
|
||||||
|
</project>
|
|
@ -21,7 +21,7 @@ open class DefaultEuiccChannelFactory(protected val context: Context) : EuiccCha
|
||||||
override suspend fun tryOpenEuiccChannel(
|
override suspend fun tryOpenEuiccChannel(
|
||||||
port: UiccPortInfoCompat,
|
port: UiccPortInfoCompat,
|
||||||
isdrAid: ByteArray
|
isdrAid: ByteArray
|
||||||
): EuiccChannel? = try {
|
): EuiccChannel? {
|
||||||
if (port.portIndex != 0) {
|
if (port.portIndex != 0) {
|
||||||
Log.w(
|
Log.w(
|
||||||
DefaultEuiccChannelManager.TAG,
|
DefaultEuiccChannelManager.TAG,
|
||||||
|
@ -35,8 +35,9 @@ open class DefaultEuiccChannelFactory(protected val context: Context) : EuiccCha
|
||||||
DefaultEuiccChannelManager.TAG,
|
DefaultEuiccChannelManager.TAG,
|
||||||
"Trying OMAPI for physical slot ${port.card.physicalSlotIndex}"
|
"Trying OMAPI for physical slot ${port.card.physicalSlotIndex}"
|
||||||
)
|
)
|
||||||
EuiccChannelImpl(
|
try {
|
||||||
context.getString(R.string.channel_type_omapi),
|
return EuiccChannelImpl(
|
||||||
|
context.getString(R.string.omapi),
|
||||||
port,
|
port,
|
||||||
intrinsicChannelName = null,
|
intrinsicChannelName = null,
|
||||||
OmapiApduInterface(
|
OmapiApduInterface(
|
||||||
|
@ -47,23 +48,28 @@ open class DefaultEuiccChannelFactory(protected val context: Context) : EuiccCha
|
||||||
isdrAid,
|
isdrAid,
|
||||||
context.preferenceRepository.verboseLoggingFlow,
|
context.preferenceRepository.verboseLoggingFlow,
|
||||||
context.preferenceRepository.ignoreTLSCertificateFlow,
|
context.preferenceRepository.ignoreTLSCertificateFlow,
|
||||||
context.preferenceRepository.es10xMssFlow,
|
).also {
|
||||||
)
|
Log.i(DefaultEuiccChannelManager.TAG, "Is OMAPI channel, setting MSS to 60")
|
||||||
|
it.lpa.setEs10xMss(60)
|
||||||
|
}
|
||||||
} catch (_: IllegalArgumentException) {
|
} catch (_: IllegalArgumentException) {
|
||||||
// Failed
|
// Failed
|
||||||
Log.w(
|
Log.w(
|
||||||
DefaultEuiccChannelManager.TAG,
|
DefaultEuiccChannelManager.TAG,
|
||||||
"OMAPI APDU interface unavailable for physical slot ${port.card.physicalSlotIndex} with ISD-R AID: ${isdrAid.encodeHex()}."
|
"OMAPI APDU interface unavailable for physical slot ${port.card.physicalSlotIndex} with ISD-R AID: ${isdrAid.encodeHex()}."
|
||||||
)
|
)
|
||||||
null
|
}
|
||||||
|
|
||||||
|
return null
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun tryOpenUsbEuiccChannel(
|
override fun tryOpenUsbEuiccChannel(
|
||||||
ccidCtx: UsbCcidContext,
|
ccidCtx: UsbCcidContext,
|
||||||
isdrAid: ByteArray
|
isdrAid: ByteArray
|
||||||
): EuiccChannel? = try {
|
): EuiccChannel? {
|
||||||
EuiccChannelImpl(
|
try {
|
||||||
context.getString(R.string.channel_type_usb),
|
return EuiccChannelImpl(
|
||||||
|
context.getString(R.string.usb),
|
||||||
FakeUiccPortInfoCompat(FakeUiccCardInfoCompat(EuiccChannelManager.USB_CHANNEL_ID)),
|
FakeUiccPortInfoCompat(FakeUiccCardInfoCompat(EuiccChannelManager.USB_CHANNEL_ID)),
|
||||||
intrinsicChannelName = ccidCtx.productName,
|
intrinsicChannelName = ccidCtx.productName,
|
||||||
UsbApduInterface(
|
UsbApduInterface(
|
||||||
|
@ -72,7 +78,6 @@ open class DefaultEuiccChannelFactory(protected val context: Context) : EuiccCha
|
||||||
isdrAid,
|
isdrAid,
|
||||||
context.preferenceRepository.verboseLoggingFlow,
|
context.preferenceRepository.verboseLoggingFlow,
|
||||||
context.preferenceRepository.ignoreTLSCertificateFlow,
|
context.preferenceRepository.ignoreTLSCertificateFlow,
|
||||||
context.preferenceRepository.es10xMssFlow,
|
|
||||||
)
|
)
|
||||||
} catch (_: IllegalArgumentException) {
|
} catch (_: IllegalArgumentException) {
|
||||||
// Failed
|
// Failed
|
||||||
|
@ -80,7 +85,8 @@ open class DefaultEuiccChannelFactory(protected val context: Context) : EuiccCha
|
||||||
DefaultEuiccChannelManager.TAG,
|
DefaultEuiccChannelManager.TAG,
|
||||||
"USB APDU interface unavailable for ISD-R AID: ${isdrAid.encodeHex()}."
|
"USB APDU interface unavailable for ISD-R AID: ${isdrAid.encodeHex()}."
|
||||||
)
|
)
|
||||||
null
|
}
|
||||||
|
return null
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun cleanup() {
|
override fun cleanup() {
|
||||||
|
|
|
@ -1,9 +1,8 @@
|
||||||
package im.angry.openeuicc.core
|
package im.angry.openeuicc.core
|
||||||
|
|
||||||
import im.angry.openeuicc.util.UiccPortInfoCompat
|
import im.angry.openeuicc.util.UiccPortInfoCompat
|
||||||
|
import im.angry.openeuicc.util.decodeHex
|
||||||
import kotlinx.coroutines.flow.Flow
|
import kotlinx.coroutines.flow.Flow
|
||||||
import kotlinx.coroutines.flow.first
|
|
||||||
import kotlinx.coroutines.runBlocking
|
|
||||||
import net.typeblog.lpac_jni.ApduInterface
|
import net.typeblog.lpac_jni.ApduInterface
|
||||||
import net.typeblog.lpac_jni.LocalProfileAssistant
|
import net.typeblog.lpac_jni.LocalProfileAssistant
|
||||||
import net.typeblog.lpac_jni.impl.HttpInterfaceImpl
|
import net.typeblog.lpac_jni.impl.HttpInterfaceImpl
|
||||||
|
@ -16,8 +15,7 @@ class EuiccChannelImpl(
|
||||||
override val apduInterface: ApduInterface,
|
override val apduInterface: ApduInterface,
|
||||||
override val isdrAid: ByteArray,
|
override val isdrAid: ByteArray,
|
||||||
verboseLoggingFlow: Flow<Boolean>,
|
verboseLoggingFlow: Flow<Boolean>,
|
||||||
ignoreTLSCertificateFlow: Flow<Boolean>,
|
ignoreTLSCertificateFlow: Flow<Boolean>
|
||||||
es10xMssFlow: Flow<Int>,
|
|
||||||
) : EuiccChannel {
|
) : EuiccChannel {
|
||||||
override val slotId = port.card.physicalSlotIndex
|
override val slotId = port.card.physicalSlotIndex
|
||||||
override val logicalSlotId = port.logicalSlotIndex
|
override val logicalSlotId = port.logicalSlotIndex
|
||||||
|
@ -27,10 +25,8 @@ class EuiccChannelImpl(
|
||||||
LocalProfileAssistantImpl(
|
LocalProfileAssistantImpl(
|
||||||
isdrAid,
|
isdrAid,
|
||||||
apduInterface,
|
apduInterface,
|
||||||
HttpInterfaceImpl(verboseLoggingFlow, ignoreTLSCertificateFlow),
|
HttpInterfaceImpl(verboseLoggingFlow, ignoreTLSCertificateFlow)
|
||||||
).also {
|
)
|
||||||
it.setEs10xMss(runBlocking { es10xMssFlow.first().toByte() })
|
|
||||||
}
|
|
||||||
|
|
||||||
override val atr: ByteArray?
|
override val atr: ByteArray?
|
||||||
get() = (apduInterface as? ApduInterfaceAtrProvider)?.atr
|
get() = (apduInterface as? ApduInterfaceAtrProvider)?.atr
|
||||||
|
|
|
@ -36,7 +36,7 @@ private val RE_SAS = Regex(
|
||||||
|
|
||||||
class EuiccInfoActivity : BaseEuiccAccessActivity(), OpenEuiccContextMarker {
|
class EuiccInfoActivity : BaseEuiccAccessActivity(), OpenEuiccContextMarker {
|
||||||
companion object {
|
companion object {
|
||||||
private val YES_NO = Pair(R.string.euicc_info_yes, R.string.euicc_info_no)
|
private val YES_NO = Pair(R.string.yes, R.string.no)
|
||||||
}
|
}
|
||||||
|
|
||||||
private lateinit var swipeRefresh: SwipeRefreshLayout
|
private lateinit var swipeRefresh: SwipeRefreshLayout
|
||||||
|
@ -69,7 +69,7 @@ class EuiccInfoActivity : BaseEuiccAccessActivity(), OpenEuiccContextMarker {
|
||||||
logicalSlotId = intent.getIntExtra("logicalSlotId", 0)
|
logicalSlotId = intent.getIntExtra("logicalSlotId", 0)
|
||||||
|
|
||||||
val channelTitle = if (logicalSlotId == EuiccChannelManager.USB_CHANNEL_ID) {
|
val channelTitle = if (logicalSlotId == EuiccChannelManager.USB_CHANNEL_ID) {
|
||||||
getString(R.string.channel_type_usb)
|
getString(R.string.usb)
|
||||||
} else {
|
} else {
|
||||||
appContainer.customizableTextProvider.formatInternalChannelName(logicalSlotId)
|
appContainer.customizableTextProvider.formatInternalChannelName(logicalSlotId)
|
||||||
}
|
}
|
||||||
|
@ -119,7 +119,7 @@ class EuiccInfoActivity : BaseEuiccAccessActivity(), OpenEuiccContextMarker {
|
||||||
channel.lpa.euiccInfo2?.let { info ->
|
channel.lpa.euiccInfo2?.let { info ->
|
||||||
add(Item(R.string.euicc_info_sgp22_version, info.sgp22Version.toString()))
|
add(Item(R.string.euicc_info_sgp22_version, info.sgp22Version.toString()))
|
||||||
add(Item(R.string.euicc_info_firmware_version, info.euiccFirmwareVersion.toString()))
|
add(Item(R.string.euicc_info_firmware_version, info.euiccFirmwareVersion.toString()))
|
||||||
add(Item(R.string.euicc_info_gp_version, info.globalPlatformVersion.toString()))
|
add(Item(R.string.euicc_info_globalplatform_version, info.globalPlatformVersion.toString()))
|
||||||
add(Item(R.string.euicc_info_pp_version, info.ppVersion.toString()))
|
add(Item(R.string.euicc_info_pp_version, info.ppVersion.toString()))
|
||||||
info.sasAccreditationNumber.trim().takeIf(RE_SAS::matches)
|
info.sasAccreditationNumber.trim().takeIf(RE_SAS::matches)
|
||||||
?.let { add(Item(R.string.euicc_info_sas_accreditation_number, it.uppercase())) }
|
?.let { add(Item(R.string.euicc_info_sas_accreditation_number, it.uppercase())) }
|
||||||
|
@ -131,14 +131,14 @@ class EuiccInfoActivity : BaseEuiccAccessActivity(), OpenEuiccContextMarker {
|
||||||
// FS.27 v2.0, Security Guidelines for UICC Profiles (Page 25 of 27, 2024-01-30)
|
// FS.27 v2.0, Security Guidelines for UICC Profiles (Page 25 of 27, 2024-01-30)
|
||||||
// https://www.gsma.com/solutions-and-impact/technologies/security/wp-content/uploads/2024/01/FS.27-Security-Guidelines-for-UICC-Credentials-v2.0-FINAL-23-July.pdf#page=25
|
// https://www.gsma.com/solutions-and-impact/technologies/security/wp-content/uploads/2024/01/FS.27-Security-Guidelines-for-UICC-Credentials-v2.0-FINAL-23-July.pdf#page=25
|
||||||
val resId = when {
|
val resId = when {
|
||||||
signers.isEmpty() -> R.string.euicc_info_unknown // the case is not mp, but it's is not common
|
signers.isEmpty() -> R.string.unknown // the case is not mp, but it's is not common
|
||||||
PKID_GSMA_LIVE_CI.any(signers::contains) -> R.string.euicc_info_ci_gsma_live
|
PKID_GSMA_LIVE_CI.any(signers::contains) -> R.string.euicc_info_ci_gsma_live
|
||||||
PKID_GSMA_TEST_CI.any(signers::contains) -> R.string.euicc_info_ci_gsma_test
|
PKID_GSMA_TEST_CI.any(signers::contains) -> R.string.euicc_info_ci_gsma_test
|
||||||
else -> R.string.euicc_info_ci_unknown
|
else -> R.string.euicc_info_ci_unknown
|
||||||
}
|
}
|
||||||
add(Item(R.string.euicc_info_ci_type, getString(resId)))
|
add(Item(R.string.euicc_info_ci_type, getString(resId)))
|
||||||
}
|
}
|
||||||
val atr = channel.atr?.encodeHex() ?: getString(R.string.euicc_info_unavailable)
|
val atr = channel.atr?.encodeHex() ?: getString(R.string.information_unavailable)
|
||||||
add(Item(R.string.euicc_info_atr, atr, copiedToastResId = R.string.toast_atr_copied))
|
add(Item(R.string.euicc_info_atr, atr, copiedToastResId = R.string.toast_atr_copied))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -171,7 +171,7 @@ class EuiccInfoActivity : BaseEuiccAccessActivity(), OpenEuiccContextMarker {
|
||||||
fun bind(item: Item) {
|
fun bind(item: Item) {
|
||||||
copiedToastResId = item.copiedToastResId
|
copiedToastResId = item.copiedToastResId
|
||||||
title.setText(item.titleResId)
|
title.setText(item.titleResId)
|
||||||
content.text = item.content ?: getString(R.string.euicc_info_unknown)
|
content.text = item.content ?: getString(R.string.unknown)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -174,7 +174,7 @@ open class MainActivity : BaseEuiccAccessActivity(), OpenEuiccContextMarker {
|
||||||
// If USB readers exist, add them at the very last
|
// If USB readers exist, add them at the very last
|
||||||
// We use a wrapper fragment to handle logic specific to USB readers
|
// We use a wrapper fragment to handle logic specific to USB readers
|
||||||
usbDevice?.let {
|
usbDevice?.let {
|
||||||
val productName = it.productName ?: getString(R.string.channel_type_usb)
|
val productName = it.productName ?: getString(R.string.usb)
|
||||||
newPages.add(Page(EuiccChannelManager.USB_CHANNEL_ID, productName) {
|
newPages.add(Page(EuiccChannelManager.USB_CHANNEL_ID, productName) {
|
||||||
UsbCcidReaderFragment()
|
UsbCcidReaderFragment()
|
||||||
})
|
})
|
||||||
|
|
|
@ -60,7 +60,7 @@ class NotificationsActivity: BaseEuiccAccessActivity(), OpenEuiccContextMarker {
|
||||||
// This is slightly different from the MainActivity logic
|
// This is slightly different from the MainActivity logic
|
||||||
// due to the length (we don't want to display the full USB product name)
|
// due to the length (we don't want to display the full USB product name)
|
||||||
val channelTitle = if (logicalSlotId == EuiccChannelManager.USB_CHANNEL_ID) {
|
val channelTitle = if (logicalSlotId == EuiccChannelManager.USB_CHANNEL_ID) {
|
||||||
getString(R.string.channel_type_usb)
|
getString(R.string.usb)
|
||||||
} else {
|
} else {
|
||||||
appContainer.customizableTextProvider.formatInternalChannelName(logicalSlotId)
|
appContainer.customizableTextProvider.formatInternalChannelName(logicalSlotId)
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,7 +8,6 @@ import android.provider.Settings
|
||||||
import android.widget.Toast
|
import android.widget.Toast
|
||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import androidx.preference.CheckBoxPreference
|
import androidx.preference.CheckBoxPreference
|
||||||
import androidx.preference.ListPreference
|
|
||||||
import androidx.preference.Preference
|
import androidx.preference.Preference
|
||||||
import androidx.preference.PreferenceCategory
|
import androidx.preference.PreferenceCategory
|
||||||
import androidx.preference.PreferenceFragmentCompat
|
import androidx.preference.PreferenceFragmentCompat
|
||||||
|
@ -17,6 +16,7 @@ import im.angry.openeuicc.util.*
|
||||||
import kotlinx.coroutines.flow.collect
|
import kotlinx.coroutines.flow.collect
|
||||||
import kotlinx.coroutines.flow.onEach
|
import kotlinx.coroutines.flow.onEach
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
|
import kotlinx.coroutines.runBlocking
|
||||||
|
|
||||||
open class SettingsFragment: PreferenceFragmentCompat() {
|
open class SettingsFragment: PreferenceFragmentCompat() {
|
||||||
private lateinit var developerPref: PreferenceCategory
|
private lateinit var developerPref: PreferenceCategory
|
||||||
|
@ -34,7 +34,7 @@ open class SettingsFragment: PreferenceFragmentCompat() {
|
||||||
// Show / hide developer preference based on whether it is enabled
|
// Show / hide developer preference based on whether it is enabled
|
||||||
lifecycleScope.launch {
|
lifecycleScope.launch {
|
||||||
preferenceRepository.developerOptionsEnabledFlow
|
preferenceRepository.developerOptionsEnabledFlow
|
||||||
.onEach(developerPref::setVisible)
|
.onEach { developerPref.isVisible = it }
|
||||||
.collect()
|
.collect()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -84,9 +84,6 @@ open class SettingsFragment: PreferenceFragmentCompat() {
|
||||||
requirePreference<CheckBoxPreference>("pref_developer_euicc_memory_reset")
|
requirePreference<CheckBoxPreference>("pref_developer_euicc_memory_reset")
|
||||||
.bindBooleanFlow(preferenceRepository.euiccMemoryResetFlow)
|
.bindBooleanFlow(preferenceRepository.euiccMemoryResetFlow)
|
||||||
|
|
||||||
requirePreference<ListPreference>("pref_developer_es10x_mss")
|
|
||||||
.bindIntFlow(preferenceRepository.es10xMssFlow, 63)
|
|
||||||
|
|
||||||
requirePreference<Preference>("pref_developer_isdr_aid_list").apply {
|
requirePreference<Preference>("pref_developer_isdr_aid_list").apply {
|
||||||
intent = Intent(requireContext(), IsdrAidListActivity::class.java)
|
intent = Intent(requireContext(), IsdrAidListActivity::class.java)
|
||||||
}
|
}
|
||||||
|
@ -103,53 +100,51 @@ open class SettingsFragment: PreferenceFragmentCompat() {
|
||||||
@Suppress("UNUSED_PARAMETER")
|
@Suppress("UNUSED_PARAMETER")
|
||||||
private fun onAppVersionClicked(pref: Preference): Boolean {
|
private fun onAppVersionClicked(pref: Preference): Boolean {
|
||||||
if (developerPref.isVisible) return false
|
if (developerPref.isVisible) return false
|
||||||
|
|
||||||
val now = System.currentTimeMillis()
|
val now = System.currentTimeMillis()
|
||||||
numClicks = if (now - lastClickTimestamp >= 1000) 1 else numClicks + 1
|
if (now - lastClickTimestamp >= 1000) {
|
||||||
|
numClicks = 1
|
||||||
|
} else {
|
||||||
|
numClicks++
|
||||||
|
}
|
||||||
lastClickTimestamp = now
|
lastClickTimestamp = now
|
||||||
|
|
||||||
|
if (numClicks == 7) {
|
||||||
lifecycleScope.launch {
|
lifecycleScope.launch {
|
||||||
preferenceRepository.developerOptionsEnabledFlow.updatePreference(numClicks >= 7)
|
preferenceRepository.developerOptionsEnabledFlow.updatePreference(true)
|
||||||
}
|
|
||||||
|
|
||||||
val toastText = when {
|
|
||||||
numClicks == 7 -> getString(R.string.developer_options_enabled)
|
|
||||||
numClicks > 1 -> getString(R.string.developer_options_steps, 7 - numClicks)
|
|
||||||
else -> return true
|
|
||||||
}
|
|
||||||
|
|
||||||
lastToast?.cancel()
|
lastToast?.cancel()
|
||||||
lastToast = Toast.makeText(requireContext(), toastText, Toast.LENGTH_SHORT)
|
Toast.makeText(
|
||||||
|
requireContext(),
|
||||||
|
R.string.developer_options_enabled,
|
||||||
|
Toast.LENGTH_SHORT
|
||||||
|
).show()
|
||||||
|
}
|
||||||
|
} else if (numClicks > 1) {
|
||||||
|
lastToast?.cancel()
|
||||||
|
lastToast = Toast.makeText(
|
||||||
|
requireContext(),
|
||||||
|
getString(R.string.developer_options_steps, 7 - numClicks),
|
||||||
|
Toast.LENGTH_SHORT
|
||||||
|
)
|
||||||
lastToast!!.show()
|
lastToast!!.show()
|
||||||
|
}
|
||||||
|
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
protected fun CheckBoxPreference.bindBooleanFlow(flow: PreferenceFlowWrapper<Boolean>) {
|
protected fun CheckBoxPreference.bindBooleanFlow(flow: PreferenceFlowWrapper<Boolean>) {
|
||||||
lifecycleScope.launch {
|
lifecycleScope.launch {
|
||||||
flow.collect(::setChecked)
|
flow.collect { isChecked = it }
|
||||||
}
|
}
|
||||||
|
|
||||||
setOnPreferenceChangeListener { _, newValue ->
|
setOnPreferenceChangeListener { _, newValue ->
|
||||||
lifecycleScope.launch {
|
runBlocking {
|
||||||
flow.updatePreference(newValue as Boolean)
|
flow.updatePreference(newValue as Boolean)
|
||||||
}
|
}
|
||||||
true
|
true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun ListPreference.bindIntFlow(flow: PreferenceFlowWrapper<Int>, defaultValue: Int) {
|
|
||||||
lifecycleScope.launch {
|
|
||||||
flow.collect { value = it.toString() }
|
|
||||||
}
|
|
||||||
|
|
||||||
setOnPreferenceChangeListener { _, newValue ->
|
|
||||||
lifecycleScope.launch {
|
|
||||||
flow.updatePreference((newValue as String).toIntOrNull() ?: defaultValue)
|
|
||||||
}
|
|
||||||
true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
protected fun mergePreferenceOverlay(overlayKey: String, targetKey: String) {
|
protected fun mergePreferenceOverlay(overlayKey: String, targetKey: String) {
|
||||||
val overlayCat = requirePreference<PreferenceCategory>(overlayKey)
|
val overlayCat = requirePreference<PreferenceCategory>(overlayKey)
|
||||||
val targetCat = requirePreference<PreferenceCategory>(targetKey)
|
val targetCat = requirePreference<PreferenceCategory>(targetKey)
|
||||||
|
|
|
@ -19,6 +19,7 @@ import im.angry.openeuicc.util.*
|
||||||
import kotlinx.coroutines.flow.map
|
import kotlinx.coroutines.flow.map
|
||||||
import kotlinx.coroutines.flow.toList
|
import kotlinx.coroutines.flow.toList
|
||||||
import kotlinx.coroutines.launch
|
import kotlinx.coroutines.launch
|
||||||
|
import net.typeblog.lpac_jni.LocalProfileInfo
|
||||||
|
|
||||||
class DownloadWizardSlotSelectFragment : DownloadWizardActivity.DownloadWizardStepFragment() {
|
class DownloadWizardSlotSelectFragment : DownloadWizardActivity.DownloadWizardStepFragment() {
|
||||||
companion object {
|
companion object {
|
||||||
|
@ -186,12 +187,12 @@ class DownloadWizardSlotSelectFragment : DownloadWizardActivity.DownloadWizardSt
|
||||||
}
|
}
|
||||||
|
|
||||||
title.text = if (item.logicalSlotId == EuiccChannelManager.USB_CHANNEL_ID) {
|
title.text = if (item.logicalSlotId == EuiccChannelManager.USB_CHANNEL_ID) {
|
||||||
item.intrinsicChannelName ?: root.context.getString(R.string.channel_type_usb)
|
item.intrinsicChannelName ?: root.context.getString(R.string.usb)
|
||||||
} else {
|
} else {
|
||||||
appContainer.customizableTextProvider.formatInternalChannelName(item.logicalSlotId)
|
appContainer.customizableTextProvider.formatInternalChannelName(item.logicalSlotId)
|
||||||
}
|
}
|
||||||
eID.text = item.eID
|
eID.text = item.eID
|
||||||
activeProfile.text = item.enabledProfileName ?: root.context.getString(R.string.profile_no_enabled_profile)
|
activeProfile.text = item.enabledProfileName ?: root.context.getString(R.string.unknown)
|
||||||
freeSpace.text = formatFreeSpace(item.freeSpace)
|
freeSpace.text = formatFreeSpace(item.freeSpace)
|
||||||
checkBox.isChecked = adapter.currentSelectedIdx == idx
|
checkBox.isChecked = adapter.currentSelectedIdx == idx
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,6 @@ import androidx.datastore.core.DataStore
|
||||||
import androidx.datastore.preferences.core.Preferences
|
import androidx.datastore.preferences.core.Preferences
|
||||||
import androidx.datastore.preferences.core.booleanPreferencesKey
|
import androidx.datastore.preferences.core.booleanPreferencesKey
|
||||||
import androidx.datastore.preferences.core.edit
|
import androidx.datastore.preferences.core.edit
|
||||||
import androidx.datastore.preferences.core.intPreferencesKey
|
|
||||||
import androidx.datastore.preferences.core.stringPreferencesKey
|
import androidx.datastore.preferences.core.stringPreferencesKey
|
||||||
import androidx.datastore.preferences.preferencesDataStore
|
import androidx.datastore.preferences.preferencesDataStore
|
||||||
import androidx.fragment.app.Fragment
|
import androidx.fragment.app.Fragment
|
||||||
|
@ -39,7 +38,6 @@ internal object PreferenceKeys {
|
||||||
val IGNORE_TLS_CERTIFICATE = booleanPreferencesKey("ignore_tls_certificate")
|
val IGNORE_TLS_CERTIFICATE = booleanPreferencesKey("ignore_tls_certificate")
|
||||||
val EUICC_MEMORY_RESET = booleanPreferencesKey("euicc_memory_reset")
|
val EUICC_MEMORY_RESET = booleanPreferencesKey("euicc_memory_reset")
|
||||||
val ISDR_AID_LIST = stringPreferencesKey("isdr_aid_list")
|
val ISDR_AID_LIST = stringPreferencesKey("isdr_aid_list")
|
||||||
val ES10X_MSS = intPreferencesKey("es10x_mss")
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const val EUICC_DEFAULT_ISDR_AID = "A0000005591010FFFFFFFF8900000100"
|
const val EUICC_DEFAULT_ISDR_AID = "A0000005591010FFFFFFFF8900000100"
|
||||||
|
@ -52,12 +50,9 @@ internal object PreferenceConstants {
|
||||||
# eUICC standard
|
# eUICC standard
|
||||||
$EUICC_DEFAULT_ISDR_AID
|
$EUICC_DEFAULT_ISDR_AID
|
||||||
|
|
||||||
# ESTKme AUX (deprecated, use SE0 instead)
|
# eSTK.me
|
||||||
A06573746B6D65FFFFFFFF4953442D52
|
A06573746B6D65FFFFFFFF4953442D52
|
||||||
|
|
||||||
# ESTKme SE0
|
|
||||||
A06573746B6D65FFFF4953442D522030
|
|
||||||
|
|
||||||
# eSIM.me
|
# eSIM.me
|
||||||
A0000005591010000000008900000300
|
A0000005591010000000008900000300
|
||||||
|
|
||||||
|
@ -91,7 +86,6 @@ open class PreferenceRepository(private val context: Context) {
|
||||||
PreferenceConstants.DEFAULT_AID_LIST,
|
PreferenceConstants.DEFAULT_AID_LIST,
|
||||||
{ Base64.getEncoder().encodeToString(it.encodeToByteArray()) },
|
{ Base64.getEncoder().encodeToString(it.encodeToByteArray()) },
|
||||||
{ Base64.getDecoder().decode(it).decodeToString() })
|
{ Base64.getDecoder().decode(it).decodeToString() })
|
||||||
val es10xMssFlow = bindFlow(PreferenceKeys.ES10X_MSS, 63)
|
|
||||||
|
|
||||||
protected fun <T> bindFlow(
|
protected fun <T> bindFlow(
|
||||||
key: Preferences.Key<T>,
|
key: Preferences.Key<T>,
|
||||||
|
|
|
@ -102,8 +102,8 @@ fun <T : ActivityResultCaller> T.setupLogSaving(
|
||||||
|
|
||||||
AlertDialog.Builder(context).apply {
|
AlertDialog.Builder(context).apply {
|
||||||
setMessage(R.string.logs_saved_message)
|
setMessage(R.string.logs_saved_message)
|
||||||
setNegativeButton(android.R.string.cancel) { _, _ -> }
|
setNegativeButton(R.string.no) { _, _ -> }
|
||||||
setPositiveButton(android.R.string.ok) { _, _ ->
|
setPositiveButton(R.string.yes) { _, _ ->
|
||||||
val intent = Intent(Intent.ACTION_SEND).apply {
|
val intent = Intent(Intent.ACTION_SEND).apply {
|
||||||
type = "text/plain"
|
type = "text/plain"
|
||||||
clipData = ClipData.newUri(context.contentResolver, lastFileName, uri)
|
clipData = ClipData.newUri(context.contentResolver, lastFileName, uri)
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
|
|
||||||
<item
|
<item
|
||||||
android:id="@+id/reset"
|
android:id="@+id/reset"
|
||||||
android:title="@string/isdr_aid_list_restore_defaults"
|
android:title="@string/reset"
|
||||||
android:icon="@drawable/ic_refresh_black"
|
android:icon="@drawable/ic_refresh_black"
|
||||||
app:showAsAction="ifRoom" />
|
app:showAsAction="ifRoom" />
|
||||||
</menu>
|
</menu>
|
|
@ -3,7 +3,7 @@
|
||||||
xmlns:app="http://schemas.android.com/apk/res-auto">
|
xmlns:app="http://schemas.android.com/apk/res-auto">
|
||||||
<item
|
<item
|
||||||
android:id="@+id/reload"
|
android:id="@+id/reload"
|
||||||
android:title="@string/profile_reload_slots"
|
android:title="@string/reload"
|
||||||
android:icon="@drawable/ic_refresh_black"
|
android:icon="@drawable/ic_refresh_black"
|
||||||
app:showAsAction="ifRoom" />
|
app:showAsAction="ifRoom" />
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,6 @@
|
||||||
<item
|
<item
|
||||||
android:id="@+id/help"
|
android:id="@+id/help"
|
||||||
android:icon="@drawable/ic_help_black"
|
android:icon="@drawable/ic_help_black"
|
||||||
android:title="@string/notification_help"
|
android:title="@string/help"
|
||||||
app:showAsAction="always" />
|
app:showAsAction="always" />
|
||||||
</menu>
|
</menu>
|
|
@ -2,10 +2,10 @@
|
||||||
<resources>
|
<resources>
|
||||||
<string name="no_euicc">このアプリでアクセスできるリムーバブル eUICC カードがデバイス上で検出されていません。互換性のあるカード挿入または USB リーダーを接続してください。</string>
|
<string name="no_euicc">このアプリでアクセスできるリムーバブル eUICC カードがデバイス上で検出されていません。互換性のあるカード挿入または USB リーダーを接続してください。</string>
|
||||||
<string name="no_profile">この eSIM にはプロファイルがありません。</string>
|
<string name="no_profile">この eSIM にはプロファイルがありません。</string>
|
||||||
<string name="euicc_info_unknown">不明</string>
|
<string name="unknown">不明</string>
|
||||||
<string name="euicc_info_unavailable">情報がありません</string>
|
<string name="information_unavailable">情報がありません</string>
|
||||||
<string name="notification_help">ヘルプ</string>
|
<string name="help">ヘルプ</string>
|
||||||
<string name="profile_reload_slots">スロットを再読み込み</string>
|
<string name="reload">スロットを再読み込み</string>
|
||||||
<string name="channel_name_format">論理スロット %d</string>
|
<string name="channel_name_format">論理スロット %d</string>
|
||||||
<string name="profile_state_enabled">有効済み</string>
|
<string name="profile_state_enabled">有効済み</string>
|
||||||
<string name="profile_state_disabled">無効済み</string>
|
<string name="profile_state_disabled">無効済み</string>
|
||||||
|
@ -110,7 +110,7 @@
|
||||||
<string name="euicc_info_fw_ver">製品ファームウェアバージョン</string>
|
<string name="euicc_info_fw_ver">製品ファームウェアバージョン</string>
|
||||||
<string name="euicc_info_sgp22_version">SGP.22 バージョン</string>
|
<string name="euicc_info_sgp22_version">SGP.22 バージョン</string>
|
||||||
<string name="euicc_info_firmware_version">eUICC OS バージョン</string>
|
<string name="euicc_info_firmware_version">eUICC OS バージョン</string>
|
||||||
<string name="euicc_info_gp_version">グローバルプラットフォームのバージョン</string>
|
<string name="euicc_info_globalplatform_version">グローバルプラットフォームのバージョン</string>
|
||||||
<string name="euicc_info_sas_accreditation_number">SAS 認定番号</string>
|
<string name="euicc_info_sas_accreditation_number">SAS 認定番号</string>
|
||||||
<string name="euicc_info_pp_version">保護されたプロファイルのバージョン</string>
|
<string name="euicc_info_pp_version">保護されたプロファイルのバージョン</string>
|
||||||
<string name="euicc_info_free_nvram">NVRAM の空き容量 (eSIM プロファイルストレージ)</string>
|
<string name="euicc_info_free_nvram">NVRAM の空き容量 (eSIM プロファイルストレージ)</string>
|
||||||
|
@ -118,8 +118,8 @@
|
||||||
<string name="euicc_info_ci_gsma_live">GSMA ライブ CI</string>
|
<string name="euicc_info_ci_gsma_live">GSMA ライブ CI</string>
|
||||||
<string name="euicc_info_ci_gsma_test">GSMA テスト CI</string>
|
<string name="euicc_info_ci_gsma_test">GSMA テスト CI</string>
|
||||||
<string name="euicc_info_ci_unknown">不明な eSIM CI</string>
|
<string name="euicc_info_ci_unknown">不明な eSIM CI</string>
|
||||||
<string name="euicc_info_yes">はい</string>
|
<string name="yes">はい</string>
|
||||||
<string name="euicc_info_no">いいえ</string>
|
<string name="no">いいえ</string>
|
||||||
<string name="logs_save">保存</string>
|
<string name="logs_save">保存</string>
|
||||||
<string name="logs_filename_template">%s のログ</string>
|
<string name="logs_filename_template">%s のログ</string>
|
||||||
<string name="developer_options_steps">開発者になるまであと %d ステップです。</string>
|
<string name="developer_options_steps">開発者になるまであと %d ステップです。</string>
|
||||||
|
@ -167,6 +167,6 @@
|
||||||
<string name="pref_developer_euicc_memory_reset_desc">この操作は、デフォルトでは非表示になっている危険な操作です。代わりに、すべての構成ファイルを手動で削除することもできます。</string>
|
<string name="pref_developer_euicc_memory_reset_desc">この操作は、デフォルトでは非表示になっている危険な操作です。代わりに、すべての構成ファイルを手動で削除することもできます。</string>
|
||||||
<string name="pref_developer_refresh_after_switch">モデムに更新コマンドを送信</string>
|
<string name="pref_developer_refresh_after_switch">モデムに更新コマンドを送信</string>
|
||||||
<string name="pref_developer_isdr_aid_list">ISD-R AID リストのカスタマイズ</string>
|
<string name="pref_developer_isdr_aid_list">ISD-R AID リストのカスタマイズ</string>
|
||||||
<string name="isdr_aid_list_restore_defaults">リセット</string>
|
<string name="reset">リセット</string>
|
||||||
<string name="isdr_aid_list">ISD-R AID リスト</string>
|
<string name="isdr_aid_list">ISD-R AID リスト</string>
|
||||||
</resources>
|
</resources>
|
||||||
|
|
|
@ -2,9 +2,9 @@
|
||||||
<resources>
|
<resources>
|
||||||
<string name="no_euicc">在此设备上未检测到此应用程序可访问的可插拔 eUICC 卡。请插入兼容卡或 USB 读卡器。</string>
|
<string name="no_euicc">在此设备上未检测到此应用程序可访问的可插拔 eUICC 卡。请插入兼容卡或 USB 读卡器。</string>
|
||||||
<string name="no_profile">此 eSIM 上还没有配置文件</string>
|
<string name="no_profile">此 eSIM 上还没有配置文件</string>
|
||||||
<string name="euicc_info_unknown">未知</string>
|
<string name="unknown">未知</string>
|
||||||
<string name="notification_help">帮助</string>
|
<string name="help">帮助</string>
|
||||||
<string name="profile_reload_slots">重新加载卡槽</string>
|
<string name="reload">重新加载卡槽</string>
|
||||||
<string name="channel_name_format">逻辑卡槽 %d</string>
|
<string name="channel_name_format">逻辑卡槽 %d</string>
|
||||||
<string name="profile_state_enabled">已启用</string>
|
<string name="profile_state_enabled">已启用</string>
|
||||||
<string name="profile_state_disabled">已禁用</string>
|
<string name="profile_state_disabled">已禁用</string>
|
||||||
|
@ -132,7 +132,7 @@
|
||||||
<string name="euicc_info_removable">可插拔</string>
|
<string name="euicc_info_removable">可插拔</string>
|
||||||
<string name="euicc_info_sgp22_version">SGP.22 版本</string>
|
<string name="euicc_info_sgp22_version">SGP.22 版本</string>
|
||||||
<string name="euicc_info_firmware_version">eUICC OS 版本</string>
|
<string name="euicc_info_firmware_version">eUICC OS 版本</string>
|
||||||
<string name="euicc_info_gp_version">GlobalPlatform 版本</string>
|
<string name="euicc_info_globalplatform_version">GlobalPlatform 版本</string>
|
||||||
<string name="euicc_info_sas_accreditation_number">SAS 认证号码</string>
|
<string name="euicc_info_sas_accreditation_number">SAS 认证号码</string>
|
||||||
<string name="euicc_info_pp_version">Protected Profile 版本</string>
|
<string name="euicc_info_pp_version">Protected Profile 版本</string>
|
||||||
<string name="euicc_info_free_nvram">NVRAM 剩余空间 (eSIM 存储容量)</string>
|
<string name="euicc_info_free_nvram">NVRAM 剩余空间 (eSIM 存储容量)</string>
|
||||||
|
@ -140,8 +140,8 @@
|
||||||
<string name="euicc_info_ci_gsma_live">GSMA 生产环境 CI</string>
|
<string name="euicc_info_ci_gsma_live">GSMA 生产环境 CI</string>
|
||||||
<string name="euicc_info_ci_gsma_test">GSMA 测试 CI</string>
|
<string name="euicc_info_ci_gsma_test">GSMA 测试 CI</string>
|
||||||
<string name="euicc_info_ci_unknown">未知 eSIM CI</string>
|
<string name="euicc_info_ci_unknown">未知 eSIM CI</string>
|
||||||
<string name="euicc_info_yes">是</string>
|
<string name="yes">是</string>
|
||||||
<string name="euicc_info_no">否</string>
|
<string name="no">否</string>
|
||||||
<string name="developer_options_steps">还有 %d 步成为开发者</string>
|
<string name="developer_options_steps">还有 %d 步成为开发者</string>
|
||||||
<string name="developer_options_enabled">你现在是开发者了!</string>
|
<string name="developer_options_enabled">你现在是开发者了!</string>
|
||||||
<string name="pref_advanced_language">语言</string>
|
<string name="pref_advanced_language">语言</string>
|
||||||
|
@ -152,7 +152,7 @@
|
||||||
<string name="pref_developer_unfiltered_profile_list_desc">在配置文件列表中包括非生产环境的配置文件</string>
|
<string name="pref_developer_unfiltered_profile_list_desc">在配置文件列表中包括非生产环境的配置文件</string>
|
||||||
<string name="pref_developer_ignore_tls_certificate">无视 SM-DP+ 的 TLS 证书</string>
|
<string name="pref_developer_ignore_tls_certificate">无视 SM-DP+ 的 TLS 证书</string>
|
||||||
<string name="pref_developer_ignore_tls_certificate_desc">允许 RSP 服务器使用任意证书</string>
|
<string name="pref_developer_ignore_tls_certificate_desc">允许 RSP 服务器使用任意证书</string>
|
||||||
<string name="euicc_info_unavailable">无信息</string>
|
<string name="information_unavailable">无信息</string>
|
||||||
<string name="toast_euicc_memory_reset_confirm_text_mismatched">输入的确认文本不匹配</string>
|
<string name="toast_euicc_memory_reset_confirm_text_mismatched">输入的确认文本不匹配</string>
|
||||||
<string name="toast_euicc_memory_reset_finitshed">此芯片已被擦除</string>
|
<string name="toast_euicc_memory_reset_finitshed">此芯片已被擦除</string>
|
||||||
<string name="task_euicc_memory_reset">正在擦除 eSIM 芯片</string>
|
<string name="task_euicc_memory_reset">正在擦除 eSIM 芯片</string>
|
||||||
|
@ -167,6 +167,6 @@
|
||||||
<string name="pref_developer_euicc_memory_reset_desc">此操作是默认隐藏的危险操作。作为替代方案,您可以手动删除所有配置文件。</string>
|
<string name="pref_developer_euicc_memory_reset_desc">此操作是默认隐藏的危险操作。作为替代方案,您可以手动删除所有配置文件。</string>
|
||||||
<string name="pref_developer_refresh_after_switch">向基带发送刷新命令</string>
|
<string name="pref_developer_refresh_after_switch">向基带发送刷新命令</string>
|
||||||
<string name="pref_developer_isdr_aid_list">自定义 ISD-R AID 列表</string>
|
<string name="pref_developer_isdr_aid_list">自定义 ISD-R AID 列表</string>
|
||||||
<string name="isdr_aid_list_restore_defaults">重置</string>
|
<string name="reset">重置</string>
|
||||||
<string name="isdr_aid_list">ISD-R AID 列表</string>
|
<string name="isdr_aid_list">ISD-R AID 列表</string>
|
||||||
</resources>
|
</resources>
|
|
@ -2,9 +2,9 @@
|
||||||
<resources>
|
<resources>
|
||||||
<string name="no_euicc">在此裝置上未檢測到此應用程式可訪問的可插拔 eUICC 卡。請插入相容卡或 USB 晶片讀卡機。</string>
|
<string name="no_euicc">在此裝置上未檢測到此應用程式可訪問的可插拔 eUICC 卡。請插入相容卡或 USB 晶片讀卡機。</string>
|
||||||
<string name="no_profile">此 eSIM 上還沒有設定檔</string>
|
<string name="no_profile">此 eSIM 上還沒有設定檔</string>
|
||||||
<string name="euicc_info_unknown">未知</string>
|
<string name="unknown">未知</string>
|
||||||
<string name="notification_help">幫助</string>
|
<string name="help">幫助</string>
|
||||||
<string name="profile_reload_slots">重新載入卡槽</string>
|
<string name="reload">重新載入卡槽</string>
|
||||||
<string name="channel_name_format">虛擬卡槽 %d</string>
|
<string name="channel_name_format">虛擬卡槽 %d</string>
|
||||||
<string name="profile_state_enabled">已啟用</string>
|
<string name="profile_state_enabled">已啟用</string>
|
||||||
<string name="profile_state_disabled">已停用</string>
|
<string name="profile_state_disabled">已停用</string>
|
||||||
|
@ -132,7 +132,7 @@
|
||||||
<string name="euicc_info_removable">可插拔</string>
|
<string name="euicc_info_removable">可插拔</string>
|
||||||
<string name="euicc_info_sgp22_version">SGP.22 版本</string>
|
<string name="euicc_info_sgp22_version">SGP.22 版本</string>
|
||||||
<string name="euicc_info_firmware_version">eUICC OS 版本</string>
|
<string name="euicc_info_firmware_version">eUICC OS 版本</string>
|
||||||
<string name="euicc_info_gp_version">GlobalPlatform 版本</string>
|
<string name="euicc_info_globalplatform_version">GlobalPlatform 版本</string>
|
||||||
<string name="euicc_info_sas_accreditation_number">SAS 認證號碼</string>
|
<string name="euicc_info_sas_accreditation_number">SAS 認證號碼</string>
|
||||||
<string name="euicc_info_pp_version">Protected Profile 版本</string>
|
<string name="euicc_info_pp_version">Protected Profile 版本</string>
|
||||||
<string name="euicc_info_free_nvram">NVRAM 剩餘空間 (eSIM 儲存容量)</string>
|
<string name="euicc_info_free_nvram">NVRAM 剩餘空間 (eSIM 儲存容量)</string>
|
||||||
|
@ -140,8 +140,8 @@
|
||||||
<string name="euicc_info_ci_gsma_live">GSMA 生產環境 CI</string>
|
<string name="euicc_info_ci_gsma_live">GSMA 生產環境 CI</string>
|
||||||
<string name="euicc_info_ci_gsma_test">GSMA 測試 CI</string>
|
<string name="euicc_info_ci_gsma_test">GSMA 測試 CI</string>
|
||||||
<string name="euicc_info_ci_unknown">未知 eSIM CI</string>
|
<string name="euicc_info_ci_unknown">未知 eSIM CI</string>
|
||||||
<string name="euicc_info_yes">是</string>
|
<string name="yes">是</string>
|
||||||
<string name="euicc_info_no">否</string>
|
<string name="no">否</string>
|
||||||
<string name="developer_options_steps">還有 %d 步成為開發者</string>
|
<string name="developer_options_steps">還有 %d 步成為開發者</string>
|
||||||
<string name="developer_options_enabled">您現在是開發者了!</string>
|
<string name="developer_options_enabled">您現在是開發者了!</string>
|
||||||
<string name="pref_advanced_language">語言</string>
|
<string name="pref_advanced_language">語言</string>
|
||||||
|
@ -152,7 +152,7 @@
|
||||||
<string name="pref_developer_unfiltered_profile_list_desc">在設定檔列表中包括非生產環境的設定檔</string>
|
<string name="pref_developer_unfiltered_profile_list_desc">在設定檔列表中包括非生產環境的設定檔</string>
|
||||||
<string name="pref_developer_ignore_tls_certificate">忽略 SM-DP+ 的 TLS 證書</string>
|
<string name="pref_developer_ignore_tls_certificate">忽略 SM-DP+ 的 TLS 證書</string>
|
||||||
<string name="pref_developer_ignore_tls_certificate_desc">允許 RSP 伺服器使用任意證書</string>
|
<string name="pref_developer_ignore_tls_certificate_desc">允許 RSP 伺服器使用任意證書</string>
|
||||||
<string name="euicc_info_unavailable">無資訊</string>
|
<string name="information_unavailable">無資訊</string>
|
||||||
<string name="toast_euicc_memory_reset_confirm_text_mismatched">輸入的確認文字不匹配</string>
|
<string name="toast_euicc_memory_reset_confirm_text_mismatched">輸入的確認文字不匹配</string>
|
||||||
<string name="toast_euicc_memory_reset_finitshed">此晶片已被擦除</string>
|
<string name="toast_euicc_memory_reset_finitshed">此晶片已被擦除</string>
|
||||||
<string name="task_euicc_memory_reset">正在擦除 eSIM 晶片</string>
|
<string name="task_euicc_memory_reset">正在擦除 eSIM 晶片</string>
|
||||||
|
@ -167,6 +167,6 @@
|
||||||
<string name="pref_developer_euicc_memory_reset_desc">此操作是預設隱藏的危險操作。作為替代方案,您可以手動刪除所有設定檔。</string>
|
<string name="pref_developer_euicc_memory_reset_desc">此操作是預設隱藏的危險操作。作為替代方案,您可以手動刪除所有設定檔。</string>
|
||||||
<string name="pref_developer_refresh_after_switch">向基帶發送刷新命令</string>
|
<string name="pref_developer_refresh_after_switch">向基帶發送刷新命令</string>
|
||||||
<string name="pref_developer_isdr_aid_list">自訂 ISD-R AID 列表</string>
|
<string name="pref_developer_isdr_aid_list">自訂 ISD-R AID 列表</string>
|
||||||
<string name="isdr_aid_list_restore_defaults">重置</string>
|
<string name="reset">重置</string>
|
||||||
<string name="isdr_aid_list">ISD-R AID 列表</string>
|
<string name="isdr_aid_list">ISD-R AID 列表</string>
|
||||||
</resources>
|
</resources>
|
|
@ -2,15 +2,14 @@
|
||||||
<resources>
|
<resources>
|
||||||
<string name="no_euicc">No removable eUICC card accessible by this app is detected on this device. Insert a compatible card or a USB reader.</string>
|
<string name="no_euicc">No removable eUICC card accessible by this app is detected on this device. Insert a compatible card or a USB reader.</string>
|
||||||
<string name="no_profile">No profiles (yet) on this eSIM.</string>
|
<string name="no_profile">No profiles (yet) on this eSIM.</string>
|
||||||
|
<string name="unknown">Unknown</string>
|
||||||
<string name="notification_help">Help</string>
|
<string name="information_unavailable">Information Unavailable</string>
|
||||||
|
<string name="help">Help</string>
|
||||||
<string name="profile_reload_slots">Reload Slots</string>
|
<string name="reload">Reload Slots</string>
|
||||||
<string name="profile_no_enabled_profile">Unknown</string>
|
|
||||||
|
|
||||||
<string name="channel_name_format">Logical Slot %d</string>
|
<string name="channel_name_format">Logical Slot %d</string>
|
||||||
<string name="channel_type_usb" translatable="false">USB</string>
|
<string name="usb" translatable="false">USB</string>
|
||||||
<string name="channel_type_omapi" translatable="false">OpenMobile API (OMAPI)</string>
|
<string name="omapi" translatable="false">OpenMobile API (OMAPI)</string>
|
||||||
|
|
||||||
<!-- Profile -->
|
<!-- Profile -->
|
||||||
<string name="profile_state_enabled">Enabled</string>
|
<string name="profile_state_enabled">Enabled</string>
|
||||||
|
@ -160,7 +159,7 @@
|
||||||
<string name="euicc_info_isdr_aid" translatable="false">ISD-R AID</string>
|
<string name="euicc_info_isdr_aid" translatable="false">ISD-R AID</string>
|
||||||
<string name="euicc_info_sgp22_version">SGP.22 Version</string>
|
<string name="euicc_info_sgp22_version">SGP.22 Version</string>
|
||||||
<string name="euicc_info_firmware_version">eUICC OS Version</string>
|
<string name="euicc_info_firmware_version">eUICC OS Version</string>
|
||||||
<string name="euicc_info_gp_version">GlobalPlatform Version</string>
|
<string name="euicc_info_globalplatform_version">GlobalPlatform Version</string>
|
||||||
<string name="euicc_info_sas_accreditation_number">SAS Accreditation Number</string>
|
<string name="euicc_info_sas_accreditation_number">SAS Accreditation Number</string>
|
||||||
<string name="euicc_info_pp_version">Protected Profile Version</string>
|
<string name="euicc_info_pp_version">Protected Profile Version</string>
|
||||||
<string name="euicc_info_free_nvram">Free NVRAM (eSIM profile storage)</string>
|
<string name="euicc_info_free_nvram">Free NVRAM (eSIM profile storage)</string>
|
||||||
|
@ -177,11 +176,8 @@
|
||||||
<string name="euicc_memory_reset_confirm_text">I CONFIRM TO ERASE THE CHIP WHOSE EID ENDS WITH %s AND UNDERSTAND THAT THIS IS IRREVERSIBLE</string>
|
<string name="euicc_memory_reset_confirm_text">I CONFIRM TO ERASE THE CHIP WHOSE EID ENDS WITH %s AND UNDERSTAND THAT THIS IS IRREVERSIBLE</string>
|
||||||
<string name="euicc_memory_reset_invoke_button">Erase</string>
|
<string name="euicc_memory_reset_invoke_button">Erase</string>
|
||||||
|
|
||||||
<!-- eUICC Info -->
|
<string name="yes">Yes</string>
|
||||||
<string name="euicc_info_yes">Yes</string>
|
<string name="no">No</string>
|
||||||
<string name="euicc_info_no">No</string>
|
|
||||||
<string name="euicc_info_unknown">Unknown</string>
|
|
||||||
<string name="euicc_info_unavailable">Information Unavailable</string>
|
|
||||||
|
|
||||||
<string name="logs_save">Save</string>
|
<string name="logs_save">Save</string>
|
||||||
<string name="logs_filename_template">Logs at %s</string>
|
<string name="logs_filename_template">Logs at %s</string>
|
||||||
|
@ -189,9 +185,10 @@
|
||||||
<string name="developer_options_steps">You are %d steps away from being a developer.</string>
|
<string name="developer_options_steps">You are %d steps away from being a developer.</string>
|
||||||
<string name="developer_options_enabled">You are now a developer!</string>
|
<string name="developer_options_enabled">You are now a developer!</string>
|
||||||
|
|
||||||
|
<string name="reset">Reset</string>
|
||||||
|
|
||||||
<string name="isdr_aid_list">ISD-R AID List</string>
|
<string name="isdr_aid_list">ISD-R AID List</string>
|
||||||
<string name="isdr_aid_list_saved">Saved custom ISD-R AID list.</string>
|
<string name="isdr_aid_list_saved">Saved custom ISD-R AID list.</string>
|
||||||
<string name="isdr_aid_list_restore_defaults">Reset</string>
|
|
||||||
|
|
||||||
<string name="pref_settings">Settings</string>
|
<string name="pref_settings">Settings</string>
|
||||||
<string name="pref_notifications">Notifications</string>
|
<string name="pref_notifications">Notifications</string>
|
||||||
|
@ -220,16 +217,6 @@
|
||||||
<string name="pref_developer_ignore_tls_certificate_desc">Accept any TLS certificate used by the RSP server</string>
|
<string name="pref_developer_ignore_tls_certificate_desc">Accept any TLS certificate used by the RSP server</string>
|
||||||
<string name="pref_developer_euicc_memory_reset">Allow erasing eUICC</string>
|
<string name="pref_developer_euicc_memory_reset">Allow erasing eUICC</string>
|
||||||
<string name="pref_developer_euicc_memory_reset_desc">This is a dangerous operation and hidden by default. As an alternative, you can delete all profiles manually.</string>
|
<string name="pref_developer_euicc_memory_reset_desc">This is a dangerous operation and hidden by default. As an alternative, you can delete all profiles manually.</string>
|
||||||
<string name="pref_developer_es10x_mss">ES10x MSS</string>
|
|
||||||
<string name="pref_developer_es10x_mss_desc">Global ES10x MSS</string>
|
|
||||||
<string-array name="pref_developer_es10x_entry_keys">
|
|
||||||
<item>High Speed</item>
|
|
||||||
<item>Compatibility Mode</item>
|
|
||||||
</string-array>
|
|
||||||
<string-array name="pref_developer_es10x_entry_values" translatable="false">
|
|
||||||
<item>255</item>
|
|
||||||
<item>63</item>
|
|
||||||
</string-array>
|
|
||||||
<string name="pref_developer_isdr_aid_list">Customize ISD-R AID list</string>
|
<string name="pref_developer_isdr_aid_list">Customize ISD-R AID list</string>
|
||||||
<string name="pref_developer_isdr_aid_list_desc">Some brands of removable eUICCs may use their own non-standard ISD-R AID, rendering them inaccessible to third-party apps. We can attempt to use non-standard AIDs added in this list, but there is no guarantee that they will work.</string>
|
<string name="pref_developer_isdr_aid_list_desc">Some brands of removable eUICCs may use their own non-standard ISD-R AID, rendering them inaccessible to third-party apps. We can attempt to use non-standard AIDs added in this list, but there is no guarantee that they will work.</string>
|
||||||
<string name="pref_info">Info</string>
|
<string name="pref_info">Info</string>
|
||||||
|
|
|
@ -81,14 +81,6 @@
|
||||||
app:summary="@string/pref_developer_euicc_memory_reset_desc"
|
app:summary="@string/pref_developer_euicc_memory_reset_desc"
|
||||||
app:title="@string/pref_developer_euicc_memory_reset" />
|
app:title="@string/pref_developer_euicc_memory_reset" />
|
||||||
|
|
||||||
<ListPreference
|
|
||||||
app:iconSpaceReserved="false"
|
|
||||||
app:key="pref_developer_es10x_mss"
|
|
||||||
app:summary="@string/pref_developer_es10x_mss_desc"
|
|
||||||
app:title="@string/pref_developer_es10x_mss"
|
|
||||||
app:entries="@array/pref_developer_es10x_entry_keys"
|
|
||||||
app:entryValues="@array/pref_developer_es10x_entry_values" />
|
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
app:iconSpaceReserved="false"
|
app:iconSpaceReserved="false"
|
||||||
app:key="pref_developer_isdr_aid_list"
|
app:key="pref_developer_isdr_aid_list"
|
||||||
|
@ -104,14 +96,12 @@
|
||||||
<Preference
|
<Preference
|
||||||
app:iconSpaceReserved="false"
|
app:iconSpaceReserved="false"
|
||||||
app:title="@string/pref_info_app_version"
|
app:title="@string/pref_info_app_version"
|
||||||
app:enableCopying="true"
|
|
||||||
app:key="pref_info_app_version" />
|
app:key="pref_info_app_version" />
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
app:iconSpaceReserved="false"
|
app:iconSpaceReserved="false"
|
||||||
app:title="@string/pref_info_source_code"
|
app:title="@string/pref_info_source_code"
|
||||||
app:summary="@string/pref_info_source_code_url"
|
app:summary="@string/pref_info_source_code_url"
|
||||||
app:enableCopying="true"
|
|
||||||
app:key="pref_info_source_code">
|
app:key="pref_info_source_code">
|
||||||
<intent
|
<intent
|
||||||
android:action="android.intent.action.VIEW"
|
android:action="android.intent.action.VIEW"
|
||||||
|
|
|
@ -27,9 +27,6 @@ android {
|
||||||
}
|
}
|
||||||
|
|
||||||
buildTypes {
|
buildTypes {
|
||||||
defaultConfig {
|
|
||||||
versionNameSuffix = "-unpriv"
|
|
||||||
}
|
|
||||||
release {
|
release {
|
||||||
isMinifyEnabled = false
|
isMinifyEnabled = false
|
||||||
proguardFiles(getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro")
|
proguardFiles(getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro")
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
import com.android.build.gradle.internal.api.ApkVariantOutputImpl
|
|
||||||
import im.angry.openeuicc.build.*
|
import im.angry.openeuicc.build.*
|
||||||
|
|
||||||
plugins {
|
plugins {
|
||||||
|
@ -24,9 +23,6 @@ android {
|
||||||
}
|
}
|
||||||
|
|
||||||
buildTypes {
|
buildTypes {
|
||||||
defaultConfig {
|
|
||||||
versionNameSuffix = "-priv"
|
|
||||||
}
|
|
||||||
release {
|
release {
|
||||||
isMinifyEnabled = false
|
isMinifyEnabled = false
|
||||||
proguardFiles(getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro")
|
proguardFiles(getDefaultProguardFile("proguard-android-optimize.txt"), "proguard-rules.pro")
|
||||||
|
@ -50,62 +46,3 @@ dependencies {
|
||||||
androidTestImplementation("androidx.test.ext:junit:1.1.5")
|
androidTestImplementation("androidx.test.ext:junit:1.1.5")
|
||||||
androidTestImplementation("androidx.test.espresso:espresso-core:3.5.1")
|
androidTestImplementation("androidx.test.espresso:espresso-core:3.5.1")
|
||||||
}
|
}
|
||||||
|
|
||||||
val modulePropsTemplate = mutableMapOf(
|
|
||||||
"id" to android.defaultConfig.applicationId!!,
|
|
||||||
"name" to "OpenEUICC",
|
|
||||||
"version" to android.defaultConfig.versionName!!,
|
|
||||||
"versionCode" to "${android.defaultConfig.versionCode}",
|
|
||||||
"author" to "OpenEUICC authors",
|
|
||||||
"description" to "OpenEUICC is an open-source app that provides system-level eSIM integration."
|
|
||||||
)
|
|
||||||
|
|
||||||
val moduleCustomizeScript = project.file("magisk/customize.sh").readText()
|
|
||||||
.replace("{APK_NAME}", "OpenEUICC")
|
|
||||||
.replace("{PKG_NAME}", android.defaultConfig.applicationId!!)
|
|
||||||
|
|
||||||
val moduleUninstallScript = project.file("magisk/uninstall.sh").readText()
|
|
||||||
.replace("{PKG_NAME}", android.defaultConfig.applicationId!!)
|
|
||||||
|
|
||||||
tasks.register<MagiskModuleDirTask>("assembleDebugMagiskModuleDir") {
|
|
||||||
variant = "debug"
|
|
||||||
appName = "OpenEUICC"
|
|
||||||
permsFile = project.rootProject.file("privapp_whitelist_im.angry.openeuicc.xml")
|
|
||||||
moduleInstaller = project.file("magisk/module_installer.sh")
|
|
||||||
moduleCustomizeScriptText = moduleCustomizeScript
|
|
||||||
moduleUninstallScriptText = moduleUninstallScript
|
|
||||||
moduleProp = modulePropsTemplate.let {
|
|
||||||
it["description"] = "(debug build) ${it["description"]}"
|
|
||||||
it["versionCode"] = "${(android.applicationVariants.find { it.name == "debug" }!!.outputs.first() as ApkVariantOutputImpl).versionCodeOverride}"
|
|
||||||
it["updateJson"] = "https://openeuicc.com/magisk/magisk-debug.json"
|
|
||||||
it
|
|
||||||
}
|
|
||||||
dependsOn("assembleDebug")
|
|
||||||
}
|
|
||||||
|
|
||||||
tasks.register<Zip>("assembleDebugMagiskModule") {
|
|
||||||
dependsOn("assembleDebugMagiskModuleDir")
|
|
||||||
from((tasks.getByName("assembleDebugMagiskModuleDir") as MagiskModuleDirTask).outputDir)
|
|
||||||
archiveFileName = "magisk-debug.zip"
|
|
||||||
destinationDirectory = project.layout.buildDirectory.dir("magisk")
|
|
||||||
entryCompression = ZipEntryCompression.STORED
|
|
||||||
}
|
|
||||||
|
|
||||||
tasks.register<MagiskModuleDirTask>("assembleReleaseMagiskModuleDir") {
|
|
||||||
variant = "release"
|
|
||||||
appName = "OpenEUICC"
|
|
||||||
permsFile = project.rootProject.file("privapp_whitelist_im.angry.openeuicc.xml")
|
|
||||||
moduleInstaller = project.file("magisk/module_installer.sh")
|
|
||||||
moduleCustomizeScriptText = moduleCustomizeScript
|
|
||||||
moduleUninstallScriptText = moduleUninstallScript
|
|
||||||
moduleProp = modulePropsTemplate
|
|
||||||
dependsOn("assembleRelease")
|
|
||||||
}
|
|
||||||
|
|
||||||
tasks.register<Zip>("assembleReleaseMagiskModule") {
|
|
||||||
dependsOn("assembleReleaseMagiskModuleDir")
|
|
||||||
from((tasks.getByName("assembleReleaseMagiskModuleDir") as MagiskModuleDirTask).outputDir)
|
|
||||||
archiveFileName = "magisk-release.zip"
|
|
||||||
destinationDirectory = project.layout.buildDirectory.dir("magisk")
|
|
||||||
entryCompression = ZipEntryCompression.STORED
|
|
||||||
}
|
|
|
@ -1,9 +0,0 @@
|
||||||
TMP_FILE="$TMPDIR/{APK_NAME}"
|
|
||||||
|
|
||||||
chmod u+x "$MODPATH/uninstall.sh"
|
|
||||||
cp "$MODPATH/system/system_ext/{APK_NAME}/{APK_NAME}.apk" "$TMP_FILE"
|
|
||||||
|
|
||||||
pm install -r "$TMP_FILE"
|
|
||||||
rm -f "$TMP_FILE"
|
|
||||||
|
|
||||||
pm grant "{PKG_NAME}" android.permission.READ_PHONE_STATE
|
|
|
@ -1,33 +0,0 @@
|
||||||
#!/sbin/sh
|
|
||||||
|
|
||||||
#################
|
|
||||||
# Initialization
|
|
||||||
#################
|
|
||||||
|
|
||||||
umask 022
|
|
||||||
|
|
||||||
# echo before loading util_functions
|
|
||||||
ui_print() { echo "$1"; }
|
|
||||||
|
|
||||||
require_new_magisk() {
|
|
||||||
ui_print "*******************************"
|
|
||||||
ui_print " Please install Magisk v20.4+! "
|
|
||||||
ui_print "*******************************"
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
#########################
|
|
||||||
# Load util_functions.sh
|
|
||||||
#########################
|
|
||||||
|
|
||||||
OUTFD=$2
|
|
||||||
ZIPFILE=$3
|
|
||||||
|
|
||||||
mount /data 2>/dev/null
|
|
||||||
|
|
||||||
[ -f /data/adb/magisk/util_functions.sh ] || require_new_magisk
|
|
||||||
. /data/adb/magisk/util_functions.sh
|
|
||||||
[ $MAGISK_VER_CODE -lt 20400 ] && require_new_magisk
|
|
||||||
|
|
||||||
install_module
|
|
||||||
exit 0
|
|
|
@ -1 +0,0 @@
|
||||||
pm uninstall "{PKG_NAME}"
|
|
|
@ -2,6 +2,7 @@ package im.angry.openeuicc.core
|
||||||
|
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import android.util.Log
|
import android.util.Log
|
||||||
|
import im.angry.openeuicc.OpenEuiccApplication
|
||||||
import im.angry.openeuicc.R
|
import im.angry.openeuicc.R
|
||||||
import im.angry.openeuicc.util.*
|
import im.angry.openeuicc.util.*
|
||||||
import kotlinx.coroutines.flow.first
|
import kotlinx.coroutines.flow.first
|
||||||
|
@ -31,7 +32,7 @@ class PrivilegedEuiccChannelFactory(context: Context) : DefaultEuiccChannelFacto
|
||||||
)
|
)
|
||||||
try {
|
try {
|
||||||
return EuiccChannelImpl(
|
return EuiccChannelImpl(
|
||||||
context.getString(R.string.channel_type_telephony_manager),
|
context.getString(R.string.telephony_manager),
|
||||||
port,
|
port,
|
||||||
intrinsicChannelName = null,
|
intrinsicChannelName = null,
|
||||||
TelephonyManagerApduInterface(
|
TelephonyManagerApduInterface(
|
||||||
|
@ -42,7 +43,6 @@ class PrivilegedEuiccChannelFactory(context: Context) : DefaultEuiccChannelFacto
|
||||||
isdrAid,
|
isdrAid,
|
||||||
context.preferenceRepository.verboseLoggingFlow,
|
context.preferenceRepository.verboseLoggingFlow,
|
||||||
context.preferenceRepository.ignoreTLSCertificateFlow,
|
context.preferenceRepository.ignoreTLSCertificateFlow,
|
||||||
context.preferenceRepository.es10xMssFlow,
|
|
||||||
)
|
)
|
||||||
} catch (_: IllegalArgumentException) {
|
} catch (_: IllegalArgumentException) {
|
||||||
// Failed
|
// Failed
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<resources>
|
<resources>
|
||||||
<string name="no_euicc_priv">このデバイスで eUICC が見つかりません。\nデバイスによってはアプリのメニューからデュアル SIM を有効化する必要があります。</string>
|
<string name="no_euicc_priv">このデバイスで eUICC が見つかりません。\nデバイスによってはアプリのメニューからデュアル SIM を有効化する必要があります。</string>
|
||||||
<string name="channel_type_telephony_manager">TelephonyManager (特権)</string>
|
<string name="telephony_manager">TelephonyManager (特権)</string>
|
||||||
<string name="dsds">デュアル SIM</string>
|
<string name="dsds">デュアル SIM</string>
|
||||||
<string name="toast_dsds_switched">DSDS の状態が切り替わりました。モデムが再起動するまでお待ちください。</string>
|
<string name="toast_dsds_switched">DSDS の状態が切り替わりました。モデムが再起動するまでお待ちください。</string>
|
||||||
<string name="footer_mep">このスロットは MEP (Multiple Enabled Profiles) をサポートしています。この機能を有効化または無効化するには「スロットマッピングツール」を使用してください。</string>
|
<string name="footer_mep">このスロットは MEP (Multiple Enabled Profiles) をサポートしています。この機能を有効化または無効化するには「スロットマッピングツール」を使用してください。</string>
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
<string name="lui_desc">您的设备支持 eSIM。要连接到移动网络,请下载运营商发布的 eSIM,或插入物理 SIM 卡。</string>
|
<string name="lui_desc">您的设备支持 eSIM。要连接到移动网络,请下载运营商发布的 eSIM,或插入物理 SIM 卡。</string>
|
||||||
<string name="lui_skip">跳过</string>
|
<string name="lui_skip">跳过</string>
|
||||||
<string name="lui_download">下载 eSIM</string>
|
<string name="lui_download">下载 eSIM</string>
|
||||||
<string name="channel_type_telephony_manager">TelephonyManager (特权)</string>
|
<string name="telephony_manager">TelephonyManager (特权)</string>
|
||||||
<string name="pref_developer_telephony_manager_removable">全局使用 TelephonyManager</string>
|
<string name="pref_developer_telephony_manager_removable">全局使用 TelephonyManager</string>
|
||||||
<string name="pref_developer_telephony_manager_removable_desc">在默认情况下,可移除 eUICC 将仅使用 OMAPI。这与非特权模式 (EasyEUICC) 一致。在某些设备上 OMAPI 可能存在问题 -- 选择此选项以强制使用 TelephonyManager。</string>
|
<string name="pref_developer_telephony_manager_removable_desc">在默认情况下,可移除 eUICC 将仅使用 OMAPI。这与非特权模式 (EasyEUICC) 一致。在某些设备上 OMAPI 可能存在问题 -- 选择此选项以强制使用 TelephonyManager。</string>
|
||||||
</resources>
|
</resources>
|
|
@ -16,7 +16,7 @@
|
||||||
<string name="lui_desc">您的裝置支援 eSIM。要連線到行動網路,請下載電信業者釋出的 eSIM,或插入實體 SIM 卡。</string>
|
<string name="lui_desc">您的裝置支援 eSIM。要連線到行動網路,請下載電信業者釋出的 eSIM,或插入實體 SIM 卡。</string>
|
||||||
<string name="lui_skip">跳過</string>
|
<string name="lui_skip">跳過</string>
|
||||||
<string name="lui_download">下載 eSIM</string>
|
<string name="lui_download">下載 eSIM</string>
|
||||||
<string name="channel_type_telephony_manager">TelephonyManager (特權)</string>
|
<string name="telephony_manager">TelephonyManager (特權)</string>
|
||||||
<string name="pref_developer_telephony_manager_removable">全域使用 TelephonyManager</string>
|
<string name="pref_developer_telephony_manager_removable">全域使用 TelephonyManager</string>
|
||||||
<string name="pref_developer_telephony_manager_removable_desc">在預設情況下,可移除 eUICC 將僅使用 OMAPI。這與非特權模式 (EasyEUICC) 一致。在某些裝置上 OMAPI 可能有問題 -- 選擇此選項以強制使用 TelephonyManager。</string>
|
<string name="pref_developer_telephony_manager_removable_desc">在預設情況下,可移除 eUICC 將僅使用 OMAPI。這與非特權模式 (EasyEUICC) 一致。在某些裝置上 OMAPI 可能有問題 -- 選擇此選項以強制使用 TelephonyManager。</string>
|
||||||
</resources>
|
</resources>
|
|
@ -1,7 +1,7 @@
|
||||||
<resources>
|
<resources>
|
||||||
<string name="app_name" translatable="false">OpenEUICC</string>
|
<string name="app_name" translatable="false">OpenEUICC</string>
|
||||||
<string name="no_euicc_priv">No eUICC found on this device.\nOn some devices, you may need to enable dual SIM first in the menu of this app.</string>
|
<string name="no_euicc_priv">No eUICC found on this device.\nOn some devices, you may need to enable dual SIM first in the menu of this app.</string>
|
||||||
<string name="channel_type_telephony_manager">TelephonyManager (Privileged)</string>
|
<string name="telephony_manager">TelephonyManager (Privileged)</string>
|
||||||
|
|
||||||
<string name="dsds">Dual SIM</string>
|
<string name="dsds">Dual SIM</string>
|
||||||
|
|
||||||
|
|
|
@ -1,74 +0,0 @@
|
||||||
package im.angry.openeuicc.build
|
|
||||||
|
|
||||||
import org.gradle.api.DefaultTask
|
|
||||||
import org.gradle.api.provider.MapProperty
|
|
||||||
import org.gradle.api.provider.Property
|
|
||||||
import org.gradle.api.tasks.Input
|
|
||||||
import org.gradle.api.tasks.InputDirectory
|
|
||||||
import org.gradle.api.tasks.InputFile
|
|
||||||
import org.gradle.api.tasks.OutputDirectory
|
|
||||||
import org.gradle.api.tasks.TaskAction
|
|
||||||
import java.io.File
|
|
||||||
|
|
||||||
abstract class MagiskModuleDirTask : DefaultTask() {
|
|
||||||
@get:Input
|
|
||||||
abstract val variant : Property<String>
|
|
||||||
|
|
||||||
@get:Input
|
|
||||||
abstract val appName : Property<String>
|
|
||||||
|
|
||||||
@get:InputFile
|
|
||||||
abstract val permsFile : Property<File>
|
|
||||||
|
|
||||||
@get:InputFile
|
|
||||||
abstract val moduleInstaller : Property<File>
|
|
||||||
|
|
||||||
@get:Input
|
|
||||||
abstract val moduleCustomizeScriptText : Property<String>
|
|
||||||
|
|
||||||
@get:Input
|
|
||||||
abstract val moduleUninstallScriptText : Property<String>
|
|
||||||
|
|
||||||
@get:Input
|
|
||||||
abstract val moduleProp : MapProperty<String, String>
|
|
||||||
|
|
||||||
@InputDirectory
|
|
||||||
val inputDir = variant.map { project.layout.buildDirectory.dir("outputs/apk/${it}") }
|
|
||||||
|
|
||||||
@OutputDirectory
|
|
||||||
val outputDir = variant.map { project.layout.buildDirectory.dir("magisk/${it}") }
|
|
||||||
|
|
||||||
@TaskAction
|
|
||||||
fun build() {
|
|
||||||
val dir = outputDir.get().get()
|
|
||||||
project.mkdir(dir)
|
|
||||||
val systemExtDir = dir.dir("system/system_ext")
|
|
||||||
val permDir = dir.dir("system/system_ext/etc/permissions")
|
|
||||||
val appDir = systemExtDir.dir("priv-app/${appName.get()}")
|
|
||||||
val metaInfDir = dir.dir("META-INF/com/google/android")
|
|
||||||
project.mkdir(systemExtDir)
|
|
||||||
project.mkdir(metaInfDir)
|
|
||||||
project.mkdir(appDir)
|
|
||||||
project.mkdir(permDir)
|
|
||||||
project.copy {
|
|
||||||
into(appDir)
|
|
||||||
from(inputDir) {
|
|
||||||
include("app-${variant.get()}.apk")
|
|
||||||
rename("app-${variant.get()}.apk", "${appName.get()}.apk")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
project.copy {
|
|
||||||
from(permsFile)
|
|
||||||
into(permDir)
|
|
||||||
}
|
|
||||||
project.copy {
|
|
||||||
from(moduleInstaller)
|
|
||||||
into(metaInfDir)
|
|
||||||
rename(".*", "update-binary")
|
|
||||||
}
|
|
||||||
dir.file("customize.sh").asFile.writeText(moduleCustomizeScriptText.get())
|
|
||||||
dir.file("uninstall.sh").asFile.writeText(moduleUninstallScriptText.get())
|
|
||||||
metaInfDir.file("updater-script").asFile.writeText("# MAGISK")
|
|
||||||
dir.file("module.prop").asFile.writeText(moduleProp.get().map { (k, v) -> "$k=$v" }.joinToString("\n"))
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -16,7 +16,7 @@ val Project.gitVersionCode: Int
|
||||||
standardOutput = stdout
|
standardOutput = stdout
|
||||||
}
|
}
|
||||||
stdout.toString("utf-8").trim('\n').toInt()
|
stdout.toString("utf-8").trim('\n').toInt()
|
||||||
} catch (_: Exception) {
|
} catch (e: Exception) {
|
||||||
0
|
0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,7 +29,7 @@ val Project.gitVersionName: String
|
||||||
standardOutput = stdout
|
standardOutput = stdout
|
||||||
}
|
}
|
||||||
stdout.toString("utf-8").trim('\n')
|
stdout.toString("utf-8").trim('\n')
|
||||||
} catch (_: Exception) {
|
} catch (e: Exception) {
|
||||||
"Unknown"
|
"Unknown"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -38,7 +38,7 @@ class MyVersioningPlugin: Plugin<Project> {
|
||||||
target.configure<BaseAppModuleExtension> {
|
target.configure<BaseAppModuleExtension> {
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
versionCode = target.gitVersionCode
|
versionCode = target.gitVersionCode
|
||||||
versionName = target.gitVersionName.removePrefix("unpriv-")
|
versionName = target.gitVersionName
|
||||||
}
|
}
|
||||||
|
|
||||||
applicationVariants.all {
|
applicationVariants.all {
|
||||||
|
|
|
@ -2,4 +2,3 @@ APP_ABI := all
|
||||||
APP_SHORT_COMMANDS := true
|
APP_SHORT_COMMANDS := true
|
||||||
APP_CFLAGS := -Wno-compound-token-split-by-macro
|
APP_CFLAGS := -Wno-compound-token-split-by-macro
|
||||||
APP_LDFLAGS := -Wl,--build-id=none -z muldefs
|
APP_LDFLAGS := -Wl,--build-id=none -z muldefs
|
||||||
APP_SUPPORT_FLEXIBLE_PAGE_SIZES := true
|
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
LOCAL_PATH := $(call my-dir)
|
LOCAL_PATH := $(call my-dir)
|
||||||
LOCAL_LDFLAGS += "-Wl,-z,max-page-size=16384"
|
|
||||||
|
|
||||||
# function to find all *.c files under a directory
|
# function to find all *.c files under a directory
|
||||||
define all-c-files-under
|
define all-c-files-under
|
||||||
|
|
Loading…
Add table
Reference in a new issue