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

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

    <bug>
          <bug_id>31798</bug_id>
          
          <creation_ts>2016-02-15 08:36:56 +0300</creation_ts>
          <short_desc>wireshark не работает от пользователя</short_desc>
          <delta_ts>2016-02-16 08:11:23 +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>wireshark-base</component>
          <version>unstable</version>
          <rep_platform>all</rep_platform>
          <op_sys>Linux</op_sys>
          <bug_status>CLOSED</bug_status>
          <resolution>WORKSFORME</resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords></keywords>
          <priority>P3</priority>
          <bug_severity>normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Стас">stas.grumbler</reporter>
          <assigned_to name="Anton Farygin">rider</assigned_to>
          <cc>aris</cc>
    
    <cc>evg</cc>
    
    <cc>rider</cc>
          
          <qa_contact>qa-sisyphus</qa_contact>

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>154998</commentid>
    <comment_count>0</comment_count>
    <who name="Стас">stas.grumbler</who>
    <bug_when>2016-02-15 08:36:56 +0300</bug_when>
    <thetext>Когда wireshark запущен от пользователя, нет возможности выбрать нтерфейс и включить захват пакетов. Когда запускаешь его от рута, программа предупреждает, что это неправильно.

Решение: в скрипт postinstall нужно вставить строку
setcap &apos;CAP_NET_RAW+eip CAP_NET_ADMIN+eip&apos; /usr/bin/dumpcap
Это даст программе захвата трафика нужные привилегии.

Подробности см. в документации к wireshark: https://wiki.wireshark.org/CaptureSetup/CapturePrivileges?highlight=%28permission%29 под заголовком &quot;Setting network privileges for dumpcap if your kernel and file system support file capabilities&quot;.

Ещё один момент. Параллельно имеет смысл сразу разумно настроить права доступа к файлу. На настоящий момент по умолчанию запуск программы захвата трафика доступен всем. В /etc/control.d/facilities/wireshark-capture имеется четыре варианта установки прав на бинарник /usr/bin/dumpcap:
 new_fmode public 4711 root root
 new_fmode relaxed 711 root root
 new_fmode netadmin 4710 root netadmin
 new_fmode restricted 700 root root
По умолчанию выбран вариант relaxed.

Предлагаю следующие:
 new_fmode public 711 root root
 new_fmode relaxed 710 root root
 new_fmode netadmin 710 root netadmin
 new_fmode restricted 700 root root
и выставить по умолчанию третий вариант (запуск доступен руту и группе netadmin)
Можно вовсе убрать вариант relaxed.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>154999</commentid>
    <comment_count>1</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2016-02-15 08:55:25 +0300</bug_when>
    <thetext>есть такой инструмент, просто после установки нужно выполнить донастройку системы
control wireshark-capture  (public relaxed netadmin restricted)</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>155000</commentid>
    <comment_count>2</comment_count>
    <who name="Стас">stas.grumbler</who>
    <bug_when>2016-02-15 09:03:05 +0300</bug_when>
    <thetext>Прошу прощения, я не полностью описал проблему.

Надеюсь, никто не будет спорить, что SUID/SGID - дурная практика, когда есть альтернатива. 
В случае wireshark альтернатива описана в документации - установка file capabilities программой setcap.

Касательно существующего положения, когда &quot;после установки нужно выполнить донастройку&quot;, где описана эта самая донастройка?
IMHO пакет должен работать сразу после установки либо инсталлятор должен сообщить, что необходимо сделать дополнительно.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>155003</commentid>
    <comment_count>3</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2016-02-15 11:27:02 +0300</bug_when>
    <thetext>Настройки безопасности по умолчанию после установки традиционно в ALT Linux отдаются на сторону авторов дистрибутивов.

В пакетах по умолчанию политика такова, что привелигерованные приложения устанавливаются и не работают из под рядового пользователя.

Инсталятор в нашем случае - это rpm, я могу вывести нужное сообщение в post-скрипте, но вероятность того, что его кто-то прочитает - стремится к нулю, оно потеряется на общем фоне.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>155004</commentid>
    <comment_count>4</comment_count>
    <who name="Стас">stas.grumbler</who>
    <bug_when>2016-02-15 11:42:09 +0300</bug_when>
    <thetext>&gt; В пакетах по умолчанию политика такова, что привелигерованные приложения
