Add wireshark

This commit is contained in:
Andrey Rodionov 2023-06-17 15:56:05 +03:00
parent afb8d3aab4
commit dbc8b4e255
3 changed files with 108 additions and 0 deletions

99
wireshark/PKGBUILD Normal file
View file

@ -0,0 +1,99 @@
# Maintainer: Levente Polyak <anthraxx[at]archlinux[dot]org>
# Maintainer: Filipe Laíns <lains@archlinux.org>
# Contributor: Timothy Redaelli <timothy.redaelli@gmail.com>
# Contributor: Guillaume ALAUX <guillaume@archlinux.org>
# Contributor: Florian Pritz <bluewind at jabber dot ccc dot de>
# Contributor: Peter Wu <peter@lekensteyn.nl>
pkgbase=wireshark
pkgname=('wireshark-cli' 'wireshark-qt')
pkgver=4.0.6
pkgrel=1
pkgdesc='Network traffic and protocol analyzer/sniffer'
url='https://www.wireshark.org/'
arch=('x86_64')
license=('GPL2')
makedepends=('glibc' 'cmake' 'ninja' 'c-ares' 'libmaxminddb' 'qt6-tools' 'qt6-svg'
'qt6-multimedia' 'krb5' 'libpcap' 'libssh' 'libxml2' 'libnghttp2'
'snappy' 'lz4' 'spandsp' 'gnutls' 'lua52' 'python' 'libcap' 'libnl'
'glib2' 'libgcrypt' 'sbc' 'bcg729' 'desktop-file-utils' 'libxslt'
'hicolor-icon-theme' 'zstd' 'zlib' 'gcc-libs' 'brotli' 'asciidoctor'
'doxygen' 'minizip' 'speexdsp' 'opus' 'flex')
options=('!emptydirs')
source=(https://www.wireshark.org/download/src/${pkgbase}-${pkgver}.tar.xz
wireshark.sysusers)
sha512sums=('SKIP'
'3956c1226e64f0ce4df463f80b55b15eed06ecd9b8703b3e8309d4236a6e1ca84e43007336f3987bc862d8a5e7cfcaaf6653125d2a34999a0f1357c52e7c4990')
b2sums=('SKIP'
'3cebcc993f51eaf0e09673c77e0436598593ef5eff306d880415ccc8eecb32fee93c9a6986f1a7bb0835ab7f9732369d7c5a07e6c053d6293e73a1ea84c58a5c')
build() {
cd ${pkgbase}-${pkgver}
cmake \
-B build \
-G Ninja \
-DVCSVERSION_OVERRIDE="Git v${pkgver} packaged as ${pkgver}-${pkgrel}" \
-DCMAKE_BUILD_TYPE=None \
-DCMAKE_INSTALL_PREFIX=/usr \
-DCMAKE_INSTALL_LIBDIR=lib \
-DCMAKE_INSTALL_RPATH= \
-DCMAKE_SKIP_RPATH=ON \
-DUSE_qt6=ON \
-Wno-dev
ninja -C build -v
}
package_wireshark-cli() {
pkgdesc+=' - CLI tools and data files'
depends=('glibc' 'c-ares' 'libmaxminddb' 'krb5' 'libgcrypt' 'libcap' 'libpcap'
'gnutls' 'glib2' 'lua52' 'libssh' 'libxml2' 'libnghttp2' 'snappy'
'lz4' 'spandsp' 'sbc' 'bcg729' 'zstd' 'zlib' 'brotli' 'speexdsp'
'opus' libpcap.so libcap.so libbrotlidec.so libcares.so libkrb5.so
libk5crypto.so)
install=wireshark.install
conflicts=(wireshark)
provides=(libwireshark.so libwiretap.so libwsutil.so)
cd ${pkgbase}-${pkgver}
DESTDIR="${pkgdir}" ninja -C build install
# wireshark uid group is 150
install -Dm 644 "${srcdir}"/wireshark.sysusers "${pkgdir}"/usr/lib/sysusers.d/wireshark.conf
chgrp 150 "${pkgdir}"/usr/bin/dumpcap
chmod 754 "${pkgdir}"/usr/bin/dumpcap
cd "${pkgdir}"
rm -r usr/share/mime \
usr/share/icons \
usr/share/man/man1/wireshark.1 \
usr/bin/wireshark \
usr/share/applications/org.wireshark.Wireshark.desktop \
usr/share/metainfo/org.wireshark.Wireshark.metainfo.xml
}
package_wireshark-qt() {
pkgdesc+=' - Qt GUI'
depends=('glibc' 'desktop-file-utils' 'qt6-multimedia' 'qt6-svg'
'wireshark-cli' 'libwireshark.so' 'libwiretap.so' 'libwsutil.so'
'shared-mime-info' 'hicolor-icon-theme' 'xdg-utils' 'gcc-libs'
'zlib' 'libpcap' 'libgcrypt' 'libnl' 'minizip' 'speexdsp'
libpcap.so)
replaces=(wireshark wireshark-gtk wireshark-common)
conflicts=(wireshark wireshark-gtk wireshark-common)
cd ${pkgbase}-${pkgver}
install -d "${srcdir}/staging"
DESTDIR="${srcdir}/staging" ninja -C build install
install -Dm 755 build/run/wireshark -t "${pkgdir}"/usr/bin
install -Dm 644 build/doc/wireshark.1 -t "${pkgdir}"/usr/share/man/man1
install -Dm 644 build/doc/wireshark.html -t "${pkgdir}"/usr/share/doc/wireshark
cd "${srcdir}"/staging/usr/share
install -Dm 644 applications/org.wireshark.Wireshark.desktop -t "${pkgdir}"/usr/share/applications
install -Dm 644 mime/packages/org.wireshark.Wireshark.xml -t "${pkgdir}"/usr/share/mime/packages
install -Dm 644 metainfo/org.wireshark.Wireshark.metainfo.xml -t "${pkgdir}"/usr/share/metainfo
mv icons "${pkgdir}"/usr/share/icons
}
# vim: ts=2 sw=2 et:

View file

@ -0,0 +1,8 @@
post_install() {
post_upgrade
echo "NOTE: To run wireshark as normal user you have to add yourself into wireshark group"
}
post_upgrade() {
setcap cap_net_raw,cap_net_admin,cap_dac_override+eip usr/bin/dumpcap
}

View file

@ -0,0 +1 @@
g wireshark 150 - -