From e4ba6dbc3f1e76890b22773807ea37fe8fa2b1bc Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Wed, 10 Apr 2024 22:34:10 +0200 Subject: Adding upstream version 4.2.2. Signed-off-by: Daniel Baumann --- packaging/macosx/ChmodBPF/install-distribution.xml | 25 + .../macosx/ChmodBPF/install-scripts/postinstall | 35 + .../Wireshark/ChmodBPF/ChmodBPF | 41 + .../LaunchDaemons/org.wireshark.ChmodBPF.plist | 14 + .../macosx/ChmodBPF/uninstall-distribution.xml | 25 + .../macosx/ChmodBPF/uninstall-scripts/postinstall | 26 + .../macosx/Donate_to_the_Wireshark_Foundation.adoc | 15 + packaging/macosx/Logray.icns | Bin 0 -> 161519 bytes packaging/macosx/LograyInfo.plist.in | 71 + packaging/macosx/Logray_dsym_installation.adoc | 17 + packaging/macosx/Logray_read_me_first.adoc | 34 + packaging/macosx/Wireshark.icns | Bin 0 -> 1031753 bytes packaging/macosx/WiresharkInfo.plist.in | 276 ++++ packaging/macosx/Wireshark_dsym_installation.adoc | 17 + packaging/macosx/Wireshark_read_me_first.adoc | 70 + packaging/macosx/Wiresharkdoc.icns | Bin 0 -> 81772 bytes packaging/macosx/dmg_background.png | Bin 0 -> 1410 bytes packaging/macosx/dmg_background.svg | 1394 ++++++++++++++++++++ packaging/macosx/entitlements.plist | 8 + packaging/macosx/logray-app.dmgbuild.in | 146 ++ packaging/macosx/logray-dsym.dmgbuild.in | 139 ++ packaging/macosx/lriconvol.icns | Bin 0 -> 71576 bytes packaging/macosx/lriconvol.svg | 113 ++ packaging/macosx/osx-app.sh.in | 717 ++++++++++ packaging/macosx/osx-dmg.sh.in | 108 ++ packaging/macosx/osx-extras.sh | 86 ++ .../macosx/path_helper/install-distribution.xml | 24 + .../path_helper/root/etc/manpaths.d/Wireshark | 1 + .../macosx/path_helper/root/etc/paths.d/Wireshark | 1 + .../macosx/path_helper/uninstall-distribution.xml | 24 + .../path_helper/uninstall-scripts/postinstall | 11 + packaging/macosx/wireshark-app.dmgbuild.in | 170 +++ packaging/macosx/wireshark-dsym.dmgbuild.in | 139 ++ packaging/macosx/wsiconvol.icns | Bin 0 -> 21096 bytes packaging/macosx/wsiconvol.svg | 106 ++ 35 files changed, 3853 insertions(+) create mode 100644 packaging/macosx/ChmodBPF/install-distribution.xml create mode 100755 packaging/macosx/ChmodBPF/install-scripts/postinstall create mode 100755 packaging/macosx/ChmodBPF/root/Library/Application Support/Wireshark/ChmodBPF/ChmodBPF create mode 100644 packaging/macosx/ChmodBPF/root/Library/LaunchDaemons/org.wireshark.ChmodBPF.plist create mode 100644 packaging/macosx/ChmodBPF/uninstall-distribution.xml create mode 100755 packaging/macosx/ChmodBPF/uninstall-scripts/postinstall create mode 100644 packaging/macosx/Donate_to_the_Wireshark_Foundation.adoc create mode 100644 packaging/macosx/Logray.icns create mode 100644 packaging/macosx/LograyInfo.plist.in create mode 100644 packaging/macosx/Logray_dsym_installation.adoc create mode 100644 packaging/macosx/Logray_read_me_first.adoc create mode 100644 packaging/macosx/Wireshark.icns create mode 100644 packaging/macosx/WiresharkInfo.plist.in create mode 100644 packaging/macosx/Wireshark_dsym_installation.adoc create mode 100644 packaging/macosx/Wireshark_read_me_first.adoc create mode 100644 packaging/macosx/Wiresharkdoc.icns create mode 100644 packaging/macosx/dmg_background.png create mode 100644 packaging/macosx/dmg_background.svg create mode 100644 packaging/macosx/entitlements.plist create mode 100644 packaging/macosx/logray-app.dmgbuild.in create mode 100644 packaging/macosx/logray-dsym.dmgbuild.in create mode 100644 packaging/macosx/lriconvol.icns create mode 100644 packaging/macosx/lriconvol.svg create mode 100755 packaging/macosx/osx-app.sh.in create mode 100755 packaging/macosx/osx-dmg.sh.in create mode 100755 packaging/macosx/osx-extras.sh create mode 100644 packaging/macosx/path_helper/install-distribution.xml create mode 100644 packaging/macosx/path_helper/root/etc/manpaths.d/Wireshark create mode 100644 packaging/macosx/path_helper/root/etc/paths.d/Wireshark create mode 100644 packaging/macosx/path_helper/uninstall-distribution.xml create mode 100755 packaging/macosx/path_helper/uninstall-scripts/postinstall create mode 100644 packaging/macosx/wireshark-app.dmgbuild.in create mode 100644 packaging/macosx/wireshark-dsym.dmgbuild.in create mode 100644 packaging/macosx/wsiconvol.icns create mode 100644 packaging/macosx/wsiconvol.svg (limited to 'packaging/macosx') diff --git a/packaging/macosx/ChmodBPF/install-distribution.xml b/packaging/macosx/ChmodBPF/install-distribution.xml new file mode 100644 index 00000000..fbd6fd91 --- /dev/null +++ b/packaging/macosx/ChmodBPF/install-distribution.xml @@ -0,0 +1,25 @@ + + + + ChmodBPF +
+

This package will install the ChmodBPF launch daemon, create the access_bpf group, and add you to that group.

]]>
+ + + + + + + + + + + + + install.ChmodBPF.pkg +
diff --git a/packaging/macosx/ChmodBPF/install-scripts/postinstall b/packaging/macosx/ChmodBPF/install-scripts/postinstall new file mode 100755 index 00000000..1f11eb3e --- /dev/null +++ b/packaging/macosx/ChmodBPF/install-scripts/postinstall @@ -0,0 +1,35 @@ +#!/bin/sh + +# +# Fix up ownership and permissions on /Library/Application Support/Wireshark; +# for some reason, it's not being owned by root:wheel, and it's not +# publicly readable and, for directories and executables, not publicly +# searchable/executable. +# +# Also take away group write permission. +# +# XXX - that may be a problem with the process of building the installer +# package; if so, that's where it *should* be fixed. +# +chown -R root:wheel "/Library/Application Support/Wireshark" +chmod -R a+rX,go-w "/Library/Application Support/Wireshark" + +CHMOD_BPF_PLIST="/Library/LaunchDaemons/org.wireshark.ChmodBPF.plist" +BPF_GROUP="access_bpf" +BPF_GROUP_NAME="BPF device access ACL" +min_gid=100 + +if ! dscl . -read /Groups/"$BPF_GROUP" > /dev/null 2>&1; then + free_gid=$(dscl . -list /Groups PrimaryGroupID | sort -bnk2 | awk -v min_gid=$min_gid 'BEGIN{i=min_gid}{if($2==i)i++}END{print i}') + dseditgroup -q -o create -i $free_gid -r "$BPF_GROUP_NAME" "$BPF_GROUP" +fi + +dseditgroup -q -o edit -a "$USER" -t user "$BPF_GROUP" + +chmod u=rw,g=r,o=r "$CHMOD_BPF_PLIST" +chown root:wheel "$CHMOD_BPF_PLIST" + +# Clean up our legacy startup item if it's still around. +rm -rf /Library/StartupItems/ChmodBPF + +launchctl bootstrap system "$CHMOD_BPF_PLIST" diff --git a/packaging/macosx/ChmodBPF/root/Library/Application Support/Wireshark/ChmodBPF/ChmodBPF b/packaging/macosx/ChmodBPF/root/Library/Application Support/Wireshark/ChmodBPF/ChmodBPF new file mode 100755 index 00000000..1dc12e7a --- /dev/null +++ b/packaging/macosx/ChmodBPF/root/Library/Application Support/Wireshark/ChmodBPF/ChmodBPF @@ -0,0 +1,41 @@ +#! /bin/zsh +# shellcheck shell=bash + +# +# Unfortunately, macOS's devfs is based on the old FreeBSD +# one, not the current one, so there's no way to configure it +# to create BPF devices with particular owners or groups. BPF +# devices on macOS are also non-cloning, that is they can +# be created on demand at any time. This startup item will +# pre-create a number of BPF devices, then make them owned by +# the access_bpf group, with permissions rw-rw----, so that +# anybody in the access_bpf group can use programs that capture +# or send raw packets. +# +# Change this as appropriate for your site, e.g. to make +# it owned by a particular user without changing the permissions, +# so only that user and the super-user can capture or send raw +# packets, or give it the permissions rw-r-----, so that +# only the super-user can send raw packets but anybody in the +# admin group can capture packets. +# + +# Pre-create BPF devices. Set to 0 to disable. +FORCE_CREATE_BPF_MAX=256 + +SYSCTL_MAX=$( sysctl -n debug.bpf_maxdevices ) +if [ "$FORCE_CREATE_BPF_MAX" -gt "$SYSCTL_MAX" ] ; then + FORCE_CREATE_BPF_MAX=$SYSCTL_MAX +fi + +syslog -s -l notice "ChmodBPF: Forcing creation and setting permissions for /dev/bpf0-$(( FORCE_CREATE_BPF_MAX - 1))" + +CUR_DEV=0 +while [ "$CUR_DEV" -lt "$FORCE_CREATE_BPF_MAX" ] ; do + # Try to do the minimum necessary to trigger the next device. + read -r -n 0 < /dev/bpf$CUR_DEV > /dev/null 2>&1 + CUR_DEV=$(( CUR_DEV + 1 )) +done + +chgrp access_bpf /dev/bpf* +chmod g+rw /dev/bpf* diff --git a/packaging/macosx/ChmodBPF/root/Library/LaunchDaemons/org.wireshark.ChmodBPF.plist b/packaging/macosx/ChmodBPF/root/Library/LaunchDaemons/org.wireshark.ChmodBPF.plist new file mode 100644 index 00000000..1b3317e3 --- /dev/null +++ b/packaging/macosx/ChmodBPF/root/Library/LaunchDaemons/org.wireshark.ChmodBPF.plist @@ -0,0 +1,14 @@ + + + + + Label + org.wireshark.ChmodBPF + RunAtLoad + + Program + /Library/Application Support/Wireshark/ChmodBPF/ChmodBPF + AssociatedBundleIdentifiers + org.wireshark.Wireshark + + diff --git a/packaging/macosx/ChmodBPF/uninstall-distribution.xml b/packaging/macosx/ChmodBPF/uninstall-distribution.xml new file mode 100644 index 00000000..001f6e14 --- /dev/null +++ b/packaging/macosx/ChmodBPF/uninstall-distribution.xml @@ -0,0 +1,25 @@ + + + + Uninstall ChmodBPF +
+