&gt; устанавливаются и не работают из под рядового пользователя.

Хорошо. Повторяю: давайте сделаем wireshark непривилегированным. Для этого достаточно добавить одну строку в postinstall и убрать установку бита SGID в 
скрипте /etc/control.d/facilities/wireshark-capture.

&gt; Настройки безопасности по умолчанию после установки традиционно в ALT Linux
&gt; отдаются на сторону авторов дистрибутивов.
Знают ли об обсуждаемых настройках wireshark-base авторы дистрибутива Altlinux P7 и готовящегося P8? Я этого не заметил.


В любом случае нужно как-то задокументировать особенности пакета. Например, можно добавить файл с описанием настроек безопасности в /usr/share/doc/wireshark-base-1.12.1/ALTLINUX-README  Как его назвать - вопрос открытый, я предложил так, чтобы он не терялся в множестве тамошних README.*.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>155005</commentid>
    <comment_count>5</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2016-02-15 11:47:20 +0300</bug_when>
    <thetext>Хорошо, Readme я напишу.

Насколько я помню - Wireshark не устанавливается ни в одном из дистрибутивов по умолчанию.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>155008</commentid>
    <comment_count>6</comment_count>
    <who name="Стас">stas.grumbler</who>
    <bug_when>2016-02-15 12:02:24 +0300</bug_when>
    <thetext>README - это хорошо и правильно. Умеющий читать не будет задавать дурацкие вопросы на форуме :)

Непонятно, как связаны эти две фразы (они из разных сообщений):

&gt; Настройки безопасности по умолчанию после установки традиционно в ALT Linux
&gt; отдаются на сторону авторов дистрибутивов.

&gt; Насколько я помню - Wireshark не устанавливается ни в одном из дистрибутивов по
&gt; умолчанию.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>155009</commentid>
    <comment_count>7</comment_count>
    <who name="Стас">stas.grumbler</who>
    <bug_when>2016-02-15 12:02:35 +0300</bug_when>
    <thetext>Всё же, давайте сделаем wireshark непривилегированным и отберём права на запуск. Если после первичной установки разрешён запуск только от рута и выставлены file capabilities, тогда пользователь увидит ошибку &quot;Couldn&apos;t run /usr/bin/dumpcap in child process: access denied&quot; и полезет смотреть причину.
При нынешней конфигурации нет никакой диагностики, wireshark просто не обнаруживает интерфейсы.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>155010</commentid>
    <comment_count>8</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2016-02-15 12:21:48 +0300</bug_when>
    <thetext>Я подумаю как это сделать более дистрибутивно.
Идея установки capabilities в POST-скрипте мне не нравится.

Что касается вопроса с дистрибутивами - то если автор дистрибутива сочтёт нужным включить Wireshark в установку по умолчанию - то он предусмотрит все необходимые настройки для его запуска.

При нынешней конфигурации wireshark выводит сообщение: Couldn&apos;t run /usr/bin/dumpcap in child process - отказано в доступе. Вполне понятное сообщение, если не совсем, то можем его поправить - предлагайте варианты.

У меня ровно такая конфигурация и я wireshark использую в этом режиме, для dump&apos;а есть другие инструменты и в другом месте.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>155011</commentid>
    <comment_count>9</comment_count>
    <who name="Yuri N. Sedunov">aris</who>
    <bug_when>2016-02-15 12:42:33 +0300</bug_when>
    <thetext>(В ответ на комментарий №8)
&gt; Я подумаю как это сделать более дистрибутивно.
&gt; Идея установки capabilities в POST-скрипте мне не нравится.

Самой идее  установки capabilities в POST-скрипте у нас нет альтернативы, приходится использовать.
Позаимствовав из других RPM, можно было делать это при сборке пакета как-то так
%files
...
%caps(cap_ipc_lock=ep) %_bindir/prog

А в данном случае, видимо, можно и CONTROL(8) задействовать.</thetext>
  </long_desc>
      
      

    </bug>

</bugzilla>