O Android 12 agora permite que administradores de TI desativem a sinalização de dados por USB em dispositivos da empresa (exceto para a função de carregamento). Para oferecer suporte a isso, os OEMs precisarão atualizar a HAL de USB e usar a compatibilidade adicional com o Google Apps Device Policy. Manager.
Device Policy Manager
Para oferecer suporte à desativação da sinalização por USB, as três APIs públicas a seguir estão incluídas no
DevicePolicyManager
:
- A
setUsbDataSignalingEnabled(boolean enabled)
é uma API que ativa ou desativa a sinalização de dados USB chamando o APIenableUsbDataSignal
emUsbManager
. canUsbDataSignalingBeDisabled()
é uma API que verifica se a ativação ou desativação da sinalização de dados USB é compatível com o dispositivo.isUsbDataSignalingEnabled()
é uma API que verifica se a sinalização de dados USB foi ativada.- É necessário para verificar se há uma caixa de diálogo de transparência da política é exibida. Os usuários do sistema podem chamar uma variante oculta para essa API específica que pode ser chamado pelo usuário do sistema para verificar se o sinal de dados USB foi ativado de um usuário específico.
- Toque em Configurações.
- Toque em Dispositivos conectados.
- Toque em USB.
Exemplo de implementação do Device Policy Manager
Confira a seguir um exemplo de como implementar o Gerenciador de políticas de dispositivo.class android.app.admin.DevicePolicyManager { /** * Called by device owner or profile owner of an organization-owned managed profile to * enable or disable USB data signaling for the device. When disabled, USB data connections * (except from charging functions) are prohibited. * * <p> This API is not supported on all devices, the caller should call * {@link #canUsbDataSignalingBeDisabled()} to check whether enabling or disabling USB data * signaling is supported on the device. * * @param enabled whether USB data signaling should be enabled or not. * @throws SecurityException if the caller is not a device owner or a profile owner on * an organization-owned managed profile. * @throws IllegalStateException if disabling USB data signaling is not supported or * if USB data signaling fails to be enabled/disabled. */ public void setUsbDataSignalingEnabled(boolean enabled);
/** * Called by device owner or profile owner of an organization-owned managed profile to return * whether USB data signaling is currently enabled by the admin. * * @return {@code true} if USB data signaling is enabled, {@code false} otherwise. */ public boolean isUsbDataSignalingEnabled();
/** * Called by the system to check whether USB data signaling is currently enabled for this user. * * @param userId which user to check for. * @return {@code true} if USB data signaling is enabled, {@code false} otherwise. * @hide */ public boolean isUsbDataSignalingEnabledForUser(@UserIdInt int userId);
/** * Returns whether enabling or disabling USB data signaling is supported on the device. * * @return {@code true} if the device supports enabling and disabling USB data signaling. */ public boolean canUsbDataSignalingBeDisabled();
Configurações
Os usuários podem modificar as configurações de preferência de USB e de tethering assim que o USB é conectados. Para acessar a tela de preferências do USB, faça o seguinte:
Observação: se o USB não estiver conectado, as preferências USB não poderão ser modificadas e não vão aparecer na janela "Dispositivos conectados".
Se um administrador de TI desativar a sinalização de dados USB em um dispositivo corporativo, o usuário não poderá modificar as preferências de USB. Em vez disso, todas as preferências de USB As configurações estão totalmente desativadas, o que criará uma política da caixa de diálogo de transparência.
Observação: se a sinalização de dados USB estiver desativada, a depuração USB, as configurações padrão do USB e as preferências de roteamento de áudio USB serão desativadas nas opções para desenvolvedores.