This package will uninstall the ChmodBPF launch daemon and remove the access_bpf group.

]]>
+ + + + + + + + + + + + + uninstall.ChmodBPF.pkg +
diff --git a/packaging/macosx/ChmodBPF/uninstall-scripts/postinstall b/packaging/macosx/ChmodBPF/uninstall-scripts/postinstall new file mode 100755 index 00000000..93a33b4c --- /dev/null +++ b/packaging/macosx/ChmodBPF/uninstall-scripts/postinstall @@ -0,0 +1,26 @@ +#!/bin/sh + +# +# Remove the following: +# - The ChmmodBPF launch daemon +# - The ChmmodBPF script +# - The access_bpf group +# + +CHMOD_BPF_PLIST="/Library/LaunchDaemons/org.wireshark.ChmodBPF.plist" +BPF_GROUP="access_bpf" + +launchctl bootout system "$CHMOD_BPF_PLIST" + +dscl . -read /Groups/"$BPF_GROUP" > /dev/null 2>&1 && \ + dseditgroup -q -o delete "$BPF_GROUP" + +rm -rf "/Library/Application Support/Wireshark" + +rm -f "$CHMOD_BPF_PLIST" + +# ChmodBPF hasn't been a startup item since 2018 (ac4f3c0f4d). +rm -rf /Library/StartupItems/ChmodBPF + +# https://gitlab.com/wireshark/wireshark/-/issues/18734 +pkgutil --forget org.wireshark.ChmodBPF.pkg diff --git a/packaging/macosx/Donate_to_the_Wireshark_Foundation.adoc b/packaging/macosx/Donate_to_the_Wireshark_Foundation.adoc new file mode 100644 index 00000000..3c461d5d --- /dev/null +++ b/packaging/macosx/Donate_to_the_Wireshark_Foundation.adoc @@ -0,0 +1,15 @@ +// Required attributes: +// include-dir + +include::{include-dir}/attributes.adoc[] +:stylesheet: {include-dir}/ws.css + +== The Wireshark Founation + +The https://wiresharkfoundation.org/[Wireshark Foundation] is a non-profit organization helping as many people as possible understand their networks as much as possible. +As time goes on, more and more of our daily life happens using software, and that software relies on network connectivity. +By hosting educational conferences, the Wireshark Foundation provides industry professionals and students with the knowledge and understanding required to ensure that the networks and systems we depend on are reliable, fast, and secure. + +The Wireshark Foundation fosters open source development and explores new ways of educating the public. + +You can learn more and donate at https://wiresharkfoundation.org/[wiresharkfoundation.org]. diff --git a/packaging/macosx/Logray.icns b/packaging/macosx/Logray.icns new file mode 100644 index 00000000..68949c3a Binary files /dev/null and b/packaging/macosx/Logray.icns differ diff --git a/packaging/macosx/LograyInfo.plist.in b/packaging/macosx/LograyInfo.plist.in new file mode 100644 index 00000000..1074f1a2 --- /dev/null +++ b/packaging/macosx/LograyInfo.plist.in @@ -0,0 +1,71 @@ + + + + + CFBundleDevelopmentRegion + English + CFBundleExecutable + Logray + CFBundleGetInfoString + @LOG_PROJECT_VERSION@, Copyright 1998-2024 Wireshark Development Team + CFBundleIconFile + Logray.icns + CFBundleIdentifier + org.wireshark.Logray + CFBundleDocumentTypes + + + CFBundleTypeExtensions + + scap + scap.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + Sysdig capture + CFBundleTypeRole + Viewer + + + + CFBundleInfoDictionaryVersion + 6.0 + CFBundlePackageType + APPL + CFBundleShortVersionString + @LOG_PROJECT_VERSION@ + CFBundleSignature + Lgry + CFBundleVersion + @LOG_PROJECT_VERSION@ + NSHumanReadableCopyright + Copyright 1998-2024 Wireshark Developers, GNU General Public License. + NSPrincipalClass + NSApplication + NSHighResolutionCapable + + + NSRequiresAquaSystemAppearance + + LSMinimumSystemVersion + @MIN_MACOS_VERSION@ + + + SUFeedURL + https://www.wireshark.org/update/0/Logray/@LOG_PROJECT_MAJOR_VERSION@.@LOG_PROJECT_MINOR_VERSION@.@PROJECT_PATCH_VERSION@/macOS/x86-64/en-US/stable.xml + SUEnableAutomaticChecks + + SUPublicEDKey + BeSuPpEZOmOzkON9QMnfIdwyi06P/LcVoik8M5O2bsQ= + SUEnableSystemProfiling + + + SUAutomaticallyUpdate + + + + diff --git a/packaging/macosx/Logray_dsym_installation.adoc b/packaging/macosx/Logray_dsym_installation.adoc new file mode 100644 index 00000000..6ca4f2f8 --- /dev/null +++ b/packaging/macosx/Logray_dsym_installation.adoc @@ -0,0 +1,17 @@ +// Required attributes: +// include-dir + +include::{include-dir}/attributes.adoc[] +:stylesheet: {include-dir}/ws.css + +== Debugging Symbols for Logray + +This archive contains the debugging symbols for Logray {logray-version}. +The debugging symbols are only necessary if Logray is crashing and you need to report an issue to the Logray development team. + +WARNING: This won't work properly with any version other than Logray {logray-version}. + +To install the symbols, drag _Logray.dSYM_ to the same location as _Logray_. +This is usually your _Applications_ folder. + +To uninstall, drag _Logray.dSYM_ to the trash. diff --git a/packaging/macosx/Logray_read_me_first.adoc b/packaging/macosx/Logray_read_me_first.adoc new file mode 100644 index 00000000..498b039e --- /dev/null +++ b/packaging/macosx/Logray_read_me_first.adoc @@ -0,0 +1,34 @@ +// Required attributes: +// include-dir +// min-macos-version + +include::{include-dir}/attributes.adoc[] +:stylesheet: {include-dir}/ws.css + +== Before You Begin + +This release of Logray requires macOS {min-macos-version} or later. +If you are running an earlier version of macOS you can install using another packaging system such as Homebrew or MacPorts. + +== Quick Setup + +To install Logray, drag the _Logray_ application bundle to the _Applications_ folder. + +//// +If you would like to add the path to +https://www.wireshark.org/docs/man-pages/wireshark.html[Logray], +https://www.wireshark.org/docs/man-pages/tshark.html[TShark], +https://www.wireshark.org/docs/man-pages/capinfos.html[capinfos], +https://www.wireshark.org/docs/man-pages/editcap.html[editcap], +and +https://www.wireshark.org/docs/man-pages/[other command line utilities] +to the system PATH, install the +link:Logray.app/Contents/Resources/Extras/Add%20Wireshark%20to%20the%20system%20path.pkg[Add Logray to the system path] +package. +//// + +== Uninstalling + +To uninstall Logray, do the following: + +. Remove _/Applications/Logray.app_ diff --git a/packaging/macosx/Wireshark.icns b/packaging/macosx/Wireshark.icns new file mode 100644 index 00000000..21dcd6c0 Binary files /dev/null and b/packaging/macosx/Wireshark.icns differ diff --git a/packaging/macosx/WiresharkInfo.plist.in b/packaging/macosx/WiresharkInfo.plist.in new file mode 100644 index 00000000..64ae6119 --- /dev/null +++ b/packaging/macosx/WiresharkInfo.plist.in @@ -0,0 +1,276 @@ + + + + + CFBundleDevelopmentRegion + English + CFBundleExecutable + Wireshark + CFBundleGetInfoString + @PROJECT_VERSION@, Copyright 1998-2024 Wireshark Development Team + CFBundleIconFile + Wireshark.icns + CFBundleIdentifier + org.wireshark.Wireshark + CFBundleDocumentTypes + + + CFBundleTypeExtensions + + 5vw + 5vw.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + InfoVista/Accellent 5View Packet Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + apc + pkt + tpc + wpz + apc.gz + pkt.gz + tpc.gz + wpz.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + LiveAction/Savvius/WildPackets *Peek Packet Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + bfr + bfr.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + Viavi/Network Instruments Observer Packet Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + erf + erf.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + Endace ERF Packet Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + ipfix + ipfix.gz + + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + IPFIX Packet Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + mplog + mplog.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + Micropross mplog Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + pcap + pcap.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeMIMETypes + + application/vnd.tcpdump.pcap + + CFBundleTypeName + Pcap Network Capture + CFBundleTypeOSTypes + + PCAP + + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + pcapng + ntar + pcapng.gz + ntar.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + Pcapng Network Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + pklg + pklg.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + macOS PacketLogger Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + rf5 + rf5.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + Tektronix K12 Packet Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + snoop + snoop.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + Solaris snoop Packet Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + tr1 + tr1.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + Novell LANalyzer Packet Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + trc0 + trc0.gz + trc1 + trc1.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + HP-UX nettl Packet Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + vwr + vwr.gz + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + Ixia IxVeriWave Packet Capture + CFBundleTypeRole + Viewer + + + CFBundleTypeExtensions + + rtp + rtp.gz + rtp.zst + rtp.lz4 + + CFBundleTypeIconFile + Wiresharkdoc.icns + CFBundleTypeName + RTP stream (RTPDump) + CFBundleTypeRole + Viewer + + + + CFBundleInfoDictionaryVersion + 6.0 + CFBundlePackageType + APPL + CFBundleShortVersionString + @PROJECT_VERSION@ + CFBundleSignature + Wshk + CFBundleVersion + @PROJECT_VERSION@ + NSHumanReadableCopyright + Copyright 1998-2024 Wireshark Developers, GNU General Public License. + NSPrincipalClass + NSApplication + NSHighResolutionCapable + + + NSRequiresAquaSystemAppearance + + LSMinimumSystemVersion + @MIN_MACOS_VERSION@ + + + SUFeedURL + https://www.wireshark.org/update/0/Wireshark/@PROJECT_MAJOR_VERSION@.@PROJECT_MINOR_VERSION@.@PROJECT_PATCH_VERSION@/macOS/x86-64/en-US/stable.xml + SUEnableAutomaticChecks + + SUPublicEDKey + BeSuPpEZOmOzkON9QMnfIdwyi06P/LcVoik8M5O2bsQ= + SUEnableSystemProfiling + + + SUAutomaticallyUpdate + + + + diff --git a/packaging/macosx/Wireshark_dsym_installation.adoc b/packaging/macosx/Wireshark_dsym_installation.adoc new file mode 100644 index 00000000..a7c1b99e --- /dev/null +++ b/packaging/macosx/Wireshark_dsym_installation.adoc @@ -0,0 +1,17 @@ +// Required attributes: +// include-dir + +include::{include-dir}/attributes.adoc[] +:stylesheet: {include-dir}/ws.css + +== Debugging Symbols for Wireshark + +This archive contains the debugging symbols for Wireshark {wireshark-version}. +The debugging symbols are only necessary if Wireshark is crashing and you need to report an issue to the Wireshark development team. + +WARNING: This won't work properly with any version other than Wireshark {wireshark-version}. + +To install the symbols, drag _Wireshark.dSYM_ to the same location as _Wireshark_. +This is usually your _Applications_ folder. + +To uninstall, drag _Wireshark.dSYM_ to the trash. diff --git a/packaging/macosx/Wireshark_read_me_first.adoc b/packaging/macosx/Wireshark_read_me_first.adoc new file mode 100644 index 00000000..1f6073de --- /dev/null +++ b/packaging/macosx/Wireshark_read_me_first.adoc @@ -0,0 +1,70 @@ +// Required attributes: +// include-dir +// min-macos-version + +include::{include-dir}/attributes.adoc[] +:stylesheet: {include-dir}/ws.css + +== Before You Begin + +This release of Wireshark requires macOS {min-macos-version} or later. +If you are running an earlier version of macOS you can install using another packaging system such as Homebrew or MacPorts. + +== Quick Setup + +To install Wireshark, drag the _Wireshark_ application bundle to the _Applications_ folder. + +In order to be able to capture packets, install the +link:Wireshark.app/Contents/Resources/Extras/Install%20ChmodBPF.pkg[Install ChmodBPF] +package. + +If you would like to add the path to +https://www.wireshark.org/docs/man-pages/wireshark.html[Wireshark], +https://www.wireshark.org/docs/man-pages/tshark.html[TShark], +https://www.wireshark.org/docs/man-pages/capinfos.html[capinfos], +https://www.wireshark.org/docs/man-pages/editcap.html[editcap], +and +https://www.wireshark.org/docs/man-pages/[other command line utilities] +to the system PATH, install the +link:Wireshark.app/Contents/Resources/Extras/Add%20Wireshark%20to%20the%20system%20path.pkg[Add Wireshark to the system path] +package. + +== Package Installation Details + +The ChmodBPF installer writes to the following locations: + +* _/Library/LaunchDaemons/org.wireshark.ChmodBPF.plist_. A launch daemon that adjusts permissions on the system's packet capture devices (/dev/bpf*) when the system starts up. +* _/Library/Application Support/Wireshark/ChmodBPF_. A copy of the launch daemon property list, and the script that the launch daemon runs. + +The installer group named “access_bpf” is created. The user who opened the package is added to the group. + +The system path installer writes to the following locations: + +* _/etc/paths.d/Wireshark_. The folder name in this file is automatically added to PATH +* _/etc/manpaths.d/Wireshark_. The folder name in this file is used by the man command. + +It assumes that Wireshark is installed in _/Applications_. + +== Uninstalling + +To uninstall Wireshark, do the following: + +. Remove _/Applications/Wireshark.app_ +. Remove _/Library/Application Support/Wireshark_ + +You can uninstall ChmodBPF via the +link:Wireshark.app/Contents/Resources/Extras/Uninstall%20ChmodBPF.pkg[Uninstall ChmodBPF] +package, which is available on this disk or via menu:Wireshark[About Wireshark,Folders,macOS Extras]. +You can also uninstall it manually by doing the following: + +. Unload the “org.wireshark.ChmodBPF.plist” launchd job +. Remove _/Library/LaunchDaemons/org.wireshark.ChmodBPF.plist_ +. Remove the “access_bpf” group. + +You can uninstall the system path components via the +link:Wireshark.app/Contents/Resources/Extras/Remove%20Wireshark%20from%20the%20system%20path.pkg[Remove Wireshark from the system path] +package, which is available on this disk or via menu:Wireshark[About Wireshark,Folders,macOS Extras]. +You can also uninstall it manually by doing the following: + +. Remove _/etc/paths.d/Wireshark_ +. Remove _/etc/manpaths.d/Wireshark_ diff --git a/packaging/macosx/Wiresharkdoc.icns b/packaging/macosx/Wiresharkdoc.icns new file mode 100644 index 00000000..fb660029 Binary files /dev/null and b/packaging/macosx/Wiresharkdoc.icns differ diff --git a/packaging/macosx/dmg_background.png b/packaging/macosx/dmg_background.png new file mode 100644 index 00000000..10502b6c Binary files /dev/null and b/packaging/macosx/dmg_background.png differ diff --git a/packaging/macosx/dmg_background.svg b/packaging/macosx/dmg_background.svg new file mode 100644 index 00000000..2588f018 --- /dev/null +++ b/packaging/macosx/dmg_background.svg @@ -0,0 +1,1394 @@ + + + +image/svg+xml>>> diff --git a/packaging/macosx/entitlements.plist b/packaging/macosx/entitlements.plist new file mode 100644 index 00000000..62a55450 --- /dev/null +++ b/packaging/macosx/entitlements.plist @@ -0,0 +1,8 @@ + + + + + com.apple.security.cs.disable-library-validation + + + diff --git a/packaging/macosx/logray-app.dmgbuild.in b/packaging/macosx/logray-app.dmgbuild.in new file mode 100644 index 00000000..a7d83600 --- /dev/null +++ b/packaging/macosx/logray-app.dmgbuild.in @@ -0,0 +1,146 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +import os.path + +# +# Example settings file for dmgbuild +# +# Adapted from https://raw.githubusercontent.com/al45tair/dmgbuild/master/examples/settings.py + +# Use like this: dmgbuild -s settings.py "Test Volume" test.dmg + +# You can actually use this file for your own application (not just TextEdit) +# by doing e.g. +# +# dmgbuild -s settings.py -D app=/path/to/My.app "My Application" MyApp.dmg + +# .. Useful stuff .............................................................. + +lr_version = '@LOG_PROJECT_VERSION@' +lr_volname = 'Logray ' + lr_version +lr_srcdir = '@CMAKE_SOURCE_DIR@' +lr_bindir = '@CMAKE_BINARY_DIR@' +lr_app = 'Logray.app' +lr_readme = 'Read me first.html' +lr_install_chmodbpf = 'Install ChmodBPF.pkg' +lr_uninstall_chmodbpf = 'Uninstall ChmodBPF.pkg' +lr_install_path_helper = 'Add Logray to the system path.pkg' +lr_uninstall_path_helper = 'Remove Logray from the system path.pkg' + +# .. Basics .................................................................... + +# Uncomment to override the output filename +# filename = lr_volname + ' Intel 64.dmg' + +# Uncomment to override the output volume name +# volume_name = 'Logray ' + lr_version + +# From the hdiutil man page: +# UDZO - UDIF zlib-compressed image +# UDBZ - UDIF bzip2-compressed image (Mac OS X 10.4+ only) +# ULFO - UDIF lzfse-compressed image (OS X 10.11+ only) +# ULMO - UDIF lzma-compressed image (macOS 10.15+ only) +# Volume format (see hdiutil create -help) + +# https://developer.apple.com/forums/thread/128166 +# currently (Jan 2023) says to use UDZO +format = defines.get('format', 'UDZO') + +# Compression level (if relevant) +compression_level = 9 + +# Volume size +size = None + +# Files to include +files = [ + os.path.join(lr_bindir, 'run', lr_app), + os.path.join(lr_bindir, 'packaging', 'macosx', 'logray', lr_readme), +] + +# Symlinks to create +symlinks = { + 'Applications': '/Applications', + } + +# Volume icon +# +# You can either define icon, in which case that icon file will be copied to the +# image, *or* you can define badge_icon, in which case the icon file you specify +# will be used to badge the system's Removable Disk icon +# +badge_icon = os.path.join(lr_srcdir, 'packaging', 'macosx', 'lriconvol.icns') +#badge_icon = icon_from_app(application) + +# Where to put the icons +icon_locations = { + lr_app: ( 80, 64), + 'Applications': (240, 64), + lr_readme: (160, 170), + lr_install_chmodbpf: ( 80, 276), + lr_uninstall_chmodbpf: (250, 276), + lr_install_path_helper: ( 80, 382), + lr_uninstall_path_helper: (250, 382), + } + +# .. Window configuration ...................................................... + +# Background +# +# This is a STRING containing any of the following: +# +# #3344ff - web-style RGB color +# #34f - web-style RGB color, short form (#34f == #3344ff) +# rgb(1,0,0) - RGB color, each value is between 0 and 1 +# hsl(120,1,.5) - HSL (hue saturation lightness) color +# hwb(300,0,0) - HWB (hue whiteness blackness) color +# cmyk(0,1,0,0) - CMYK color +# goldenrod - X11/SVG named color +# builtin-arrow - A simple built-in background with a blue arrow +# /foo/bar/baz.png - The path to an image file +# +# The hue component in hsl() and hwb() may include a unit; it defaults to +# degrees ('deg'), but also supports radians ('rad') and gradians ('grad' +# or 'gon'). +# +# Other color components may be expressed either in the range 0 to 1, or +# as percentages (e.g. 60% is equivalent to 0.6). +background = os.path.join(lr_srcdir, 'packaging', 'macosx', 'dmg_background.png') + +show_status_bar = False +show_tab_view = False +show_toolbar = False +show_pathbar = False +show_sidebar = False +sidebar_width = 180 + +# Window position in ((x, y), (w, h)) format +window_rect = ((600, 200), (350, 525)) + +# Select the default view; must be one of +# +# 'icon-view' +# 'list-view' +# 'column-view' +# 'coverflow' +# +default_view = 'icon-view' + +# General view configuration +show_icon_preview = False + +# Set these to True to force inclusion of icon/list view settings (otherwise +# we only include settings for the default view) +include_icon_view_settings = 'auto' +include_list_view_settings = 'auto' + +# .. Icon view configuration ................................................... + +arrange_by = None +grid_offset = (0, 0) +#grid_spacing = 100 +scroll_position = (0, 0) +#label_pos = 'bottom' # or 'right' +text_size = 12 +icon_size = 72 diff --git a/packaging/macosx/logray-dsym.dmgbuild.in b/packaging/macosx/logray-dsym.dmgbuild.in new file mode 100644 index 00000000..f57950bb --- /dev/null +++ b/packaging/macosx/logray-dsym.dmgbuild.in @@ -0,0 +1,139 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +import os.path + +# +# Example settings file for dmgbuild +# +# Adapted from https://raw.githubusercontent.com/al45tair/dmgbuild/master/examples/settings.py + +# Use like this: dmgbuild -s settings.py "Test Volume" test.dmg + +# You can actually use this file for your own application (not just TextEdit) +# by doing e.g. +# +# dmgbuild -s settings.py -D app=/path/to/My.app "My Application" MyApp.dmg + +# .. Useful stuff .............................................................. + +lw_version = '@LOG_PROJECT_VERSION@' +lw_volname = 'Logray Debugging Symbols' + lw_version +lw_srcdir = '@CMAKE_SOURCE_DIR@' +lw_bindir = '@CMAKE_BINARY_DIR@' +lw_app_dsym = 'Logray.dSYM' +lw_readme_dsym = 'Debugging symbols installation.html' + +# .. Basics .................................................................... + +# Uncomment to override the output filename +# filename = lw_volname + ' Intel 64.dmg' + +# Uncomment to override the output volume name +# volume_name = 'Logray ' + lw_version + +# From the hdiutil man page: +# UDZO - UDIF zlib-compressed image +# UDBZ - UDIF bzip2-compressed image (Mac OS X 10.4+ only) +# ULFO - UDIF lzfse-compressed image (OS X 10.11+ only) +# ULMO - UDIF lzma-compressed image (macOS 10.15+ only) +# Volume format (see hdiutil create -help) + +# dSYMs are huge, so compress them with UDBZ despite what +# https://developer.apple.com/forums/thread/128166 +# currently (Jan 2023) says. +format = defines.get('format', 'UDBZ') + +# Compression level (if relevant) +compression_level = 9 + +# Volume size +size = None + +# Files to include +files = [ + os.path.join(lw_bindir, 'run', lw_app_dsym), + os.path.join(lw_bindir, 'packaging', 'macosx', 'logray', lw_readme_dsym), +] + +# Symlinks to create +symlinks = { + 'Applications': '/Applications', + } + +# Volume icon +# +# You can either define icon, in which case that icon file will be copied to the +# image, *or* you can define badge_icon, in which case the icon file you specify +# will be used to badge the system's Removable Disk icon +# +badge_icon = os.path.join(lw_srcdir, 'packaging', 'macosx', 'lriconvol.icns') +#badge_icon = icon_from_app(application) + +# Where to put the icons +icon_locations = { + lw_app_dsym: ( 80, 64), + 'Applications': (240, 64), + lw_readme_dsym: (160, 170), + } + +# .. Window configuration ...................................................... + +# Background +# +# This is a STRING containing any of the following: +# +# #3344ff - web-style RGB color +# #34f - web-style RGB color, short form (#34f == #3344ff) +# rgb(1,0,0) - RGB color, each value is between 0 and 1 +# hsl(120,1,.5) - HSL (hue saturation lightness) color +# hwb(300,0,0) - HWB (hue whiteness blackness) color +# cmyk(0,1,0,0) - CMYK color +# goldenrod - X11/SVG named color +# builtin-arrow - A simple built-in background with a blue arrow +# /foo/bar/baz.png - The path to an image file +# +# The hue component in hsl() and hwb() may include a unit; it defaults to +# degrees ('deg'), but also supports radians ('rad') and gradians ('grad' +# or 'gon'). +# +# Other color components may be expressed either in the range 0 to 1, or +# as percentages (e.g. 60% is equivalent to 0.6). +background = os.path.join(lw_srcdir, 'packaging', 'macosx', 'dmg_background.png') + +show_status_bar = False +show_tab_view = False +show_toolbar = False +show_pathbar = False +show_sidebar = False +sidebar_width = 180 + +# Window position in ((x, y), (w, h)) format +window_rect = ((600, 200), (350, 325)) + +# Select the default view; must be one of +# +# 'icon-view' +# 'list-view' +# 'column-view' +# 'coverflow' +# +default_view = 'icon-view' + +# General view configuration +show_icon_preview = False + +# Set these to True to force inclusion of icon/list view settings (otherwise +# we only include settings for the default view) +include_icon_view_settings = 'auto' +include_list_view_settings = 'auto' + +# .. Icon view configuration ................................................... + +arrange_by = None +grid_offset = (0, 0) +#grid_spacing = 100 +scroll_position = (0, 0) +#label_pos = 'bottom' # or 'right' +text_size = 12 +icon_size = 72 diff --git a/packaging/macosx/lriconvol.icns b/packaging/macosx/lriconvol.icns new file mode 100644 index 00000000..80282496 Binary files /dev/null and b/packaging/macosx/lriconvol.icns differ diff --git a/packaging/macosx/lriconvol.svg b/packaging/macosx/lriconvol.svg new file mode 100644 index 00000000..c25a8c82 --- /dev/null +++ b/packaging/macosx/lriconvol.svg @@ -0,0 +1,113 @@ + +image/svg+xml + + + + + + + + diff --git a/packaging/macosx/osx-app.sh.in b/packaging/macosx/osx-app.sh.in new file mode 100755 index 00000000..0bd0b932 --- /dev/null +++ b/packaging/macosx/osx-app.sh.in @@ -0,0 +1,717 @@ +#!/bin/bash +# +# USAGE +# osx-app [-s] [-l /path/to/libraries] +# +# This script attempts to build an application bundle for macOS, resolving +# dynamic libraries, etc. +# It strips the executable and libraries if '-s' is given. +# +# AUTHORS +# Kees Cook +# Michael Wybrow +# Jean-Olivier Irisson +# +# Copyright (C) 2005 Kees Cook +# Copyright (C) 2005-2007 Michael Wybrow +# Copyright (C) 2007 Jean-Olivier Irisson +# +# Released under GNU GPL, read the file 'COPYING' for more information +# +# Thanks to GNUnet's "build_app" script for help with library dep resolution. +# https://gnunet.org/svn/GNUnet/contrib/OSX/build_app +# +# NB: +# This originally came from Inkscape; Inkscape's configure script has an +# "--enable-osxapp", which causes some of Inkscape's installation data +# files to have macOS-ish paths under Contents/Resources of the bundle +# or under /Library/Application Support. We don't have such an option; +# we just put them in "bin", "etc", "lib", and "share" directories +# under Contents/Resources, rather than in the "bin", "etc", "lib", +# and "share" directories under the installation directory. +# + +# XXX We could probably replace a lot of this with https://github.com/auriamg/macdylibbundler + +shopt -s extglob + +# Defaults +strip=false +install_exclude_prefixes="/System/|/Library/|/usr/lib/|/usr/X11/|/opt/X11/|@executable_path" + +# Bundle always has the same name. Version information is stored in +# the Info.plist file which is filled in by the configure script. +bundle="Wireshark.app" + +# Location for libraries (tools/macos-setup.sh defaults to whatever the +# various support libraries use as their standard installation location, +# which is /usr/local) +if [ -z "$LIBPREFIX" ]; then + LIBPREFIX="/usr/local" +fi + + +# Help message +#---------------------------------------------------------- +help() +{ +echo -e " +Create an app bundle for macOS + +USAGE + $0 [-s] [-l /path/to/libraries] + +OPTIONS + -h,--help + Display this help message. + -b,--bundle + The application bundle name. Default is Wireshark.app. + -s + Strip the libraries and executables from debugging symbols. + -l,--libraries + Specify the path to the libraries the application depends + on (typically /sw or /opt/local). By default it is + /usr/local. + +EXAMPLE + $0 -b Logray.app -s -l /opt/local +" +} + + +# Parse command line arguments +#---------------------------------------------------------- +while [ "$1" != "" ] +do + case $1 in + -b|--bundle) + bundle="$2" + shift 1 ;; + -s) + strip=true ;; + -l|--libraries) + LIBPREFIX="$2" + shift 1 ;; + -h|--help) + help + exit 0 ;; + *) + echo "Invalid command line option: $1" + exit 2 ;; + esac + shift 1 +done + +# Safety tests +if [ ! -e "$LIBPREFIX" ]; then + echo "Cannot find the directory containing the libraries: $LIBPREFIX" >&2 + exit 1 +fi + +if [ ! -d "$bundle" ] ; then + echo "$bundle not found" >&2 + exit 1 +fi + +qt_frameworks_dir=$( "@QT_QMAKE_EXECUTABLE@" -query QT_INSTALL_LIBS ) +if [ ! -d "$qt_frameworks_dir" ] ; then + echo "Can't find the Qt frameworks directory" >&2 + exit 1 +fi + +sparkle_version="@SPARKLE_VERSION@" +sparkle_frameworks_dir="@SPARKLE_LIBRARY@" + +# +# Define the signing identities, or use self-signed ("-") +# if the identity is not provided. +if [ -n "$CODE_SIGN_IDENTITY" ] ; then + codesign_dev_app_identity="Developer ID Application: $CODE_SIGN_IDENTITY" + codesign_dev_install_identity="Developer ID Installer: $CODE_SIGN_IDENTITY" +else + codesign_dev_app_identity="-" + codesign_dev_install_identity="-" +fi + +# +# Leave the Qt frameworks out of the special processing. +# +install_exclude_prefixes="$install_exclude_prefixes|$qt_frameworks_dir" + +app_name=${bundle%%.app} +app_lower=$(echo "$app_name" | tr '[:upper:]' '[:lower:]') + +# Package paths +pkgexec="$bundle/Contents/MacOS" +#pkgres="$bundle/Contents/Resources" +pkglib="$bundle/Contents/Frameworks" +pkgplugin="$bundle/Contents/PlugIns/$app_lower/@PLUGIN_PATH_ID@" + +# Set the 'macosx' directory, usually the current directory. +#resdir=$( pwd ) + +# +# Get a list of all binaries in the bundle. +# Treat all plain files with read and execute permissions for all as +# binaries. +# +secondary_binary_list=() +while read -r binary ; do + secondary_binary_list+=("$binary") +done < <( find "$pkgexec" \! -name "$app_name" -type f -perm -0555 -print | sort ) +plugin_library_list=() +while read -r library ; do + plugin_library_list+=("$library") +done < <( find "$pkgplugin" -name "*.so" -type f -perm -0555 -print | sort ) +bundle_binary_list=("$pkgexec/$app_name" "${secondary_binary_list[@]}" "${plugin_library_list[@]}") + +echo -e "\\nFixing up $bundle..." + +# Start with a clean Frameworks slate. +if [ -d "$pkglib" ] ; then + printf "Removing %s\n" "$pkglib" + rm -v -r -f "$pkglib" +fi +mkdir -v -m u=rwx,go=rx "$pkglib" + +echo -e "\\nPrepopulating our libraries" + +# Copy only ..dylib. +cp -v +([^.]).+([[:digit:]]).dylib "$pkglib" + +# Fetch a unique list of LC_RPATHs from our executables, which will be used +# for our dependency search below. +bundle_binary_rpaths=("/usr/local/lib") +rpaths=() + +# macdeployqt handles our Qt dependencies. We handle our Sparkle and +# internal dependencies. +skip_pats="Qt|Sparkle|build/run" + +for binary in "${bundle_binary_list[@]}" "$pkglib"/*.dylib ; do + while read -r rpath ; do + bundle_binary_rpaths+=("$rpath") + done < <( otool -l "$binary" | grep -A2 LC_RPATH | awk '$1=="path" && $2 !~ /^@/ {print $2}' | grep -E -v "$skip_pats" ) +done + +while read -r rpath ; do + rpaths+=("$rpath") +done < <( printf '%s\n' "${bundle_binary_rpaths[@]}" | sort -u) + +printf "\nSearching the following LC_RPATHs for dependencies:\n" +printf '%s\n' "${rpaths[@]}" + +# Find out libs we need from Fink, MacPorts, or from a custom install +# (i.e. $LIBPREFIX), then loop until no changes. +a=1 +nfiles=0 +endl=true +while $endl; do + echo -e "\\nLooking for dependencies. Round $a" + # + # To find dependencies, we: + # + # run otool -L on all the binaries in the bundle, and on all + # the shared libraries in the $pkglib directory, to find all + # the libraries they depend on (we don't bother with the + # frameworks, as the only frameworks we ship are the Qt + # frameworks, which don't depend on any libraries that + # don't ship with the OS, and as it's hard to find the + # framework libraries under $pkglib without getting + # non-framework files); + # + # filter out all lines that don't contain "compatibility" to + # remove lines of output that don't correspond to dependencies; + # + # use cut to extract the library name from the output; + + # replace "\tlibbrotli" with "\t/usr/local/lib/libbrotli" so that + # it isn't excluded from subsequent filtering. + # libbrotli 1.09 and earlier doesn't have a path prefix in its + # "install name" when built by tools/macos-setup.sh: + # https://github.com/google/brotli/pull/976; + # + # replace "@loader_path/libbrotli" with "/usr/local/lib/libbrotli" so that + # it isn't excluded from subsequent filtering; + # + # strip out system libraries, as we don't bundle them with + # Wireshark; + # + # eliminate duplicates. + # + # We might want to let dyld do some of the work for us, e.g. by + # parsing the output of + # + # `DYLD_PRINT_LIBRARIES=1 $bundle_binary` + # + # instead, or just use CMake's fixup_bundle: + # https://cmake.org/cmake/help/latest/module/BundleUtilities.html + libs=() + while read -r lib ; do + libs+=("$lib") + done < <( + otool -L "${bundle_binary_list[@]}" "$pkglib"/*.dylib 2>/dev/null \ + | grep -F compatibility \ + | grep -v @rpath \ + | cut -d\( -f1 \ + | sed '1,$s;^ libbrotli; /usr/local/lib/libbrotli;' \ + | sed '1,$s;^ @loader_path/libbrotli; /usr/local/lib/libbrotli;' \ + | grep -E -v "$install_exclude_prefixes" \ + | sort \ + | uniq \ + ) + while read -r rpath_lib _ ; do + suffix=${rpath_lib/@rpath\/} + for rpath in "${rpaths[@]}" ; do + if [ -f "$rpath/$suffix" ] ; then + printf "Found @rpath/%s in %s\n" "$suffix" "$rpath" + libs+=("$rpath/$suffix") + fi + done + done < <( otool -L "${bundle_binary_list[@]}" "$pkglib"/*.dylib \ + | grep @rpath \ + | grep -E -v "$skip_pats" \ + | sort -u \ + ) + install -m 644 -C -v "${libs[@]}" "$pkglib" + (( a++ )) + # shellcheck disable=SC2012 + nnfiles=$( ls "$pkglib" | wc -l ) + if (( nnfiles == nfiles )); then + endl=false + else + nfiles=$nnfiles + fi +done + +# Strip libraries and executables if requested +#---------------------------------------------------------- +if [ "$strip" = "true" ]; then + echo -e "\\nStripping debugging symbols...\\n" + strip -x "$pkglib"/*.dylib + strip -ur "${bundle_binary_list[@]}" +fi + +"@QT_MACDEPLOYQT_EXECUTABLE@" "$bundle" -no-strip -verbose=2 || exit 1 + +# +# The build process added to the Wireshark/Logray binary an rpath +# entry pointing to the directory containing the Qt frameworks; remove +# that entry from the binary in the package. +# +/usr/bin/install_name_tool -delete_rpath "$qt_frameworks_dir" "$pkgexec/$app_name" + +if [ -d "$sparkle_frameworks_dir" ] ; then + cp -R "$sparkle_frameworks_dir" "$pkglib" || exit 1 + # Remove these if we ever start sandboxing. + rm -f "$pkglib/Sparkle.framework/XPCServices" || exit 1 + rm -rf "$pkglib/Sparkle.framework/Versions/B/XPCServices" || exit 1 +fi + +# NOTE: we must rpathify *all* files, *including* Qt libraries etc., +# +rpathify_file () { + local rpathify_exclude_prefixes="$install_exclude_prefixes|@rpath" + + # Fix a given executable, library, or plugin to be relocatable + if [ ! -f "$1" ]; then + return 0; + fi + + # + # OK, what type of file is this? + # + if ! filetype=$( otool -hv "$1" | grep -E MH_MAGIC | awk '{print $5}' ; exit "${PIPESTATUS[0]}" ) ; then + echo "Unable to rpathify $1 in $( pwd ): file type failed." + exit 1 + fi + + case "$filetype" in + + EXECUTE|DYLIB|BUNDLE) + # + # Executable, library, or plugin. (Plugins + # can be either DYLIB or BUNDLE; shared + # libraries are DYLIB.) + # + # For DYLIB and BUNDLE, fix the shared + # library identification. + # + if [[ "$filetype" = "DYLIB" || "$filetype" = "BUNDLE" ]]; then + echo "Changing shared library identification of $1" + base=$( echo "$1" | awk -F/ '{print $NF}' ) + # + # The library will end up in a directory in + # the rpath; this is what we should change its + # ID to. + # + to=@rpath/$base + /usr/bin/install_name_tool -id "$to" "$1" + + # + # If we're a library and we depend on something in + # @executable_path/../Frameworks, replace that with + # @rpath. + # + while read -r dep_lib ; do + base=$( echo "$dep_lib" | awk -F/ '{print $NF}' ) + to="@rpath/$base" + echo "Changing reference to $dep_lib to $to in $1" + /usr/bin/install_name_tool -change "$dep_lib" "$to" "$1" + done < <( otool -L "$1" | grep @executable_path/../Frameworks | awk '{print $1}' ) + + # + # Try to work around brotli's lack of a full path + # https://github.com/google/brotli/issues/934 + # + while read -r base ; do + to="@rpath/$base" + echo "Changing reference to $base to $to in $1" + /usr/bin/install_name_tool -change "$base" "$to" "$1" + done < <( otool -L "$1" | grep '^ libbrotli' | awk '{print $1}' ) + fi + + # + # Find our local rpaths and remove them. + # + otool -l "$1" | grep -A2 LC_RPATH \ + | awk '$1=="path" && $2 !~ /^@/ {print $2}' \ + | grep -E -v "$rpathify_exclude_prefixes" | \ + while read -r lc_rpath ; do + echo "Stripping LC_RPATH $lc_rpath from $1" + install_name_tool -delete_rpath "$lc_rpath" "$1" + done + + # + # Add -Wl,-rpath,@executable_path/../Frameworks + # to the rpath, so it'll find the bundled + # frameworks and libraries if they're referred + # to by @rpath/, rather than having a wrapper + # script tweak DYLD_LIBRARY_PATH. + # + if [[ "$filetype" = "EXECUTE" ]]; then + if [ -d ../Frameworks ] ; then + framework_path=../Frameworks + elif [ -d ../../Frameworks ] ; then + framework_path=../../Frameworks + else + echo "Unable to find relative path to Frameworks for $1 from $( pwd )" + exit 1 + fi + + echo "Adding @executable_path/$framework_path to rpath of $1" + /usr/bin/install_name_tool -add_rpath @executable_path/$framework_path "$1" + fi + + # + # Show the minimum supported version of macOS + # for each executable or library + # + if [[ "$filetype" = "EXECUTE" || "$filetype" = "DYLIB" ]] ; then + echo "Minimum macOS version for $1:" + otool -l "$1" | grep -A3 LC_VERSION_MIN_MACOSX + fi + + # + # Get the list of dynamic libraries on which this + # file depends, and select only the libraries that + # are in $LIBPREFIX, as those are the only ones + # that we'll be shipping in the app bundle; the + # other libraries are system-supplied or supplied + # as part of X11, will be expected to be on the + # system on which the bundle will be installed, + # and should be referred to by their full pathnames. + # + local libs=() + while read -r lib ; do + libs+=("$lib") + done < <( otool -L "$1" \ + | grep -F compatibility \ + | cut -d\( -f1 \ + | grep -E -v "$rpathify_exclude_prefixes" \ + | sort \ + | uniq \ + ) + + for lib in "${libs[@]}"; do + # + # Get the file name of the library. + # + base=$( echo "$lib" | awk -F/ '{print $NF}' ) + # + # The library will end up in a directory in + # the rpath; this is what we should change its + # file name to. + # + to=@rpath/$base + # + # Change the reference to that library. + # + echo "Changing reference to $lib to $to in $1" + /usr/bin/install_name_tool -change "$lib" "$to" "$1" + done + ;; + esac +} + +rpathify_dir () { + # + # Make sure we *have* that directory + # + if [ -d "$1" ]; then + (cd "$1" || exit 1 + echo "rpathifying $1" + # + # Make sure we *have* files to fix + # + # shellcheck disable=SC2086 + files=$( ls $2 2>/dev/null ) + if [ -n "$files" ]; then + for file in $files; do + rpathify_file "$file" "$( pwd )" + done + else + echo "no files found in $1" + fi + ) + rf_ret=$? + if [ $rf_ret -ne 0 ] ; then exit $rf_ret ; fi + fi +} + +rpathify_files () { + # + # Fix bundle deps + # + rpathify_dir "$pkglib" "*.dylib" + rpathify_dir "$pkgexec" "*" + for plugindir in "$pkgplugin"/* + do + rpathify_dir "$plugindir" "*" + done + + rpathify_dir "$pkgexec/extcap" "*" +} + +if [ ${#LIBPREFIX} -ge "6" ]; then + # If the LIBPREFIX path is long enough to allow + # path rewriting, then do this. + # 6 is the length of @rpath, which replaces LIBPREFIX. + rpathify_files +else + echo "Could not rewrite dylib paths for bundled libraries. This requires" >&2 + echo "the support libraries to be installed in a PREFIX of at least 6 characters in length." >&2 + echo "" >&2 + exit 1 + +fi + +# QtNetwork might be linked with brotli. +rpathify_file "$pkglib/QtNetwork.framework/Versions/Current/QtNetwork" + +bundle_dsym="${bundle%%.app}.dSYM" + +frameworks=() +for framework in "$pkglib"/*.framework/Versions/*/* ; do + if [ -f "$framework" ];then + frameworks+=("$framework") + fi +done + +echo "Dsymifying binaries to $bundle_dsym:" +# shellcheck disable=SC2086 +dsymutil --minimize --out "$bundle_dsym" \ + "${bundle_binary_list[@]}" \ + "${frameworks[@]}" \ + "$pkglib"/*.dylib + +# echo "Stripping binaries:" +# # shellcheck disable=SC2086 +# strip -S \ +# "${bundle_binary_list[@]}" \ +# "${frameworks[@]}" \ +# "$pkglib"/*.dylib \ +# "$pkgplugin"/*/*.so + +# XXX What's the proper directory layout here? +# dsymify_file () { +# # out_dsym="${1/#$bundle/$bundle_dsym}.dSYM" +# echo " $1" +# dsymutil --minimize --out "$bundle_dsym" "$1" +# strip "$1" +# } + +# echo "Dsymifying and stripping executables:" +# if [ -z "${bundle_binary_list[@]}" ] ; then +# echo "No executables specified for dsymifying." +# exit 1 +# fi +# for binary in "${bundle_binary_list[@]}" ; do +# if [ -e "$binary" ];then +# dsymify_file "$binary" +# fi +# done + +# echo "Dsymifying and stripping frameworks:" +# for framework in "$pkglib"/*.framework/Versions/*/* ; do +# if [ -f "$framework" ];then +# dsymify_file "$framework" +# fi +# done + +# echo "Dsymifying and stripping libraries:" +# for library in "$pkglib"/*.dylib ; do +# # +# # Squelch warnings, in case the .o files from building +# # support libraries aren't around any more. +# # +# dsymify_file "$library" | grep -E -v 'unable to open object file' +# done + +# echo "Dsymifying and stripping plugins:" +# for plugin in "$pkgplugin"/*/*.so ; do +# dsymify_file "$plugin" +# done + +codesign_file () { + # https://developer.apple.com/forums/thread/128166 + # https://developer.apple.com/library/archive/documentation/Security/Conceptual/CodeSigningGuide/Procedures/Procedures.html + # https://developer.apple.com/library/archive/technotes/tn2206/_index.html + # https://developer.apple.com/documentation/security/notarizing_your_app_before_distribution/resolving_common_notarization_issues?language=objc + # + # XXX Do we need to add the com.apple.security.cs.allow-unsigned-executable-memory + # entitlement for Lua? + # https://developer.apple.com/documentation/security/hardened_runtime_entitlements?language=objc + + codesign \ + --sign "$codesign_dev_app_identity" \ + --prefix "org.wireshark." \ + --force \ + --options runtime \ + --entitlements "@CMAKE_SOURCE_DIR@/packaging/macosx/entitlements.plist" \ + --timestamp \ + --verbose \ + "$1" || exit 1 +} + +# XXX We could do this via the productbuild calls in the {,un}install_*_pkg +# targets in CMakeLists.txt instead. +productsign_pkg () { + mv "$1" "$1.unsigned" || exit 1 + productsign \ + --sign "$codesign_dev_install_identity" \ + --timestamp \ + "$1.unsigned" "$1" || exit 1 + rm -f "$1.unsigned" || exit 1 +} + +if [ -n "$CODE_SIGN_IDENTITY" ] ; then + security find-identity -v -s "$CODE_SIGN_IDENTITY" -p codesigning + + # The Code Signing Guide says: + # + # "While you use the --deep option for verification to mimic what Gatekeeper does, + # it is not recommended for signing. During signing, if you have nested code, and + # if you are signing manually, you sign nested code in stages (as Xcode does + # automatically), starting with the most deeply embedded components first. You + # then sign code at the next level of hierarchy, and so on. You work your way + # outward, finally signing the top level entity that contains all the others. + # Signing all the components in one shot with --deep is for emergency repairs and + # temporary adjustments only. Note that signing with the combination --deep + # --force will forcibly re-sign all code in a bundle." + + # We need to force-sign Sparkle and its Updater.app. + # https://sparkle-project.org/documentation/#4-distributing-your-app + # https://sparkle-project.org/documentation/sandboxing/#code-signing + + if [ "$sparkle_version" == "2" ] ; then + echo "Signing Sparkle's assets" + codesign \ + --sign "$codesign_dev_app_identity" \ + --force \ + --options runtime \ + --verbose \ + "$pkglib/Sparkle.framework/Versions/B/AutoUpdate" \ + "$pkglib/Sparkle.framework/Versions/B/Updater.app" \ + "$pkglib/Sparkle.framework" \ + || exit 1 + # Uncomment if we ever start sandboxing. + # "$pkglib/Sparkle.framework/Versions/B/XPCServices/org.sparkle-project.InstallerLauncher.xpc" + # codesign \ + # --sign "$codesign_dev_app_identity" \ + # --force \ + # --options runtime \ + # --entitlements "$sparkle_frameworks_dir/../Entitlements/org.sparkle-project.Downloader.entitlements" \ + # --verbose \ + # "$pkglib/Sparkle.framework/Versions/B/XPCServices/org.sparkle-project.Downloader.xpc" \ + # || exit 1 + else + echo "Signing Sparkle's AutoUpdate.app" + codesign \ + --sign "$codesign_dev_app_identity" \ + --force \ + --timestamp \ + --options runtime \ + --verbose \ + "$pkglib/Sparkle.framework/Versions/A/Resources/AutoUpdate.app" \ + || exit 1 + fi + + echo "Signing frameworks" + for framework in "$pkglib"/*.framework/Versions/* ; do + if [ -L "$framework" ] ; then + # Skip "Current" + continue + fi + codesign_file "$framework" + done + + echo "Signing libraries" + for library in "$pkglib"/*.dylib ; do + codesign_file "$library" + done + + plugin_list=$( find "$bundle/Contents/PlugIns" -type f -name "*.dylib" -o -name "*.so" ) + echo "Signing plugins" + for plugin in $plugin_list ; do + codesign_file "$plugin" + done + + echo "Signing extra packages" + find "$bundle/Contents/Resources/Extras" -type f -name "*.pkg" | \ + while read -r extra_pkg ; do + productsign_pkg "$extra_pkg" + done + + echo "Signing secondary executables" + if (( ! ${#secondary_binary_list[@]} )) ; then + echo "No executables specified for code signing." + exit 1 + fi + for binary in "${secondary_binary_list[@]}" ; do + if [ -e "$binary" ];then + codesign_file "$binary" + fi + done + + echo "Signing primary executable" + codesign_file "$pkgexec/$app_name" + + echo "Signing $bundle" + codesign_file "$bundle" + + # Code Signing Guide, "Testing Conformance with Command Line Tools" + codesign --verify --deep --strict --verbose=2 "$bundle" || exit 1 + spctl --assess --type exec --verbose=2 "$bundle" || exit 1 +else + echo "Code signing not performed (no identity)" +fi + +# File permission sanity check. +if badperms=$( find "$bundle" ! -perm -0444 -exec ls -l "{}" + | grep . ) ; then + echo "Found files with restrictive permissions:" + echo "$badperms" + exit 1 +fi + +exit 0 diff --git a/packaging/macosx/osx-dmg.sh.in b/packaging/macosx/osx-dmg.sh.in new file mode 100755 index 00000000..5eda3998 --- /dev/null +++ b/packaging/macosx/osx-dmg.sh.in @@ -0,0 +1,108 @@ +#!/bin/bash +# +# The script creates a disk image using the dmgbuild utility and signs it. + +set -e + +# Defaults +app_name="Wireshark" +dmgbuild="@DMGBUILD_EXECUTABLE@" +version="@PROJECT_VERSION@" +log_version="@LOG_PROJECT_VERSION@" +app_settings_file="@CMAKE_BINARY_DIR@/packaging/macosx/wireshark-app.dmgbuild" +dsym_settings_file="@CMAKE_BINARY_DIR@/packaging/macosx/wireshark-dsym.dmgbuild" +architecture="" + +# Help message +#---------------------------------------------------------- +help() +{ +echo -e " +Create a custom dmg file to distribute Wireshark + +USAGE + $0 + +OPTIONS + -h,--help + Display this help message. + +Icons are positioned and the background image is set in wireshark-app.dmgbuild.in +and wireshark-dsym.dmgbuild.in. +" +} + +if [ ! -x "$dmgbuild" ] ; then + echo "Error: \"$dmgbuild\" not found." + exit 1 +fi + +# Parse command line arguments +while [ "$1" != "" ] +do + case $1 in + -a|--app-name) + shift 1 + app_name="$1" + ;; + -h|--help) + help + exit 0 ;; + *) + echo "Invalid command line option" + exit 2 ;; + esac + shift 1 +done + +if lipo "$app_name.app/Contents/MacOS/$app_name" -verify_arch arm64 ; then + architecture="Arm 64" +elif lipo "$app_name.app/Contents/MacOS/$app_name" -verify_arch x86_64 ; then + architecture="Intel 64" +else + echo "Error: $app_name.app missing or has unknown architecture." + lipo "$app_name.app/Contents/MacOS/$app_name" -detailed_info + exit 1 +fi + +if [[ $app_name = Log* ]] ; then + version=$log_version + app_settings_file="@CMAKE_BINARY_DIR@/packaging/macosx/logray-app.dmgbuild" + dsym_settings_file="@CMAKE_BINARY_DIR@/packaging/macosx/logray-dsym.dmgbuild" +fi + +app_vol_name="$app_name ${version}" +app_img_name="$app_vol_name $architecture.dmg" + +printf "\nCreating application disk image %s\n" "$app_img_name" + +"$dmgbuild" \ + --no-hidpi \ + -s "$app_settings_file" \ + "$app_vol_name" \ + "$app_img_name" || exit 1 + +dsym_vol_name="$app_name dSYM ${version}" +dsym_img_name="$dsym_vol_name $architecture.dmg" + +printf "\nCreating debugging symbols disk image %s\n" "$dsym_img_name" + +"$dmgbuild" \ + --no-hidpi \ + -s "$dsym_settings_file" \ + "$dsym_vol_name" \ + "$dsym_img_name" || exit 1 + +printf "\nSigning disk images\n" + +# TN2206, "Signing Disk Images" +if [ -n "$CODE_SIGN_IDENTITY" ] ; then + echo -e "Signing $app_img_name and $dsym_img_name" + codesign \ + --sign "Developer ID Application: $CODE_SIGN_IDENTITY" \ + --timestamp \ + --verbose \ + "$app_img_name" "$dsym_img_name" +fi + +exit 0 diff --git a/packaging/macosx/osx-extras.sh b/packaging/macosx/osx-extras.sh new file mode 100755 index 00000000..a306ce40 --- /dev/null +++ b/packaging/macosx/osx-extras.sh @@ -0,0 +1,86 @@ +#!/bin/bash +# +# USAGE +# osx-extras +# +# This script preps the "Extras" packages prior to package creation. +# + +set -e +shopt -s extglob + +# Help message +#---------------------------------------------------------- +help() +{ +echo -e " +Prepare Wireshark's \"Extras\" packages. + +USAGE + $0 + +OPTIONS + -h,--help + Display this help message. +" +} + + +# Parse command line arguments +#---------------------------------------------------------- +while [ "$1" != "" ] +do + case $1 in + -h|--help) + help + exit 0 ;; + *) + echo "Invalid command line option: $1" + exit 2 ;; + esac + shift 1 +done + +script_dir=$( dirname "$0" ) + +codesign_file () { + # https://developer.apple.com/library/archive/documentation/Security/Conceptual/CodeSigningGuide/Procedures/Procedures.html + # https://developer.apple.com/library/archive/technotes/tn2206/_index.html + # https://developer.apple.com/documentation/security/notarizing_your_app_before_distribution/resolving_common_notarization_issues?language=objc + # + # XXX Do we need to add the com.apple.security.cs.allow-unsigned-executable-memory + # entitlement for Lua? + # https://developer.apple.com/documentation/security/hardened_runtime_entitlements?language=objc + codesign \ + --sign "Developer ID Application: $CODE_SIGN_IDENTITY" \ + --prefix "org.wireshark." \ + --force \ + --timestamp \ + --verbose \ + "$1" +} + +if [ -n "$CODE_SIGN_IDENTITY" ] ; then + security find-identity -v -s "$CODE_SIGN_IDENTITY" -p codesigning + + # According to + # https://developer.apple.com/library/archive/technotes/tn2206/_index.html and + # https://carlashley.com/2018/09/23/code-signing-scripts-for-pppc-whitelisting/ + # script signatures are stored in the file's extended attributes. + # + # In general, signing shell scripts probably isn't very useful. + # In this specific case we should be able to ensure that + # ChmodBPF's extended attributes are preserved from the build + # system to the end user's machine. + + chmodbpf="$script_dir/ChmodBPF/root/Library/Application Support/Wireshark/ChmodBPF/ChmodBPF" + echo "Signing ChmodBPF" + codesign_file "$chmodbpf" + + # Code Signing Guide, "Testing Conformance with Command Line Tools" + codesign --verify --strict --verbose=2 "$chmodbpf" || exit 1 +else + echo "Extras code signing not performed (no identity)" +fi + +exit 0 diff --git a/packaging/macosx/path_helper/install-distribution.xml b/packaging/macosx/path_helper/install-distribution.xml new file mode 100644 index 00000000..245f0765 --- /dev/null +++ b/packaging/macosx/path_helper/install-distribution.xml @@ -0,0 +1,24 @@ + + + + Add Wireshark to the system PATH +
+

