- Android open source dialer
- Пишем свой Dialer для Android и работаем со звонками на низком уровне
- Содержание статьи
- Linux для хакера
- А где у него кнопочки?
- Принимаем первый звонок
- Принимаем второй звонок
- Положи трубку!
- Липкий список Google
- Перезваниваем
- Ода манифесту
- Заключение
- www.androidpolice.com
- Follow Android Police
- Simple Dialer is a free, open-source alternative to your default phone app
Android open source dialer
Для установки программы необходимы права root пользователя или кастомное recovery.
Краткое описание:
Приложение для звонков с автозаписью вызовов на Android 11+
Описание:
Указанный Dialer изначально был частью прошивки OctaviOS. В дальнейшем, разработчик ELON (@eloncyborg) проделал большую работу для того, чтобы портировать его на другие устройства в виде пакета для TWRP Recovery и модуля для Magisk. Сама звонилка представляет собой стандартный андройдовский Dialer, но с модифицированными функциями и автоматической записью разговоров с линии на устройствах под управлением Android 11+. Работоспособность проверена и гарантирована на OneUI 3.1, MIUI 12.5, Pixel Experience 11, Evox и HavocOS. Гарантировать работу на других прошивках не представляется возможным — тестируйте. Я же на основе трудов @eloncybord сделал порт Dialer’а из прошивки CrDroid.
Установка (если у вас GAPPS версия):
1. Устанавливаем через TWRP или как модуль Magisk (управляем кнопками громкости)
2. Даем приложению ВСЕ РАЗРЕШЕНИЯ
3. Выбираем это приложение для звонков по умолчанию
Установка (если у вас VANILLA версия):
Для VANILLA версий автоустановщик не подходит , поэтому нужно делать все руками.
Требуется Android: 11 и выше
Русский интерфейс: Да
Источник
Пишем свой Dialer для Android и работаем со звонками на низком уровне
Содержание статьи
В юбилейном выпуске «Хакера» за номером 200 мы рассматривали скрытые и не очень аспекты работы с СМС. Сегодня мы продолжаем тему, обратив внимание на голосовые звонки.
Одной из самых популярных программ времен Symbian и «Нокии» был так называемый черный список звонков, позволяющий оградить тонкую натуру владельца телефона от нежелательных абонентов. И хотя сегодня подобная функциональность интегрирована в некоторые прошивки смартфонов, зачастую такие возможности сводятся лишь к банальному перманентному «бану» контакта в адресной книге. В исследовательских целях рассмотрим, как подобный механизм реализуется на практике. Будем считать, что ты давно читаешь рубрику «Кодинг», живешь в Android Studio и ругаешься исключительно на Java.
Типичный черный список
Linux для хакера
А где у него кнопочки?
Каким бы ни было приложение, официальным или негласным (только для личного пользования в целях исследования, естественно), одинаково плохо, если оно будет падать из-за отсутствия на устройстве телефонных функций (Wi-Fi-планшет). Поэтому первое, что стоит сделать, — проверить таковые:
Как видишь, мы воспользовались методом hasSystemFeature из объекта PackageManager, указав константу FEATURE_TELEPHONY в качестве параметра. Кроме того, имеет смысл дополнительно проверить поддержку GSM-модуля константой FEATURE_TELEPHONY_GSM .
Если обе константы лживы, то мы ошиблись устройством, ничего не поделаешь. В этом случае стоит завершить работу приложения, а на выходе попросить пользователя сменить девайс ;).
Принимаем первый звонок
С помощью класса PhoneStateListener в Android’е отслеживается состояние телефона, но лишь в том случае, если приложение запросило полномочие READ_PHONE_STATE в своем манифесте:
Далее необходимо переопределить и зарегистрировать метод onCallStateChanged в реализации PhoneStateListener , чтобы получать уведомления об изменении состояния телефонного вызова. Готовая реализация представлена ниже:
Когда поступает звонок, целочисленный параметр state принимает значение CALL_STATE_RINGING , что приводит к вызову нашей боевой (или мирной) нагрузки в виде функции doMagicWork .
Входящий звонок
В природе данный вариант приема телефонного звонка используется чуть реже, чем никогда. Дело в том, что в момент звонка приложение должно работать на переднем плане, — такое своеобразное использование придумать сложновато (разве только в отладочных целях), поэтому двигаемся дальше.
Принимаем второй звонок
Когда состояние телефона изменяется (например, в результате приема звонка), объект TelephonyManager начинает транслировать намерение (Intent) с действием ACTION_PHONE_STATE_CHANGED .
Намерения — межпрограммный фреймворк для обмена сообщениями. Намерения широко используются в Android для запуска/остановки активностей и сервисов, трансляции сообщений по всей системе, неявного вызова активностей, сервисов и широковещательных приемников.
Широковещательные приемники — компоненты, с помощью которых приложение может отслеживать намерения и реагировать на любые полученные действия. Приемники реализуют событийную модель взаимодействия приложений и системы. Более подробно тема создания широковещательного приемника рассмотрена в статье «Хакерский Cron на Android».
Как и в предыдущем случае, приложение должно получить разрешение READ_PHONE_STATE в манифесте:
Там же регистрируется и широковещательный приемник, способный отслеживать трансляцию намерения:
При таком подходе мы всегда можем получать информацию о входящих звонках, даже если приложение в данный момент не запущено.
Намерение, сообщающее об изменении состояния телефона, будет содержать два параметра: EXTRA_STATE_RINGING — признак входящего звонка и EXTRA_INCOMING_NUMBER — телефонный номер звонящего.
Такой подход и следует использовать на практике.
Положи трубку!
Итак, телефон весело звонит, номер входящего определен, наш широковещательный приемник сработал. Что дальше?
Если рассматривать вариант черного списка или же бота, выполняющего команды извне, то неплохо бы научиться вешать трубку, не привлекая внимания пользователя. Аппаратный стек телефона очень похож на нулевое кольцо (ring 0) в Windows, в том смысле, что тоже представляет собой низкоуровневый системный компонент. Поэтому не существует стандартного способа до него добраться (особенно если у тебя нерутованный аппарат).
Как вариант, можно попытаться использовать язык описания интерфейсов (Android Interface Definition Language, AIDL) для обеспечения межпроцессного взаимодействия между компонентами системы.
Для этого необходимо добавить в проект файл-интерфейс ITelephony.aidl следующего вида:
Следующий код подхватит интерфейс и, используя рефлексию, «положит» трубку:
Чтобы это хозяйство заработало, приложение должно получить еще одно разрешение в манифесте:
Из-за этого применить подобный способ на устройствах с Android 2.3 и выше не выйдет, так как начиная с Gingerbread данное разрешение считается системным и попытка его использовать приведет к падению приложения:
Но ведь в Google Play полно приложений, реализующих черный список! Как же они работают? Условно их можно разделить на две группы (кроме тех, кто честно юзает AIDL): фальшивки и. костыли. Первые всего лишь имитируют работу, периодически показывая в шторке статистику «заблокированных» звонков (и СМС). Взамен они требуют доступ в интернет, скачивают килотонны рекламы, которую крутят по поводу и без. Расчет здесь строится на том, что пользователь не сразу обнаружит обман и свою порцию баннеров гарантированно получит (гомеопатия в чистом виде). Такие программы вряд ли соответствуют рубрике «Кодинг», поэтому мы их пропускаем.
Приложения второй группы пытаются оборвать звонок нетривиальными способами — например, прикидываясь пользователем и нажимая кнопки:
Оригинальным, но вполне рабочим может быть метод уменьшения громкости нежелательного звонка до нуля:
Используя объект AudioManager , мы сначала получаем текущий звуковой профиль getRingerMode() , а потом устанавливаем бесшумный режим AudioManager.RINGER_MODE_SILENT .
После того как звонок прекратится (текущее состояние сменится на EXTRA_STATE_IDLE ), восстанавливаем исходный режим:
Но даже в этом случае не обойтись без специальных разрешений:
Здесь мы не блокируем номер как таковой, скорее просто не поднимаем трубку, однако такой подход не требует никаких «выкрутасов».
Встречаются приложения, которые с переменным успехом пытаются получить доступ к кнопкам на экране входящего звонка, как, например, здесь.
К рассматриваемому вопросу можно отнести задачу вывода информации поверх активности входящего звонка (как вариант — полная визуальная замена окна для маскировки), но из соображений безопасности Android не позволяет создавать собственные активности для этих целей. Тем не менее это не распространяется на системные окна. Любопытная статья по теме.
Как показывает практика, многие «хаки», неплохо функционирующие на одних устройствах, на других в лучшем случае не работают, а в худшем — рушат приложение во время входящего звонка. Соответственно, оценки подобных приложений скачут от единицы («Ничего не работает, верните деньги!») до пяти («Пользуюсь уже двадцать лет, все устраивает!»).
Так работает или нет?
На этом можно было бы поставить жирную точку, если бы внезапно «корпорация добра» не сделала ход слоном.
Липкий список Google
В Android 7.0 Nougat (API 24) появился класс BlockedNumberContract — тот самый черный список, но уже не в виде компонента прошивки смартфона, а в качестве полноценного объекта ОС. Все звонки (а также СМС и электронные письма) от отправителей из этого списка будут автоматически отклонены системой.
BlockedNumberContract представляет собой стандартный контент-провайдер, работать с которым могут, во-первых, системные приложения, во-вторых, приложения для СМС и телефонии, заданные как приложения по умолчанию (Default App). Свойство «по умолчанию» должен установить сам пользователь — это одна из парадигм безопасности Android начиная с версии 4.4. Для телефонии указанное свойство наделяет код правом не только обрабатывать входящие и исходящие звонки, но и изменять базу данных (например, удалять отдельные звонки из логов). Поэтому, кстати, стоит очень настороженно относиться к тем приложениям, даже из Google Play, которые пытаются получить флаг «по умолчанию» и при этом имеют неограниченный доступ в интернет, — вероятность слива информации весьма высока.
Более подробную информацию о приложениях «по умолчанию» можно почерпнуть из этой статьи.
Работа с BlockedNumberContract напоминает взаимодействие с базой данных: используются узнаваемые методы вставки, удаления и, разумеется, выборки записей.
Контент-провайдер — разделяемое постоянное хранилище (как правило, база данных SQLite), которое содержит информацию, относящуюся к приложению, и управляет ею. Предпочтительный способ обмена данными между различными программами.
Чтобы забанить номер телефона, вызываем стандартный метод getContentResolver().insert :
Несмотря на название, столбик COLUMN_ORIGINAL_NUMBER может содержать не только номер телефона, но и электронный адрес:
Удалить номер из бана так же просто:
Для проверки, не внесен ли номер в черный список, предусмотрен метод isBlocked(Context, String) .
Наконец, чтобы получить всех отвергнутых одним махом:
Таким образом, рассмотренные в предыдущем разделе трюки постепенно сойдут на нет. Другой вопрос, как быстро это случится. Доля Android 7 пока не превышает даже инженерной погрешности.
Фрагментация Android (март 2017 года)
Перезваниваем
Позвонить в Android’е можно двумя принципиально разными способами. Первый, и самый простой, — вызвать стандартную активность, передав ей в качестве параметра номер для набора:
Здесь используется инициирующее звонок намерение Intent.ACTION_DIAL , а номер передается в виде пути URI с обязательным указанием протокола tel. На экране смартфона пользователь увидит привычное окно с заведенным номером.
Стандартная «звонилка»
Стандартная активность для дозвона разрешает изменить номер непосредственно перед выполнением звонка, поэтому никаких разрешений в манифесте приложения не требуется.
Второй вариант — перехват намерений, которые обслуживаются стандартным приложением, и вызов своей активности. В этом случае отрисовка экранных цифровых кнопок и поиск по контактам (и это далеко не полный перечень) ложится на плечи программиста.
Кроме того, поскольку в этом случае требуется разрешение:
начиная с Android 4.4 приложение откажется работать, если оно не будет выбрано по умолчанию, а пользователь вряд ли просто так сменит знакомую «звонилку».
Skype ненавязчиво пытается стать телефоном
Как видишь, Google неплохо защитила свой телефонный компонент, и вредоносов, скрытно звонящих на короткие платные номера, в природе (пока еще?) не наблюдается.
Ода манифесту
Если ты внимательно читаешь рубрику «Кодинг», то наверняка заметил, что то или иное потенциально опасное действие в Android требует однозначного разрешения. Несмотря на имеющиеся уязвимости (когда в последний раз к тебе прилетали патчи?) в разных компонентах системы, в целом основным рассадником проблем оказывается сам пользователь. Разумеется, если ты заинтересуешь ЦРУ, никакой запрет разрешений приложений тебя не спасет, но в обычной жизни необходимо крайне настороженно относиться ко всему устанавливаемому ПО, даже если оно родом из Google Play. Как думаешь, стоит ли ставить себе калькулятор, если он требует доступа в интернет и возможности отправлять СМС?
Заключение
Сегодня мы познакомились с одним из главных компонентов современного смартфона — телефонией (хотя, возможно, у интернет-мессенджеров другое мнение на этот счет). Как обычно, не все работает так, как хотелось бы, и свет в велосипедной мастерской еще долго не погаснет, но такая уж у программистов судьба. В любом случае «Хакер» будет держать тебя в курсе.
Источник
www.androidpolice.com
Follow Android Police
Simple Dialer is a free, open-source alternative to your default phone app
No superfluous permissions for an app that makes phone calls
We’ve highlighted apps from Simple Mobile Tools before as great, open-source, data-light alternatives to the basic tools Google provides for your Android phone. Now you can notch another one into that belt as the developer has just come out with a Simple Dialer app. And it’s free.
Image Gallery (3 Images)
Simple Dialer is like canned food in that it has inside what it says on the tin. The app’s appearance is totally customizable, right down to even the app icon’s color (changes visible where phones UIs support them). You can also drop home screen shortcuts to instant calls with your closest contacts or, if you’re old-fashioned, set your speed dial.
Image Gallery (3 Images)
Unlike Google’s Phone app, Simple Dialer does not ask for permission to access and/or modify your files and media or location data. Heck, it won’t even ask for SMS privileges. It sticks to telephony, logging down calls, and contacts.
So, being much different to most canned foods, this app doesn’t leave a bad taste in your mouth. It’s also free, did we mention that? Grab it from the Play Store or APK Mirror.
Complete with a handy virtual remote
Jules joined the Android Police team in 2019. Before that, he was at Pocketnow. He loves public transportation, podcasts, and people in general. He also likes to take views from the bigger picture in technology from how people are attracted to it to how it’s utilized across every other industry.
Источник