Дисковых телефонов, к сожалению, почти нигде уже нет, а вместе с ними ушла целая эпоха. Но есть в этих аппаратах что-то особенное, что привлекает как обычных людей, так и разработчиков. Что касается последних, то они используют дисковые системы для самых разных проектов, и об одном из них мы сегодня расскажем.
Речь идет о преобразовании телефона в цифрового секретаря, который всегда готов прийти на помощь. Для реализации проекта нужна плата Raspberry Pi Zero и подключение к Google Assistant. Ну а теперь подробнее о проекте.
Чтобы сразу было понятно, о чем идет речь, вот видео уже собранного телефона с активированным помощником.
Чуть подробнее о необходимых компонентах
Нам понадобится:
- Raspberry Pi Zero с запаянными пинами, карта памяти с Raspberry Pi OS и адаптер питания.
- Старый дисковый телефон с работающей трубкой (микрофоном и динамиком) и работающим рычажным переключателем, который придется кастомизировать.
- Разного рода кабели, паяльник, отвертки и прочие мелочи.
- 1 USB audio адаптер, совместимый с Linux.
- 1 male-male 3.5 мм аудио кабель.
- 1 Raspberry Pi Zero micro USB to USB A адаптер.
Как установить Google Assistant на старый телефон
Здесь несколько этапов работы:
- Регистрация в Google (самое простое).
- Аутентификация с Google (тоже несложно).
- Кастомизация телефона.
- Настройка помощника Google.
Регистрация в Google
Речь, конечно же, не о простой регистрации аккаунта в сервисах компании, а о регистрации с raspberry pi. Этот этап может быть немного сложным для тех, кто никогда не работал с Google Cloud Platform, так что лучше прочитать этот пункт, дабы не терять время. Если вы все знаете его можно и пропустить.
Клонируем репозиторий на малинку.
cd ~/
git clone
https://github.com/rydercalmdown/google_assistant_telephone
Открываем console.actions.google.com в браузере. Здесь расположен центр управления Google Assistant Actions.
Выбираем новый проект и заполняем появлющиеся поля.
В новой вкладке подтверждаем имя проекта и выбираем Enable для включения API.
Далее на первой вкладке пролистываем страничку до конца и выбираем Are you looking for device registration? Click here
Теперь нужно зарегистрировать девайс, заполнив все поля и скопировав полученный ID в отдельный файл он понадобится позже.
Выбираем Download OAuth 2.0 credentials для того, чтобы загрузить соответствующий файл, который малинка будет использовать для формирования запросов.
Переименовываем загруженный файл в oauth_config_credentials.json и передаем его на Raspberry Pi. Разместить его нужно в папку скопированного репозитория, загруженного в самом начале.
# Rename your downloaded file
cd ~/Downloads
mv your_unique_secret_file_name.json
oauth_config_credentials.json
# Move the file into your repository
scp oauth_config_credentials.json
pi@your_pis_ip_address:/home/pi/google_assistant_telephone
Возвращаемся к браузеру. После загрузки и переименования нажимаем Next и выбираем Save Traits, не изменяя настроек.
Аутентификация с Google
После того, как регистрация закончена, самое время аутенифицировать девайс для возможности доступа к аккаунту Google и персонализации помощника.
Открываем ссылку console.cloud.google.com/apis/credentials/consent и проверяем, чтобы имя проекта, заданное выше, совпадало с отображаемым по ссылке.
Выбираем External и нажимаем Create
Заполняем поле с названием, выбираем из выпадающего списка почту и добавляем этот e-mail в поле Developer contact information и сохраняем все.
На следующей странице выбираем Add or Remove Scopes и ищем в поисковой строке Google Assistant API. Выбираем /auth/assistant-sdk-prototype scope, обновляем путем нажатия на upfate и сохраняем все.
Затем выбираем OAuth Consent Screen и Add User, добавляя свою почту.
Теперь переходим в папку загруженного репозитория на Raspberry Pi и запускаем команду:
cd ~/google_assistant_telephone
make authenticate
Она завершает процесс аутентификации, после чего нужно скопировать полученный код в консоль. Если все хорошо, то появится сообщение credentials saved:
Эти данные требуются для перехода в текущую аудиторию.
# credentials saved: /Users/test/Library/Application
Support/google-oauthlib-tool/credentials.json
mv /Users/test/Library/Application\
Support/google-oauthlib-tool/credentials.json
/home/pi/google/assistant/telephone/credentials.json
Кастомизируем телефон
Конечно, модели дисковых телефонов отличаются друг от друга, но их схемы более-менее похожи, поэтому то, что показано ниже, можно использовать для всех аналогичных аппаратов.
В любом случае телефон сначала нужно разобрать.
Далее находим провода, которые идут к рычажковому переключателю. Их нужно будет подключить к пинам малинки, чтобы плата могла определять, снята трубка или нет.
Провода нужно припаять к 18 пину и к земле.
Далее подключаем USB аудио адаптер к raspberry pi zero, после чего припаиваем к проводам трубки два разных 3,5мм провода. Они будут передавать сигнал от Raspberri Pi к трубке и обратно. Возможно, придется повозиться, определяя, где какой провод, но в целом здесь нет ничего сложного.
Заканчиваем кастомизацию телефона, подключая 3,5мм провода к адаптеру.
Остается лишь закрыть корпус телефона, не забыв вывести кабель питания малинки.
Настройка помощника
Осталось совсем немного настраиваем помощника и все. Здесь тоже несколько шагов.
Запускаем установочный скрипт. Это займет не один час, если вы используете Raspberry Pi Zero. Лучше всего запустить все вечером и оставить на ночь.
cd google_assistant_telephone
make install
Настраиваем USB-аудио. Для этого нужна всего одна команда.
make configure-audio
Теперь тестируем аудиоадаптер.
# Run, speak something into the microphone, and listen
make test
# Set volumes
alsamixer
Экспортируем ID проекта. Можно просто зайти вот по этой ссылке и выбрать
Project Settings
export PROJECT_ID=your-project-id
Экспортируем ID
export
DEVICE_MODEL_ID=your-model-id-from-the-earlier-steps
Теперь выполняем команду
make run
После чего тестируем телефон. Это просто поднимаем трубку и задаем любой вопрос помощнику. Если все ок, консоль покажет определенное действие, а помощник ответит.
Наконец, выполняем команду ниже для запуска помощника.
make configure-on-boot
Больше подробностей на страничке самого проекта.