This package will add Wireshark and its associated utilities to the system PATH and MANPATH. Wireshark must be installed in /Applications.

]]>
+ + + + + + + + + + + + install.path_helper.pkg +
diff --git a/packaging/macosx/path_helper/root/etc/manpaths.d/Wireshark b/packaging/macosx/path_helper/root/etc/manpaths.d/Wireshark new file mode 100644 index 00000000..205dad7e --- /dev/null +++ b/packaging/macosx/path_helper/root/etc/manpaths.d/Wireshark @@ -0,0 +1 @@ +/Applications/Wireshark.app/Contents/Resources/share/man diff --git a/packaging/macosx/path_helper/root/etc/paths.d/Wireshark b/packaging/macosx/path_helper/root/etc/paths.d/Wireshark new file mode 100644 index 00000000..55493761 --- /dev/null +++ b/packaging/macosx/path_helper/root/etc/paths.d/Wireshark @@ -0,0 +1 @@ +/Applications/Wireshark.app/Contents/MacOS diff --git a/packaging/macosx/path_helper/uninstall-distribution.xml b/packaging/macosx/path_helper/uninstall-distribution.xml new file mode 100644 index 00000000..d44538cd --- /dev/null +++ b/packaging/macosx/path_helper/uninstall-distribution.xml @@ -0,0 +1,24 @@ + + + + Remove Wireshark from the system PATH +
+

