<?xml version="1.0" encoding="UTF-8" ?>

<bugzilla version="5.2"
          urlbase="https://bugzilla.altlinux.org/"
          
          maintainer="jenya@basealt.ru"
>

    <bug>
          <bug_id>38948</bug_id>
          
          <creation_ts>2020-09-16 13:38:59 +0300</creation_ts>
          <short_desc>Не показывает запрос пароля LUKS</short_desc>
          <delta_ts>2020-10-07 13:52:12 +0300</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>4</classification_id>
          <classification>Development</classification>
          <product>Sisyphus</product>
          <component>make-initrd-luks</component>
          <version>unstable</version>
          <rep_platform>x86_64</rep_platform>
          <op_sys>Linux</op_sys>
          <bug_status>CLOSED</bug_status>
          <resolution>FIXED</resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords></keywords>
          <priority>P5</priority>
          <bug_severity>normal</bug_severity>
          <target_milestone>---</target_milestone>
          <dependson>34634</dependson>
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Олег Соловьев">mcpain</reporter>
          <assigned_to name="Alexey Gladkov">legion</assigned_to>
          <cc>aen</cc>
    
    <cc>antohami</cc>
    
    <cc>darktemplaralt</cc>
    
    <cc>glebfm</cc>
    
    <cc>ldv</cc>
    
    <cc>legion</cc>
    
    <cc>nbr</cc>
    
    <cc>placeholder</cc>
    
    <cc>shaba</cc>
    
    <cc>vt</cc>
          
          <qa_contact>qa-sisyphus</qa_contact>

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>192552</commentid>
    <comment_count>0</comment_count>
    <who name="Олег Соловьев">mcpain</who>
    <bug_when>2020-09-16 13:38:59 +0300</bug_when>
    <thetext>Разбивка диска:
Единственный шифруемый раздел на весь диск, отданный под корень.

Если после установки добавить FEATURES += plymouth в /etc/initrd.mk и включить тему branding-xalt-kworkstation, то запрос на ввод пароля не показывается пользователю.

В Fedora ситуация обрабатывается корректно и запрос пароля виден пользователю на экране загрузки.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>192564</commentid>
    <comment_count>1</comment_count>
    <who name="Alexey Shabalin">shaba</who>
    <bug_when>2020-09-16 20:01:31 +0300</bug_when>
    <thetext>Но при чем тут plymouth? Он просто показывает картинку.
Это все происходит в initrd, значит initrd должен корректно эту ситуацию обрабатывать.
В systemd есть специальные утилиты systemd-tty-ask-password-agent (/sbin/systemd-tty-ask-password-agent --watch --plymouth) которые умеют работать с plymouth, но в нашем initrd они не используются. В fedora используются и эти утилиты и systemd внутри initrd, поэтому у них все работает.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>192570</commentid>
    <comment_count>2</comment_count>
    <who name="Alexey Gladkov">legion</who>
    <bug_when>2020-09-17 00:18:05 +0300</bug_when>
    <thetext>Очень печальное будущее у этой фичи, если для правильной работы plymouth нужен systemd и его утилиты.

Судя по всему фича уже давно сломана.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>192580</commentid>
    <comment_count>3</comment_count>
    <who name="Aleksei Nikiforov">darktemplaralt</who>
    <bug_when>2020-09-17 10:21:21 +0300</bug_when>
    <thetext>Насколько мне известно, в plymouth есть вызов &quot;plymouth ask-for-password&quot;, который можно использовать для ввода пароля через plymouth и передачи его куда-либо ещё, например в cryptsetup. Возможно есть и другие вызовы. О зависимостях таких вызовов на systemd мне ничего не известно, т.е. предположительно такой зависимости нет.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>192583</commentid>
    <comment_count>4</comment_count>
    <who name="Олег Соловьев">mcpain</who>
    <bug_when>2020-09-17 10:44:47 +0300</bug_when>
    <thetext>Пока что я смог выяснить, что plymouth корректно обрабатывает нажатия клавиш и заполняет буфер тем, что надо. При нажатии Enter показывает соответствующее сообщение (с plymouth.debug)

Но в cryptsetup оно не передается и прилетает в него почему-то пустой пароль.

В Ubuntu cryptsetup работает через FIFO, в Fedora, я так понимаю, тоже.
Но пока не могу найти конкретное место, плюс оно работает через какую-то обёртку. Как оно работает - ещё не разобрался.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>192584</commentid>
    <comment_count>5</comment_count>
    <who name="Олег Соловьев">mcpain</who>
    <bug_when>2020-09-17 10:45:59 +0300</bug_when>
    <thetext>PS мы обсуждаем ошибку 38949</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>192588</commentid>
    <comment_count>6</comment_count>
    <who name="Олег Соловьев">mcpain</who>
    <bug_when>2020-09-17 11:54:20 +0300</bug_when>
    <thetext>В Fedora используется systemd-cryptsetup, который через libcryptsetup занимается разблокировкой дисков.

Насколько я понял, сначала отрабатывают правила udev, которые для каждого luks запускают генератор юнитов, в каждом запускается свой systemd-cryptsetup, а он через libcryptsetup занимается расшифровкой.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>193096</commentid>
    <comment_count>7</comment_count>
    <who name="Alexey Gladkov">legion</who>
    <bug_when>2020-10-07 13:52:12 +0300</bug_when>
    <thetext>Должно быть исправлено в 2.11.0.</thetext>
  </long_desc>
      
      

    </bug>

</bugzilla>