Android Auto OS 13 dan yang lebih baru berisi fitur yang memungkinkan Anda mengonfigurasi dan mengelola jaringan Ethernet. Gambar 1 menunjukkan contoh diagram jaringan untuk mobil:
Gambar 1. Jaringan Android Auto.
Gambar ini menunjukkan aplikasi jaringan OEM Anda yang memanggil metode di class
EthernetManager
untuk mengonfigurasi dan mengelola jaringan Ethernet onboard
(eth0.1, eth0.2, dan eth0.3). Bagian lainnya dari Gambar 1 berada di luar cakupan dokumen ini.
Menetapkan setelan jaringan Ethernet default
Untuk menetapkan setelan jaringan default, gunakan
overlay resource
config_ethernet_interfaces
:
<string-array translatable="false" name="config_ethernet_interfaces">
<!--
<item>eth1;12,13,14,15;ip=192.168.0.10/24 gateway=192.168.0.1 dns=4.4.4.4,8.8.8.8</item>
<item>eth2;;ip=192.168.0.11/24</item>
<item>eth3;12,13,14,15;ip=192.168.0.12/24;1</item>
-->
</string-array>
Contoh
ini menunjukkan overlay resource config_ethernet_interfaces
dari
config.xml
.
Poin penting tentang kode
eth1
,eth2
, daneth3
adalah nama antarmuka jaringan yang sedang dikonfigurasi.- Nomor berurutan
12, 13, 14, 15
menunjukkan kemampuan jaringan yang diaktifkan. ip=
,gateway=
, dandns
digunakan untuk menyetel alamat IP, gateway, dan DNS awal untuk jaringan.
Mengaktifkan atau menonaktifkan antarmuka jaringan
Untuk mengaktifkan antarmuka jaringan, panggil
EthernetManager.enableInterface()
:
public final class InterfaceEnabler {
private final Context mApplicationContext;
private final EthernetManager mEthernetManager;
private final OutcomeReceiver<String, EthernetNetworkManagementException> mOutcomeReceiver;
public InterfaceEnabler(Context applicationContext,
OutcomeReceiver<String, EthernetNetworkManagementException> outcomeReceiver) {
mApplicationContext = applicationContext;
mEthernetManager = applicationContext.getSystemService(EthernetManager.class);
mOutcomeReceiver = outcomeReceiver;
}
public void enableInterface(String ifaceName) {
mEthernetManager.enableInterface(ifaceName,
mApplicationContext.getMainExecutor(),
mOutcomeReceiver);
}
}
Poin penting tentang kode
ifaceName
adalah nama antarmuka jaringan yang akan diaktifkan.getMainExecutor()
menampilkan konteks aplikasi.OutcomeReceiver
adalah callback yang digunakan untuk mengomunikasikan penyelesaian yang menampilkan nama jaringan yang diperbarui jika berhasil atauEthernetNetworkManagementException
jika terjadi error.
Saat antarmuka jaringan diaktifkan, antarmuka tersebut menggunakan setelan konfigurasi yang ditetapkan oleh
EthernetManager.updateConfiguration()
. Jika konfigurasi belum ditetapkan oleh EthernetManager.updateConfiguration()
, antarmuka jaringan akan menggunakan config_ethernet_interfaces
overlay resource atau konfigurasi jaringan Ethernet default jika overlay tidak tersedia.
Untuk menonaktifkan antarmuka jaringan, panggil
EthernetManager.disableInterface()
:
public final class InterfaceEnabler {
private final Context mApplicationContext;
private final EthernetManager mEthernetManager;
private final OutcomeReceiver<String, EthernetNetworkManagementException> mOutcomeReceiver;
public InterfaceEnabler(Context applicationContext,
OutcomeReceiver<String, EthernetNetworkManagementException> outcomeReceiver) {
mApplicationContext = applicationContext;
mEthernetManager = applicationContext.getSystemService(EthernetManager.class);
mOutcomeReceiver = outcomeReceiver;
}
public void disableInterface(String ifaceName) {
mEthernetManager.disableInterface(ifaceName,
mApplicationContext.getMainExecutor(),
mOutcomeReceiver);
}
}
Poin penting tentang kode
ifaceName
adalah nama antarmuka jaringan yang akan dinonaktifkan.getMainExecutor()
menampilkan konteks aplikasi.OutcomeReceiver
adalah callback yang digunakan untuk mengomunikasikan penyelesaian yang menampilkan nama jaringan yang diperbarui jika berhasil atauEthernetNetworkManagementException
jika terjadi error.
Memperbarui konfigurasi jaringan
Untuk memperbarui konfigurasi jaringan Ethernet, panggil EthernetManager.updateConfiguration()
:
public final class ConfigurationUpdater {
private final Context mApplicationContext;
private final EthernetManager mEthernetManager;
private final OutcomeReceiver<String, EthernetNetworkManagementException> mCallback;
public ConfigurationUpdater(Context applicationContext,
OutcomeReceiver<String, EthernetNetworkManagementException> callback) {
mApplicationContext = applicationContext;
mEthernetManager = applicationContext.getSystemService(EthernetManager.class);
mCallback = callback;
}
public void updateNetworkConfiguration(String packageNames,
String ipConfigurationText,
String networkCapabilitiesText,
String interfaceName)
throws IllegalArgumentException, PackageManager.NameNotFoundException {
EthernetNetworkUpdateRequest request = new EthernetNetworkUpdateRequest.Builder()
.setIpConfiguration(getIpConfiguration(ipConfigurationText))
.setNetworkCapabilities(getCapabilities(
interfaceName, networkCapabilitiesText, packageNames))
.build();
mEthernetManager.updateConfiguration(interfaceName, request,
mApplicationContext.getMainExecutor(), mCallback);
}
}
Poin penting tentang kode
getCapabilities()
adalah metode pembantu yang mendapatkan kemampuan jaringan saat ini dan memanggilconvertToUIDs()
untuk mengonversi nama paket yang mudah dibaca menjadi ID unik (UID) Linux. Biasanya, Anda tidak mengetahui UID terlebih dahulu untuk paket terkaitnya. Oleh karena itu, jika Anda ingin menggunakanEthernetManager.updateConfiguration()
untuk membatasi akses ke sebagian aplikasi, Anda harus menggunakan UID-nya.request
adalah konfigurasi yang akan digunakan untuk jaringan internal. Permintaan dapat berisi setelan baru untuk konfigurasi IP dan kemampuan jaringan. Jika jaringan terdaftar dengan stack konektivitas, jaringan tersebut akan diperbarui sesuai dengan konfigurasi. Konfigurasi ini tidak akan dipertahankan setelah perangkat dimulai ulang.getMainExecutor()
menampilkan eksekutor tempat pemroses dipanggil.mCallback
adalah callback yang digunakan untuk mengomunikasikan penyelesaian yang menampilkan nama jaringan yang diperbarui jika berhasil atauEthernetNetworkManagementException
jika terjadi error.
updateConfiguration()
dapat memperbarui karakteristik jaringan yang dianggap tidak dapat diubah oleh stack Konektivitas Android. Jaringan dimatikan, diupdate, dan diaktifkan kembali agar atribut yang tidak dapat diubah ini diupdate.
Membatasi jaringan ke subkumpulan aplikasi
Anda dapat menggunakan EthernetManager#updateConfiguration
untuk membatasi akses hanya ke subset UID yang diizinkan. Gunakan metode ini untuk mencakup kasus penggunaan yang memerlukan hal ini, seperti untuk jaringan kendaraan internal yang hanya dapat digunakan oleh sebagian kecil aplikasi OEM.
Android terutama melacak aplikasi berdasarkan UID-nya.
Kode berikut dari
UIDToPackageNameConverter.java
menunjukkan cara mendapatkan serangkaian UID dari string nama paket:
public static Set<Integer> convertToUids(Context applicationContext, String packageNames)
throws PackageManager.NameNotFoundException {
final PackageManager packageManager = applicationContext.getPackageManager();
final UserManager userManager = applicationContext.getSystemService(UserManager.class);
final Set<Integer> uids = new ArraySet<>();
final List<UserHandle> users = userManager.getUserHandles(true);
String[] packageNamesArray = packageNames.split(",");
for (String packageName : packageNamesArray) {
boolean nameNotFound = true;
packageName = packageName.trim();
for (final UserHandle user : users) {
try {
final int uid =
packageManager.getApplicationInfoAsUser(packageName, 0, user).uid;
uids.add(uid);
nameNotFound = false;
} catch (PackageManager.NameNotFoundException e) {
// Although this may seem like an error scenario, it is OK as all packages are
// not expected to be installed for all users.
continue;
}
}
if (nameNotFound) {
throw new PackageManager.NameNotFoundException("Not installed: " + packageName);
}
}
return uids;
Poin penting tentang kode
getApplicationInfoAsuser().uid
digunakan untuk mengambil UID dari nama paket.uids
adalah array bilangan bulat yang dihasilkan.
Kode berikut di
EthernetManagerTest.kt
menunjukkan cara memperbarui konfigurasi antarmuka jaringan Anda dengan UID aplikasi
yang diizinkan untuk menggunakan jaringan:
val allowedUids = setOf(Process.myUid())
val nc = NetworkCapabilities.Builder(request.networkCapabilities)
.setAllowedUids(allowedUids).build()
updateConfiguration(iface, capabilities = nc).expectResult(iface.name)
Poin penting tentang kode
allowUids
adalah kumpulan UID aplikasi yang diizinkan untuk menggunakan jaringan.updateConfiguration()
memperbarui konfigurasi untuk membatasi jaringan ke kumpulan UID yang diberikan.