This package will remove Wireshark and its associated utilities from the system PATH and MANPATH.

]]>
+ + + + + + + + + + + + uninstall.path_helper.pkg +
diff --git a/packaging/macosx/path_helper/uninstall-scripts/postinstall b/packaging/macosx/path_helper/uninstall-scripts/postinstall new file mode 100755 index 00000000..5575bdee --- /dev/null +++ b/packaging/macosx/path_helper/uninstall-scripts/postinstall @@ -0,0 +1,11 @@ +#!/bin/sh + +# +# Remove the Wireshark paths.d and manpaths.d entries. +# + +rm -f /private/etc/paths.d/Wireshark +rm -f /private/etc/manpaths.d/Wireshark + +# https://gitlab.com/wireshark/wireshark/-/issues/18734 +pkgutil --forget org.wireshark.path_helper.pkg diff --git a/packaging/macosx/wireshark-app.dmgbuild.in b/packaging/macosx/wireshark-app.dmgbuild.in new file mode 100644 index 00000000..b7ba5598 --- /dev/null +++ b/packaging/macosx/wireshark-app.dmgbuild.in @@ -0,0 +1,170 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +import os.path + +# +# Example settings file for dmgbuild +# +# Adapted from https://raw.githubusercontent.com/al45tair/dmgbuild/master/examples/settings.py + +# Use like this: dmgbuild -s settings.py "Test Volume" test.dmg + +# You can actually use this file for your own application (not just TextEdit) +# by doing e.g. +# +# dmgbuild -s settings.py -D app=/path/to/My.app "My Application" MyApp.dmg + +# .. Useful stuff .............................................................. + +ws_version = '@PROJECT_VERSION@' +ws_volname = 'Wireshark ' + ws_version +ws_srcdir = '@CMAKE_SOURCE_DIR@' +ws_bindir = '@CMAKE_BINARY_DIR@' +ws_app = 'Wireshark.app' +ws_readme = 'Read me first.html' +ws_donate = 'Donate to the Wireshark Foundation.html' +ws_install_chmodbpf = 'Install ChmodBPF.pkg' +ws_uninstall_chmodbpf = 'Uninstall ChmodBPF.pkg' +ws_install_path_helper = 'Add Wireshark to the system path.pkg' +ws_uninstall_path_helper = 'Remove Wireshark from the system path.pkg' + +# .. Basics .................................................................... + +# Uncomment to override the output filename +# filename = ws_volname + ' Intel 64.dmg' + +# Uncomment to override the output volume name +# volume_name = 'Wireshark ' + ws_version + +# From the hdiutil man page: +# UDZO - UDIF zlib-compressed image +# UDBZ - UDIF bzip2-compressed image (Mac OS X 10.4+ only) +# ULFO - UDIF lzfse-compressed image (OS X 10.11+ only) +# ULMO - UDIF lzma-compressed image (macOS 10.15+ only) +# Volume format (see hdiutil create -help) +# +# A test with the following bundles resulted in the following .dmg sizes, +# measured with `du -sm`: +# 182 Wireshark.app +# 267 Wireshark.dSYM +# +# UDBZ +# 51 Wireshark 3.7.0 Intel 64.dmg +# 81 Wireshark dSYM 3.7.0 Intel 64.dmg +# +# ULFO +# 51 Wireshark 3.7.0 Intel 64.dmg +# 81 Wireshark dSYM 3.7.0 Intel 64.dmg +# +# ULMO +# 40 Wireshark 3.7.0 Intel 64.dmg +# 50 Wireshark dSYM 3.7.0 Intel 64.dmg + +# https://developer.apple.com/forums/thread/128166 +# currently (Jan 2023) says to use UDZO +format = defines.get('format', 'UDZO') + +# Compression level (if relevant) +compression_level = 9 + +# Volume size +size = None + +# Files to include +files = [ + os.path.join(ws_bindir, 'run', ws_app), + os.path.join(ws_bindir, 'packaging', 'macosx', 'wireshark', ws_readme), + os.path.join(ws_bindir, 'packaging', 'macosx', 'wireshark', ws_donate), + os.path.join(ws_bindir, 'run', ws_app, 'Contents', 'Resources', 'Extras', ws_install_chmodbpf), + os.path.join(ws_bindir, 'run', ws_app, 'Contents', 'Resources', 'Extras', ws_uninstall_chmodbpf), + os.path.join(ws_bindir, 'run', ws_app, 'Contents', 'Resources', 'Extras', ws_install_path_helper), + os.path.join(ws_bindir, 'run', ws_app, 'Contents', 'Resources', 'Extras', ws_uninstall_path_helper), +] + +# Symlinks to create +symlinks = { + 'Applications': '/Applications', + } + +# Volume icon +# +# You can either define icon, in which case that icon file will be copied to the +# image, *or* you can define badge_icon, in which case the icon file you specify +# will be used to badge the system's Removable Disk icon +# +badge_icon = os.path.join(ws_srcdir, 'packaging', 'macosx', 'wsiconvol.icns') +#badge_icon = icon_from_app(application) + +# Window position in ((x, y), (w, h)) format +window_rect = ((600, 200), (360, 550)) + +# Where to put the icons +icon_locations = { + ws_app: ( 80, 64), + 'Applications': (250, 64), + ws_readme: ( 80, 180), + ws_donate: (250, 180), + ws_install_chmodbpf: ( 80, 296), + ws_uninstall_chmodbpf: (250, 296), + ws_install_path_helper: ( 80, 402), + ws_uninstall_path_helper: (250, 402), + } + +# .. Window configuration ...................................................... + +# Background +# +# This is a STRING containing any of the following: +# +# #3344ff - web-style RGB color +# #34f - web-style RGB color, short form (#34f == #3344ff) +# rgb(1,0,0) - RGB color, each value is between 0 and 1 +# hsl(120,1,.5) - HSL (hue saturation lightness) color +# hwb(300,0,0) - HWB (hue whiteness blackness) color +# cmyk(0,1,0,0) - CMYK color +# goldenrod - X11/SVG named color +# builtin-arrow - A simple built-in background with a blue arrow +# /foo/bar/baz.png - The path to an image file +# +# The hue component in hsl() and hwb() may include a unit; it defaults to +# degrees ('deg'), but also supports radians ('rad') and gradians ('grad' +# or 'gon'). +# +# Other color components may be expressed either in the range 0 to 1, or +# as percentages (e.g. 60% is equivalent to 0.6). +background = os.path.join(ws_srcdir, 'packaging', 'macosx', 'dmg_background.png') + +show_status_bar = False +show_tab_view = False +show_toolbar = False +show_pathbar = False +show_sidebar = False +sidebar_width = 180 + +# Select the default view; must be one of +# +# 'icon-view' +# 'list-view' +# 'column-view' +# 'coverflow' +# +default_view = 'icon-view' + +# General view configuration +show_icon_preview = False + +# Set these to True to force inclusion of icon/list view settings (otherwise +# we only include settings for the default view) +include_icon_view_settings = 'auto' +include_list_view_settings = 'auto' + +# .. Icon view configuration ................................................... + +arrange_by = None +grid_offset = (0, 0) +#grid_spacing = 100 +scroll_position = (0, 0) +#label_pos = 'bottom' # or 'right' +text_size = 12 +icon_size = 72 diff --git a/packaging/macosx/wireshark-dsym.dmgbuild.in b/packaging/macosx/wireshark-dsym.dmgbuild.in new file mode 100644 index 00000000..99516a0a --- /dev/null +++ b/packaging/macosx/wireshark-dsym.dmgbuild.in @@ -0,0 +1,139 @@ +# -*- coding: utf-8 -*- +from __future__ import unicode_literals + +import os.path + +# +# Example settings file for dmgbuild +# +# Adapted from https://raw.githubusercontent.com/al45tair/dmgbuild/master/examples/settings.py + +# Use like this: dmgbuild -s settings.py "Test Volume" test.dmg + +# You can actually use this file for your own application (not just TextEdit) +# by doing e.g. +# +# dmgbuild -s settings.py -D app=/path/to/My.app "My Application" MyApp.dmg + +# .. Useful stuff .............................................................. + +ws_version = '@PROJECT_VERSION@' +ws_volname = 'Wireshark Debugging Symbols' + ws_version +ws_srcdir = '@CMAKE_SOURCE_DIR@' +ws_bindir = '@CMAKE_BINARY_DIR@' +ws_app_dsym = 'Wireshark.dSYM' +ws_readme_dsym = 'Debugging symbols installation.html' + +# .. Basics .................................................................... + +# Uncomment to override the output filename +# filename = ws_volname + ' Intel 64.dmg' + +# Uncomment to override the output volume name +# volume_name = 'Wireshark ' + ws_version + +# From the hdiutil man page: +# UDZO - UDIF zlib-compressed image +# UDBZ - UDIF bzip2-compressed image (Mac OS X 10.4+ only) +# ULFO - UDIF lzfse-compressed image (OS X 10.11+ only) +# ULMO - UDIF lzma-compressed image (macOS 10.15+ only) +# Volume format (see hdiutil create -help) + +# dSYMs are huge, so compress them with UDBZ despite what +# https://developer.apple.com/forums/thread/128166 +# currently (Jan 2023) says. +format = defines.get('format', 'UDBZ') + +# Compression level (if relevant) +compression_level = 9 + +# Volume size +size = None + +# Files to include +files = [ + os.path.join(ws_bindir, 'run', ws_app_dsym), + os.path.join(ws_bindir, 'packaging', 'macosx', 'wireshark', ws_readme_dsym), +] + +# Symlinks to create +symlinks = { + 'Applications': '/Applications', + } + +# Volume icon +# +# You can either define icon, in which case that icon file will be copied to the +# image, *or* you can define badge_icon, in which case the icon file you specify +# will be used to badge the system's Removable Disk icon +# +badge_icon = os.path.join(ws_srcdir, 'packaging', 'macosx', 'wsiconvol.icns') +#badge_icon = icon_from_app(application) + +# Where to put the icons +icon_locations = { + ws_app_dsym: ( 80, 64), + 'Applications': (240, 64), + ws_readme_dsym: (160, 170), + } + +# .. Window configuration ...................................................... + +# Background +# +# This is a STRING containing any of the following: +# +# #3344ff - web-style RGB color +# #34f - web-style RGB color, short form (#34f == #3344ff) +# rgb(1,0,0) - RGB color, each value is between 0 and 1 +# hsl(120,1,.5) - HSL (hue saturation lightness) color +# hwb(300,0,0) - HWB (hue whiteness blackness) color +# cmyk(0,1,0,0) - CMYK color +# goldenrod - X11/SVG named color +# builtin-arrow - A simple built-in background with a blue arrow +# /foo/bar/baz.png - The path to an image file +# +# The hue component in hsl() and hwb() may include a unit; it defaults to +# degrees ('deg'), but also supports radians ('rad') and gradians ('grad' +# or 'gon'). +# +# Other color components may be expressed either in the range 0 to 1, or +# as percentages (e.g. 60% is equivalent to 0.6). +background = os.path.join(ws_srcdir, 'packaging', 'macosx', 'dmg_background.png') + +show_status_bar = False +show_tab_view = False +show_toolbar = False +show_pathbar = False +show_sidebar = False +sidebar_width = 180 + +# Window position in ((x, y), (w, h)) format +window_rect = ((600, 200), (350, 325)) + +# Select the default view; must be one of +# +# 'icon-view' +# 'list-view' +# 'column-view' +# 'coverflow' +# +default_view = 'icon-view' + +# General view configuration +show_icon_preview = False + +# Set these to True to force inclusion of icon/list view settings (otherwise +# we only include settings for the default view) +include_icon_view_settings = 'auto' +include_list_view_settings = 'auto' + +# .. Icon view configuration ................................................... + +arrange_by = None +grid_offset = (0, 0) +#grid_spacing = 100 +scroll_position = (0, 0) +#label_pos = 'bottom' # or 'right' +text_size = 12 +icon_size = 72 diff --git a/packaging/macosx/wsiconvol.icns b/packaging/macosx/wsiconvol.icns new file mode 100644 index 00000000..e32e03c0 Binary files /dev/null and b/packaging/macosx/wsiconvol.icns differ diff --git a/packaging/macosx/wsiconvol.svg b/packaging/macosx/wsiconvol.svg new file mode 100644 index 00000000..542fbab2 --- /dev/null +++ b/packaging/macosx/wsiconvol.svg @@ -0,0 +1,106 @@ + +image/svg+xml + + + + + + + + -- cgit v1.2.3