forked from PeterCxy/OpenEUICC
		
	
		
			
				
	
	
		
			125 lines
		
	
	
		
			No EOL
		
	
	
		
			7.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			125 lines
		
	
	
		
			No EOL
		
	
	
		
			7.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| <img src="https://gitea.angry.im/PeterCxy/OpenEUICC/media/branch/master/art/OpenEUICCBG.svg" width="512" height="300">
 | |
| 
 | |
| A fully free and open-source Local Profile Assistant implementation for Android devices.
 | |
| 
 | |
| There are two variants of this project:
 | |
| 
 | |
| - OpenEUICC: The full-fledged privileged variant.
 | |
|   - Due to its privilege requirement, OpenEUICC must be placed inside `/system/priv-app` and be signed with the platform certificate.
 | |
|   - The preferred way to including OpenEUICC in a system image is to [build it along with AOSP](#building-aosp).
 | |
|   - __Note__: When privileged, OpenEUICC supports any eUICC chip that implements the SGP.22 standard, internal or external. However, there is __no guarantee__ that external (removable) eSIMs actually follow the standard. Please __DO NOT__ submit bug reports for non-functioning removable eSIMs. They are __NOT__ officially supported unless they also support / are supported by EasyEUICC, the unprivileged variant.
 | |
| - EasyEUICC: Unprivileged version that can run as a user app.
 | |
|   - This version supports two modes of operation:
 | |
|     1. Inserted, removable eSIMs: Due to obvious security requirements, EasyEUICC is only able to access eSIM chips whose [ARF/ARA](https://source.android.com/docs/core/connect/uicc#arf) contains the hash of EasyEUICC's signing certificate.
 | |
|     2. USB CCID Card Readers: Only `T=0` readers that use the standard [USB CCID protocol](https://en.wikipedia.org/wiki/CCID_(protocol)) are supported. In this mode, EasyEUICC can access any eSIM chip loaded in the card reader regardless of their ARF/ARA, as long as they implement the [SGP.22 standard](https://www.gsma.com/solutions-and-impact/technologies/esim/wp-content/uploads/2021/07/SGP.22-v2.3.pdf).
 | |
|   - Prebuilt release-mode EasyEUICC apks can be downloaded [here](https://gitea.angry.im/PeterCxy/OpenEUICC/releases)
 | |
|   - For removable eSIM chip vendors: to have your chip supported by official builds of EasyEUICC when inserted, include the ARA-M hash `2A2FA878BC7C3354C2CF82935A5945A3EDAE4AFA`
 | |
| 
 | |
| __This project is Free Software licensed under GNU GPL v3, WITHOUT the "or later" clause.__ Any modification and derivative work __MUST__ be released under the SAME license, which means, at the very least, that the source code __MUST__ be available upon request.
 | |
| 
 | |
| __If you are releasing a modification of this app, you are kindly asked to make changes to at least the app name and package name.__  
 | |
| 
 | |
| Building (Gradle)
 | |
| ===
 | |
| 
 | |
| Make sure you have all submodules cloned and updated by running
 | |
| 
 | |
| ```shell
 | |
| git submodule update --init
 | |
| ```
 | |
| 
 | |
| A file `keystore.properties` is required in the root directory. Template:
 | |
| 
 | |
| ```ini
 | |
| storePassword=my-store-password
 | |
| keyPassword=my-password
 | |
| keyAlias=my-key
 | |
| unprivKeyPassword=my-unpriv-password
 | |
| unprivKeyAlias=my-unpriv-key
 | |
| storeFile=/path/to/android/keystore
 | |
| ```
 | |
| 
 | |
| Note that you must have a Java-compatible keystore generated first.
 | |
| 
 | |
| To build the privileged OpenEUICC:
 | |
| 
 | |
| ```shell
 | |
| ./gradlew :app:assembleRelease
 | |
| ```
 | |
| 
 | |
| For EasyEUICC:
 | |
| 
 | |
| ```shell
 | |
| ./gradlew :app-unpriv:assembleRelease
 | |
| ```
 | |
| 
 | |
| Building (AOSP)
 | |
| ===
 | |
| 
 | |
| There are two ways to include OpenEUICC in your AOSP-based system image:
 | |
| 
 | |
| 1. Include this project and its [dependencies](https://gitea.angry.im/PeterCxy/android_prebuilts_openeuicc-deps) inside the AOSP tree.
 | |
|    - If inclusion in `manifest.xml` is required, remember to set the `sync-s` option to clone submodules.
 | |
|    - The module name is `OpenEUICC`. You can include it in `PRODUCT_PACKAGES`, or simply build it standalone using `mm`.
 | |
|    - Compilation of this project is **only** tested against the latest AOSP release version. The app itself should be compatible with older AOSP versions, but the source may not compile against an older AOSP source tree.
 | |
| 2. If compilation against AOSP source tree is not possible, consider [building with gradle](#building-gradle) and import the apk as a prebuilt.
 | |
|    - No official `Android.bp` is provided for this case but it should be straightforward to write.
 | |
|    - You might want to include `privapp_whitelist_im.angry.openeuicc.xml` as well.
 | |
| 
 | |
| FAQs
 | |
| ===
 | |
| 
 | |
| - Q: Do you provide prebuilt binaries for OpenEUICC?
 | |
| - A: Debug-mode APKs are available continuously as an artifact of the [Actions](https://gitea.angry.im/PeterCxy/OpenEUICC/actions) CI used by this project. However, these debug-mode APKs are **not** intended for inclusion inside system images, nor are they supported by the developer in any sense. If you are a custom ROM developer, either include the entire OpenEUICC repository in your AOSP source tree, or generate an APK using `gradle` and import that as a prebuilt system app. Note that you might want `privapp_whitelist_im.angry.openeuicc.xml` as well.
 | |
| 
 | |
| - Q: AOSP's Settings app seems to be confused by OpenEUICC (for example, disabling / enabling profiles from the Networks page do not work properly)
 | |
| - A: When your device has internal eSIM chip(s) __and__ you have inserted a removable eSIM chip, the Settings app can misbehave since it was never designed for this scenario. __Please prefer using OpenEUICC's own management interface whenever possible.__ In the future, there might be an option to exclude removable SIMs from being reported to the Android system.
 | |
| 
 | |
| - Q: Can EasyEUICC manage my phone's internal eSIM?
 | |
| - A: No. For EasyEUICC to work, the eSIM chip MUST proactively grant access via its ARA-M field.
 | |
| 
 | |
| - Q: Removable eSIMs? Are they a joke?
 | |
| - A: No, even though the name "removable embedded SIM" can sound like an oxymoron. In fact, there can be many advantages to these chips compared to fully embedded ones. For example, the ability to transfer eSIM profiles without carrier support or approval, or the ability to use eSIM on devices that do not and may never get the support, such as Wi-Fi hotspots.
 | |
| 
 | |
| Copyright
 | |
| ===
 | |
| 
 | |
| Everything except `libs/lpac-jni` and `art/`:
 | |
| 
 | |
| ```
 | |
| Copyright 2022-2024 OpenEUICC contributors
 | |
| 
 | |
| This program is free software; you can redistribute it and/or
 | |
| modify it under the terms of the GNU General Public License
 | |
| as published by the Free Software Foundation, version 3.
 | |
| 
 | |
| This program is distributed in the hope that it will be useful,
 | |
| but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
| GNU General Public License for more details.
 | |
| 
 | |
| You should have received a copy of the GNU General Public License
 | |
| along with this program; if not, write to the Free Software
 | |
| Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 | |
| ```
 | |
| 
 | |
| `libs/lpac-jni`:
 | |
| 
 | |
| ```
 | |
| Copyright (C) 2022-2024 OpenEUICC contributiors
 | |
| 
 | |
| This library is free software; you can redistribute it and/or
 | |
| modify it under the terms of the GNU Lesser General Public
 | |
| License as published by the Free Software Foundation, version 2.1.
 | |
| 
 | |
| This library is distributed in the hope that it will be useful,
 | |
| but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
| Lesser General Public License for more details.
 | |
| 
 | |
| You should have received a copy of the GNU Lesser General Public
 | |
| License along with this library; if not, write to the Free Software
 | |
| Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 | |
| ```
 | |
| 
 | |
| `art/`: Courtesy of [Aikoyori](https://github.com/Aikoyori), CC NC-SA 4.0. |