import wireshark-3.4.7-3.el9
This commit is contained in:
commit
92f0395601
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
SOURCES/wireshark-3.4.7.tar.xz
|
1
.wireshark.metadata
Normal file
1
.wireshark.metadata
Normal file
@ -0,0 +1 @@
|
|||||||
|
3fa4bb774030442b9908243a9927d38479c52bf5 SOURCES/wireshark-3.4.7.tar.xz
|
1
SOURCES/90-wireshark-usbmon.rules
Normal file
1
SOURCES/90-wireshark-usbmon.rules
Normal file
@ -0,0 +1 @@
|
|||||||
|
SUBSYSTEM=="usbmon", GROUP="usbmon", MODE="640"
|
60
SOURCES/SIGNATURES-3.4.7.txt
Normal file
60
SOURCES/SIGNATURES-3.4.7.txt
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
-----BEGIN PGP SIGNED MESSAGE-----
|
||||||
|
Hash: SHA512
|
||||||
|
|
||||||
|
wireshark-3.4.7.tar.xz: 32311140 bytes
|
||||||
|
SHA256(wireshark-3.4.7.tar.xz)=6c4cee51ef997cb9d9aaee84113525a5629157d3c743d7c4e320000de804a09d
|
||||||
|
RIPEMD160(wireshark-3.4.7.tar.xz)=be6d3f018532d17b0154677c6fd54c61a2f289f3
|
||||||
|
SHA1(wireshark-3.4.7.tar.xz)=3fa4bb774030442b9908243a9927d38479c52bf5
|
||||||
|
|
||||||
|
Wireshark-win64-3.4.7.exe: 71354272 bytes
|
||||||
|
SHA256(Wireshark-win64-3.4.7.exe)=b61fcdb21a5a1f40d267748300d29b04562277175d827312202c6ea918065238
|
||||||
|
RIPEMD160(Wireshark-win64-3.4.7.exe)=8789c7d43d7822f83e3887a8584abc262c93f3fa
|
||||||
|
SHA1(Wireshark-win64-3.4.7.exe)=55620cf189b44e84f654d39299af106b6ea1a5f3
|
||||||
|
|
||||||
|
Wireshark-win32-3.4.7.exe: 55389856 bytes
|
||||||
|
SHA256(Wireshark-win32-3.4.7.exe)=1ff1e362aa96864e2d08e0241d6c36fc2ee2f9bb228695da5a0040e8b2ea1542
|
||||||
|
RIPEMD160(Wireshark-win32-3.4.7.exe)=a62874a0acfaf48335f8470a9fbc5adbdda68b64
|
||||||
|
SHA1(Wireshark-win32-3.4.7.exe)=f2970ef2bca028768008d687bc04a678c53c299f
|
||||||
|
|
||||||
|
Wireshark-win64-3.4.7.msi: 49106944 bytes
|
||||||
|
SHA256(Wireshark-win64-3.4.7.msi)=86dd46ede8ce640623686d73b9f1bd5f514428ea3f2d335325db4867330a9d38
|
||||||
|
RIPEMD160(Wireshark-win64-3.4.7.msi)=aba2d1f6595165bb840bd2b5e74609b010d940e9
|
||||||
|
SHA1(Wireshark-win64-3.4.7.msi)=f0a1da013a66aa8d138f05d83889df4465b06cd1
|
||||||
|
|
||||||
|
Wireshark-win32-3.4.7.msi: 43905024 bytes
|
||||||
|
SHA256(Wireshark-win32-3.4.7.msi)=d6e900c35637df916d157c1c932dd3a60b6d9e1e4d1b93795efe3208ce016d7f
|
||||||
|
RIPEMD160(Wireshark-win32-3.4.7.msi)=d0bc87c9ca19a420a367fb91dcc42cd0ab3694b9
|
||||||
|
SHA1(Wireshark-win32-3.4.7.msi)=f601e8874355c46c0bf836f6e28b48f5f166ae7d
|
||||||
|
|
||||||
|
WiresharkPortable_3.4.7.paf.exe: 38205224 bytes
|
||||||
|
SHA256(WiresharkPortable_3.4.7.paf.exe)=6529ee4f5d6d850dafaea7bbb334c7c9858e24af4a8b48a2e0f1f75204f8b20d
|
||||||
|
RIPEMD160(WiresharkPortable_3.4.7.paf.exe)=a6333431329c231aca67386840c0725957f69e9a
|
||||||
|
SHA1(WiresharkPortable_3.4.7.paf.exe)=85f4449bc1295d3a24fe750c211b1fa42724574a
|
||||||
|
|
||||||
|
Wireshark 3.4.7 Intel 64.dmg: 131023034 bytes
|
||||||
|
SHA256(Wireshark 3.4.7 Intel 64.dmg)=454c2533aed96e3a39d0c21f9edecad0d75ef9c688d3aef7619895fb7a3c5db4
|
||||||
|
RIPEMD160(Wireshark 3.4.7 Intel 64.dmg)=3dc8b43a2b9173d4e6b79c9313b28558ff957225
|
||||||
|
SHA1(Wireshark 3.4.7 Intel 64.dmg)=bce18e4357e17be18b822bd8c772bb7637268287
|
||||||
|
|
||||||
|
You can validate these hashes using the following commands (among others):
|
||||||
|
|
||||||
|
Windows: certutil -hashfile Wireshark-win64-x.y.z.exe SHA256
|
||||||
|
Linux (GNU Coreutils): sha256sum wireshark-x.y.z.tar.xz
|
||||||
|
macOS: shasum -a 256 "Wireshark x.y.z Intel 64.dmg"
|
||||||
|
Other: openssl sha256 wireshark-x.y.z.tar.xz
|
||||||
|
-----BEGIN PGP SIGNATURE-----
|
||||||
|
|
||||||
|
iQIzBAEBCgAdFiEEWlrbp9vqbD+HIk8ZgiRKeOb+ruoFAmDvMYkACgkQgiRKeOb+
|
||||||
|
ruobURAA2yam2rlLnHN45AUxhCxaEA5PpMMbSVP8eSEj4BDjyjAPt7Ibtt2jOPmv
|
||||||
|
61hKRSckw/+Id9QaHfvbUOD98JSOpVbEv7Gv2ZS6Ek1lFUE1lxdPDcKD8y0ezYIn
|
||||||
|
GH37SGG3yoUOkbBjiTuyFEGyVy6j79ZIFz9imMriBEq0/sJ8OkpIA3AR672UvS1n
|
||||||
|
JnPFXN5NZdsunZtfqOUdIxDEQoUw+Wz9mfyaW+KqMhP9aK8MyQYffsO/z76ieg3l
|
||||||
|
UvgJOhFtkPPwyNyGaP1sji42IiEzubDMx0tEyoVPsjqkARTHPCQUKfCNIKp77EEl
|
||||||
|
4WwNwUuuluJXz02fmFiN/UAU7ebL04xFaoE/VpEbNC4+a1m6jxiQbwGFu5O8P/pS
|
||||||
|
z1lL6N1KoS3ymt6FnZe9fMQOEeVC1IzQKDyhMBIg636naeMjAADCF1oE1fCGHl3z
|
||||||
|
Dq0ZN9BJTnfX8CaOqc4ROaMoTdKZNRMorD2twgs++vseafpKSASLT+11lvwt+e9l
|
||||||
|
Gir9Wge8M60iPIUxOPIl54/vjljgiTSJACHsuyo1VzArmeMv3KQNOpurZkMZIgzx
|
||||||
|
NsiqA7fk3ZmIsMBdjv1rs2yxvJE1LYcWgppLVPh0cJDKlpapVA2EC3v1vONtJxBZ
|
||||||
|
9jDkbzcI+ZnZBhFpErpxrUopiVL1TBBulIMFSyY9OlepWbMlg/g=
|
||||||
|
=Gln0
|
||||||
|
-----END PGP SIGNATURE-----
|
@ -0,0 +1,57 @@
|
|||||||
|
From: Jan Safranek <jsafrane@redhat.com>
|
||||||
|
Date: Fri, 26 Nov 2010 14:30:45 +0300
|
||||||
|
Subject: [PATCH] Customize 'permission denied' error.
|
||||||
|
|
||||||
|
Add Fedora-specific message to error output when dumpcap cannot be started
|
||||||
|
because of permissions.
|
||||||
|
|
||||||
|
Signed-off-by: Jan Safranek <jsafrane@redhat.com>
|
||||||
|
|
||||||
|
diff --git a/capchild/capture_sync.c b/capchild/capture_sync.c
|
||||||
|
index 2f9d2cc..b18e47f 100644
|
||||||
|
--- a/capchild/capture_sync.c
|
||||||
|
+++ b/capchild/capture_sync.c
|
||||||
|
@@ -375,6 +375,7 @@ sync_pipe_start(capture_options *capture_opts, capture_session *cap_session, voi
|
||||||
|
gchar *signal_pipe_name;
|
||||||
|
#else
|
||||||
|
char errmsg[1024+1];
|
||||||
|
+ const char *securitymsg = "";
|
||||||
|
int sync_pipe[2]; /* pipe used to send messages from child to parent */
|
||||||
|
enum PIPES { PIPE_READ, PIPE_WRITE }; /* Constants 0 and 1 for PIPE_READ and PIPE_WRITE */
|
||||||
|
#endif
|
||||||
|
@@ -728,8 +729,11 @@ sync_pipe_start(capture_options *capture_opts, capture_session *cap_session, voi
|
||||||
|
dup2(sync_pipe[PIPE_WRITE], 2);
|
||||||
|
ws_close(sync_pipe[PIPE_READ]);
|
||||||
|
execv(argv[0], argv);
|
||||||
|
- g_snprintf(errmsg, sizeof errmsg, "Couldn't run %s in child process: %s",
|
||||||
|
- argv[0], g_strerror(errno));
|
||||||
|
+ if (errno == EPERM || errno == EACCES)
|
||||||
|
+ securitymsg = "\nAre you a member of the 'wireshark' group? Try running\n'usermod -a -G wireshark _your_username_' as root.";
|
||||||
|
+ g_snprintf(errmsg, sizeof errmsg, "Couldn't run %s in child process: %s%s",
|
||||||
|
+ argv[0], g_strerror(errno), securitymsg);
|
||||||
|
+
|
||||||
|
sync_pipe_errmsg_to_parent(2, errmsg, "");
|
||||||
|
|
||||||
|
/* Exit with "_exit()", so that we don't close the connection
|
||||||
|
@@ -826,6 +830,7 @@ sync_pipe_open_command(char** argv, int *data_read_fd,
|
||||||
|
int i;
|
||||||
|
#else
|
||||||
|
char errmsg[1024+1];
|
||||||
|
+ const char *securitymsg = "";
|
||||||
|
int sync_pipe[2]; /* pipe used to send messages from child to parent */
|
||||||
|
int data_pipe[2]; /* pipe used to send data from child to parent */
|
||||||
|
#endif
|
||||||
|
@@ -1003,8 +1008,11 @@ sync_pipe_open_command(char** argv, int *data_read_fd,
|
||||||
|
ws_close(sync_pipe[PIPE_READ]);
|
||||||
|
ws_close(sync_pipe[PIPE_WRITE]);
|
||||||
|
execv(argv[0], argv);
|
||||||
|
- g_snprintf(errmsg, sizeof errmsg, "Couldn't run %s in child process: %s",
|
||||||
|
- argv[0], g_strerror(errno));
|
||||||
|
+ execv(argv[0], (gpointer)argv);
|
||||||
|
+ if (errno == EPERM || errno == EACCES)
|
||||||
|
+ securitymsg = "\nAre you a member of the 'wireshark' group? Try running\n'usermod -a -G wireshark _your_username_' as root.";
|
||||||
|
+ g_snprintf(errmsg, sizeof errmsg, "Couldn't run %s in child process: %s%s",
|
||||||
|
+ argv[0], g_strerror(errno), securitymsg);
|
||||||
|
sync_pipe_errmsg_to_parent(2, errmsg, "");
|
||||||
|
|
||||||
|
/* Exit with "_exit()", so that we don't close the connection
|
@ -0,0 +1,18 @@
|
|||||||
|
From: Peter Hatina <phatina@redhat.com>
|
||||||
|
Date: Wed, 4 Sep 2013 10:03:57 +0200
|
||||||
|
Subject: [PATCH] fix string overrun in plugins/profinet
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/plugins/epan/profinet/packet-dcom-cba.c b/plugins/epan/profinet/packet-dcom-cba.c
|
||||||
|
index 0f1658a..f7fd322 100644
|
||||||
|
--- a/plugins/epan/profinet/packet-dcom-cba.c
|
||||||
|
+++ b/plugins/epan/profinet/packet-dcom-cba.c
|
||||||
|
@@ -555,7 +555,7 @@ dissect_ICBAPhysicalDevice_get_LogicalDevice_rqst(tvbuff_t *tvb, int offset,
|
||||||
|
packet_info *pinfo, proto_tree *tree, dcerpc_info *di, guint8 *drep)
|
||||||
|
{
|
||||||
|
guint32 u32Pointer;
|
||||||
|
- gchar szStr[1000];
|
||||||
|
+ gchar szStr[1000] = "";
|
||||||
|
guint32 u32MaxStr = sizeof(szStr);
|
||||||
|
gchar *call;
|
||||||
|
|
15
SOURCES/wireshark-0004-Restore-Fedora-specific-groups.patch
Normal file
15
SOURCES/wireshark-0004-Restore-Fedora-specific-groups.patch
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
From: Peter Lemenkov <lemenkov@gmail.com>
|
||||||
|
Date: Fri, 13 Sep 2013 14:36:55 +0400
|
||||||
|
Subject: [PATCH] Restore Fedora-specific groups
|
||||||
|
|
||||||
|
Signed-off-by: Peter Lemenkov <lemenkov@gmail.com>
|
||||||
|
diff --git a/wireshark.desktop b/wireshark.desktop
|
||||||
|
index 334db48..669c6f1 100644
|
||||||
|
--- a/wireshark.desktop
|
||||||
|
+++ b/wireshark.desktop
|
||||||
|
@@ -108,4 +108,4 @@ Terminal=false
|
||||||
|
MimeType=application/vnd.tcpdump.pcap;application/x-pcapng;application/x-snoop;application/x-iptrace;application/x-lanalyzer;application/x-nettl;application/x-radcom;application/x-etherpeek;application/x-visualnetworks;application/x-netinstobserver;application/x-5view;application/x-tektronix-rf5;application/x-micropross-mplog;application/x-apple-packetlogger;application/x-endace-erf;application/ipfix;application/x-ixia-vwr;
|
||||||
|
# Category entry according to:
|
||||||
|
# https://specifications.freedesktop.org/menu-spec/1.0/
|
||||||
|
-Categories=Network;Monitor;Qt;
|
||||||
|
+Categories=Application;Network;Monitor;Qt;
|
@ -0,0 +1,20 @@
|
|||||||
|
From: Kenneth Soerensen <knnthsrnsn@gmail.com>
|
||||||
|
Date: Wed, 29 Jan 2014 16:04:12 +0400
|
||||||
|
Subject: [PATCH] Fix paths in a wireshark.desktop file
|
||||||
|
|
||||||
|
|
||||||
|
diff --git a/wireshark.desktop b/wireshark.desktop
|
||||||
|
index 669c6f1..f7df1f3 100644
|
||||||
|
--- a/wireshark.desktop
|
||||||
|
+++ b/wireshark.desktop
|
||||||
|
@@ -102,8 +102,8 @@ Comment[tr]=Ağ trafiği çözümleyicisi
|
||||||
|
Comment[vi]=Trình phân tích giao thông mạng
|
||||||
|
Comment[uk]=Аналізатор мережевого трафіку
|
||||||
|
Icon=wireshark
|
||||||
|
-TryExec=wireshark
|
||||||
|
-Exec=wireshark %f
|
||||||
|
+TryExec=/usr/bin/wireshark
|
||||||
|
+Exec=/usr/bin/wireshark %f
|
||||||
|
Terminal=false
|
||||||
|
MimeType=application/vnd.tcpdump.pcap;application/x-pcapng;application/x-snoop;application/x-iptrace;application/x-lanalyzer;application/x-nettl;application/x-radcom;application/x-etherpeek;application/x-visualnetworks;application/x-netinstobserver;application/x-5view;application/x-tektronix-rf5;application/x-micropross-mplog;application/x-apple-packetlogger;application/x-endace-erf;application/ipfix;application/x-ixia-vwr;
|
||||||
|
# Category entry according to:
|
295
SOURCES/wireshark-0006-Move-tmp-to-var-tmp.patch
Normal file
295
SOURCES/wireshark-0006-Move-tmp-to-var-tmp.patch
Normal file
@ -0,0 +1,295 @@
|
|||||||
|
From cb54210f7f02b07768cfbf49ae266d487f580e1b Mon Sep 17 00:00:00 2001
|
||||||
|
From: rpm-build <rpm-build>
|
||||||
|
Date: Thu, 29 Jun 2017 15:32:58 +0200
|
||||||
|
Subject: [PATCH] Move /tmp to /var/tmp
|
||||||
|
|
||||||
|
Fedora is using tmpfs which is limited by the size of RAM, thus we need
|
||||||
|
to use different directory on different filesystem.
|
||||||
|
---
|
||||||
|
ui/qt/about_dialog.cpp | 3 +-
|
||||||
|
ui/qt/iax2_analysis_dialog.cpp | 5 +--
|
||||||
|
ui/qt/rtp_analysis_dialog.cpp | 5 +--
|
||||||
|
ui/qt/rtp_audio_stream.cpp | 3 +-
|
||||||
|
wsutil/tempfile.c | 9 +++---
|
||||||
|
wsutil/tempfile.h | 4 +--
|
||||||
|
wsutil/wstmpdir.c | 70 ++++++++++++++++++++++++++++++++++++++++++
|
||||||
|
wsutil/wstmpdir.h | 39 +++++++++++++++++++++++
|
||||||
|
8 files changed, 132 insertions(+), 11 deletions(-)
|
||||||
|
create mode 100644 wsutil/wstmpdir.c
|
||||||
|
create mode 100644 wsutil/wstmpdir.h
|
||||||
|
|
||||||
|
diff --git a/ui/qt/about_dialog.cpp b/ui/qt/about_dialog.cpp
|
||||||
|
index 31dc581..2f74285 100644
|
||||||
|
--- a/ui/qt/about_dialog.cpp
|
||||||
|
+++ b/ui/qt/about_dialog.cpp
|
||||||
|
@@ -26,6 +26,7 @@
|
||||||
|
|
||||||
|
#include "wireshark_application.h"
|
||||||
|
#include <wsutil/filesystem.h>
|
||||||
|
+#include <wsutil/wstmpdir.h> /* for get_tmp_dir() */
|
||||||
|
|
||||||
|
#include <QDesktopServices>
|
||||||
|
#include <QUrl>
|
||||||
|
@@ -206,7 +206,7 @@ FolderListModel::FolderListModel(QObject * parent):
|
||||||
|
appendRow(QStringList() << tr("\"File\" dialogs") << get_last_open_dir() << tr("capture files"));
|
||||||
|
|
||||||
|
/* temp */
|
||||||
|
- appendRow(QStringList() << tr("Temp") << g_get_tmp_dir() << tr("untitled capture files"));
|
||||||
|
+ appendRow(QStringList() << tr("Temp") << get_tmp_dir() << tr("untitled capture files"));
|
||||||
|
|
||||||
|
/* pers conf */
|
||||||
|
appendRow(QStringList() << tr("Personal configuration")
|
||||||
|
diff --git a/ui/qt/iax2_analysis_dialog.cpp b/ui/qt/iax2_analysis_dialog.cpp
|
||||||
|
index ee4e5fd..fe17a95 100644
|
||||||
|
--- a/ui/qt/iax2_analysis_dialog.cpp
|
||||||
|
+++ b/ui/qt/iax2_analysis_dialog.cpp
|
||||||
|
@@ -37,6 +37,7 @@
|
||||||
|
#include "ui/rtp_stream.h"
|
||||||
|
#endif
|
||||||
|
#include <wsutil/utf8_entities.h>
|
||||||
|
+#include <wsutil/wstmpdir.h> /* for get_tmp_dir() */
|
||||||
|
|
||||||
|
#include <wsutil/g711.h>
|
||||||
|
#include <wsutil/pint.h>
|
||||||
|
@@ -271,10 +272,10 @@ Iax2AnalysisDialog::Iax2AnalysisDialog(QWidget &parent, CaptureFile &cf) :
|
||||||
|
|
||||||
|
// We keep our temp files open for the lifetime of the dialog. The GTK+
|
||||||
|
// UI opens and closes at various points.
|
||||||
|
- QString tempname = QString("%1/wireshark_iax2_f").arg(QDir::tempPath());
|
||||||
|
+ QString tempname = QString("%1/wireshark_iax2_f").arg(get_tmp_dir());
|
||||||
|
fwd_tempfile_ = new QTemporaryFile(tempname, this);
|
||||||
|
fwd_tempfile_->open();
|
||||||
|
- tempname = QString("%1/wireshark_iax2_r").arg(QDir::tempPath());
|
||||||
|
+ tempname = QString("%1/wireshark_iax2_r").arg(get_tmp_dir());
|
||||||
|
rev_tempfile_ = new QTemporaryFile(tempname, this);
|
||||||
|
rev_tempfile_->open();
|
||||||
|
|
||||||
|
diff --git a/ui/qt/rtp_analysis_dialog.cpp b/ui/qt/rtp_analysis_dialog.cpp
|
||||||
|
index 5d82e46..8008984 100644
|
||||||
|
--- a/ui/qt/rtp_analysis_dialog.cpp
|
||||||
|
+++ b/ui/qt/rtp_analysis_dialog.cpp
|
||||||
|
@@ -37,6 +37,7 @@
|
||||||
|
|
||||||
|
#include <wsutil/g711.h>
|
||||||
|
#include <wsutil/pint.h>
|
||||||
|
+#include <wsutil/wstmpdir.h> /* for get_tmp_dir() */
|
||||||
|
|
||||||
|
#include <QMessageBox>
|
||||||
|
#include <QPushButton>
|
||||||
|
@@ -331,10 +332,10 @@ RtpAnalysisDialog::RtpAnalysisDialog(QWidget &parent, CaptureFile &cf, struct _r
|
||||||
|
|
||||||
|
// We keep our temp files open for the lifetime of the dialog. The GTK+
|
||||||
|
// UI opens and closes at various points.
|
||||||
|
- QString tempname = QString("%1/wireshark_rtp_f").arg(QDir::tempPath());
|
||||||
|
+ QString tempname = QString("%1/wireshark_rtp_f").arg(get_tmp_dir());
|
||||||
|
fwd_tempfile_ = new QTemporaryFile(tempname, this);
|
||||||
|
fwd_tempfile_->open();
|
||||||
|
- tempname = QString("%1/wireshark_rtp_r").arg(QDir::tempPath());
|
||||||
|
+ tempname = QString("%1/wireshark_rtp_r").arg(get_tmp_dir());
|
||||||
|
rev_tempfile_ = new QTemporaryFile(tempname, this);
|
||||||
|
rev_tempfile_->open();
|
||||||
|
|
||||||
|
diff --git a/ui/qt/rtp_audio_stream.cpp b/ui/qt/rtp_audio_stream.cpp
|
||||||
|
index fde66c8..b9531d2 100644
|
||||||
|
--- a/ui/qt/rtp_audio_stream.cpp
|
||||||
|
+++ b/ui/qt/rtp_audio_stream.cpp
|
||||||
|
@@ -37,6 +37,7 @@
|
||||||
|
#include <ui/rtp_stream.h>
|
||||||
|
|
||||||
|
#include <wsutil/nstime.h>
|
||||||
|
+#include <wsutil/wstmpdir.h> /* for get_tmp_dir() */
|
||||||
|
|
||||||
|
#include <QAudioFormat>
|
||||||
|
#include <QAudioOutput>
|
||||||
|
@@ -76,7 +77,7 @@ RtpAudioStream::RtpAudioStream(QObject *parent, _rtp_stream_info *rtp_stream) :
|
||||||
|
visual_sample_rate_, SPEEX_RESAMPLER_QUALITY_MIN, NULL);
|
||||||
|
speex_resampler_skip_zeros(visual_resampler_);
|
||||||
|
|
||||||
|
- QString tempname = QString("%1/wireshark_rtp_stream").arg(QDir::tempPath());
|
||||||
|
+ QString tempname = QString("%1/wireshark_rtp_stream").arg(get_tmp_dir());
|
||||||
|
tempfile_ = new QTemporaryFile(tempname, this);
|
||||||
|
tempfile_->open();
|
||||||
|
|
||||||
|
diff --git a/wsutil/tempfile.c b/wsutil/tempfile.c
|
||||||
|
index 5082452..f751a7c 100644
|
||||||
|
--- a/wsutil/tempfile.c
|
||||||
|
+++ b/wsutil/tempfile.c
|
||||||
|
@@ -12,10 +12,12 @@
|
||||||
|
|
||||||
|
#include <glib.h>
|
||||||
|
#include "tempfile.h"
|
||||||
|
+#include <wsutil/file_util.h>
|
||||||
|
+#include <wsutil/wstmpdir.h> /* for get_tmp_dir() */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a tempfile with the given prefix (e.g. "wireshark"). The path
|
||||||
|
- * is created using g_file_open_tmp.
|
||||||
|
+ * is created using get_tmp_dir.
|
||||||
|
*
|
||||||
|
* @param namebuf [in,out] If not NULL, receives the full path of the temp file.
|
||||||
|
* Must be freed.
|
||||||
|
@@ -30,6 +31,9 @@ create_tempfile(gchar **namebuf, const char *pfx, const char *sfx, GError **err)
|
||||||
|
{
|
||||||
|
int fd;
|
||||||
|
gchar *safe_pfx = NULL;
|
||||||
|
+ gchar *tmp_file;
|
||||||
|
+ const char *tmp_dir;
|
||||||
|
+ int old_mask;
|
||||||
|
|
||||||
|
if (pfx) {
|
||||||
|
/* The characters in "delimiters" come from:
|
||||||
|
@@ -49,7 +53,15 @@ create_tempfile(gchar **namebuf, const char *pfx, const char *sfx, GError **err)
|
||||||
|
gchar* filetmpl = g_strdup_printf("%sXXXXXX%s", safe_pfx ? safe_pfx : "", sfx ? sfx : "");
|
||||||
|
g_free(safe_pfx);
|
||||||
|
|
||||||
|
- fd = g_file_open_tmp(filetmpl, namebuf, err);
|
||||||
|
+ tmp_dir = get_tmp_dir();
|
||||||
|
+ tmp_file = g_strconcat(tmp_dir, "/", filetmpl, NULL);
|
||||||
|
+
|
||||||
|
+ if (namebuf)
|
||||||
|
+ *namebuf = tmp_file;
|
||||||
|
+
|
||||||
|
+ old_mask = ws_umask(0077);
|
||||||
|
+ fd = mkstemps(tmp_file, sfx ? (int) strlen(sfx) : 0);
|
||||||
|
+ ws_umask(old_mask);
|
||||||
|
|
||||||
|
g_free(filetmpl);
|
||||||
|
return fd;
|
||||||
|
diff --git a/wsutil/tempfile.h b/wsutil/tempfile.h
|
||||||
|
index 1dca2df..bb3160c 100644
|
||||||
|
--- a/wsutil/tempfile.h
|
||||||
|
+++ b/wsutil/tempfile.h
|
||||||
|
@@ -45,7 +45,7 @@ WS_DLL_PUBLIC char *get_tempfile_path(const char *filename);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a tempfile with the given prefix (e.g. "wireshark"). The path
|
||||||
|
- * is created using g_file_open_tmp.
|
||||||
|
+ * is created using get_tmp_dir and mkstemp.
|
||||||
|
*
|
||||||
|
* @param namebuf [in,out] If not NULL, receives the full path of the temp file.
|
||||||
|
* Must be freed.
|
||||||
|
diff --git a/wsutil/wstmpdir.c b/wsutil/wstmpdir.c
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..d8b733b
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/wsutil/wstmpdir.c
|
||||||
|
@@ -0,0 +1,71 @@
|
||||||
|
+/* wstmpdir.c
|
||||||
|
+ *
|
||||||
|
+ * Copyright (C) 2013 Red Hat, Inc. All right reserved.
|
||||||
|
+ *
|
||||||
|
+ * Temporary directory routine
|
||||||
|
+ *
|
||||||
|
+ * This program is free software; you can redistribute it and/or
|
||||||
|
+ * modify it under the terms of the GNU General Public License
|
||||||
|
+ * as published by the Free Software Foundation; either version 2
|
||||||
|
+ * of the License, or (at your option) any later version.
|
||||||
|
+ *
|
||||||
|
+ * This program is distributed in the hope that it will be useful,
|
||||||
|
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
+ * GNU General Public License for more details.
|
||||||
|
+ *
|
||||||
|
+ * You should have received a copy of the GNU General Public License
|
||||||
|
+ * along with this program; if not, write to the Free Software
|
||||||
|
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
+ *
|
||||||
|
+ * Author: Peter Hatina <phatina@redhat.com>
|
||||||
|
+ */
|
||||||
|
+
|
||||||
|
+#include "config.h"
|
||||||
|
+
|
||||||
|
+#include <glib.h>
|
||||||
|
+#include "wstmpdir.h"
|
||||||
|
+
|
||||||
|
+/**
|
||||||
|
+ * Gets the directory to use for temporary files.
|
||||||
|
+ *
|
||||||
|
+ * Inspired by glib-2.0. If no TMP, TEMP or TMPDIR is set,
|
||||||
|
+ * /var/tmp is returned (Fedora specific).
|
||||||
|
+ *
|
||||||
|
+ * Returns: the directory to use for temporary files.
|
||||||
|
+ */
|
||||||
|
+const char *get_tmp_dir(void)
|
||||||
|
+{
|
||||||
|
+ static gchar *tmp_dir;
|
||||||
|
+
|
||||||
|
+ if (g_once_init_enter(&tmp_dir)) {
|
||||||
|
+ gchar *tmp;
|
||||||
|
+
|
||||||
|
+ tmp = g_strdup(g_getenv("TEMP"));
|
||||||
|
+ if (tmp == NULL || *tmp == '\0') {
|
||||||
|
+ g_free(tmp);
|
||||||
|
+ tmp = g_strdup(g_getenv("TMPDIR"));
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+#ifdef P_tmpdir
|
||||||
|
+ if (tmp == NULL || *tmp == '\0') {
|
||||||
|
+ gsize k;
|
||||||
|
+ g_free(tmp);
|
||||||
|
+ tmp = g_strdup(P_tmpdir);
|
||||||
|
+ k = strlen(tmp);
|
||||||
|
+ if (k > 1 && G_IS_DIR_SEPARATOR(tmp[k - 1]))
|
||||||
|
+ tmp[k - 1] = '\0';
|
||||||
|
+ fprintf(stderr, "Using P_tmpdir: %s\n", P_tmpdir);
|
||||||
|
+ }
|
||||||
|
+#endif /* P_tmpdir */
|
||||||
|
+
|
||||||
|
+ if (tmp == NULL || *tmp == '\0') {
|
||||||
|
+ g_free(tmp);
|
||||||
|
+ tmp = g_strdup("/var/tmp");
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ g_once_init_leave(&tmp_dir, tmp);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return tmp_dir;
|
||||||
|
+}
|
||||||
|
diff --git a/wsutil/wstmpdir.h b/wsutil/wstmpdir.h
|
||||||
|
new file mode 100644
|
||||||
|
index 0000000..07ac583
|
||||||
|
--- /dev/null
|
||||||
|
+++ b/wsutil/wstmpdir.h
|
||||||
|
@@ -0,0 +1,39 @@
|
||||||
|
+/* wstmpdir.c
|
||||||
|
+ *
|
||||||
|
+ * Copyright (C) 2013 Red Hat, Inc. All right reserved.
|
||||||
|
+ *
|
||||||
|
+ * Temporary directory routine
|
||||||
|
+ *
|
||||||
|
+ * This program is free software; you can redistribute it and/or
|
||||||
|
+ * modify it under the terms of the GNU General Public License
|
||||||
|
+ * as published by the Free Software Foundation; either version 2
|
||||||
|
+ * of the License, or (at your option) any later version.
|
||||||
|
+ *
|
||||||
|
+ * This program is distributed in the hope that it will be useful,
|
||||||
|
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
+ * GNU General Public License for more details.
|
||||||
|
+ *
|
||||||
|
+ * You should have received a copy of the GNU General Public License
|
||||||
|
+ * along with this program; if not, write to the Free Software
|
||||||
|
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
+ *
|
||||||
|
+ * Author: Peter Hatina <phatina@redhat.com>
|
||||||
|
+ */
|
||||||
|
+
|
||||||
|
+#ifndef __WS_TMP_DIR_H__
|
||||||
|
+#define __WS_TMP_DIR_H__
|
||||||
|
+
|
||||||
|
+#include "ws_symbol_export.h"
|
||||||
|
+
|
||||||
|
+#ifdef __cplusplus
|
||||||
|
+extern "C" {
|
||||||
|
+#endif // __cplusplus
|
||||||
|
+
|
||||||
|
+WS_DLL_PUBLIC const char *get_tmp_dir(void);
|
||||||
|
+
|
||||||
|
+#ifdef __cplusplus
|
||||||
|
+}
|
||||||
|
+#endif // __cplusplus
|
||||||
|
+
|
||||||
|
+#endif
|
||||||
|
--
|
||||||
|
2.13.0
|
||||||
|
|
20
SOURCES/wireshark-0007-cmakelists.patch
Normal file
20
SOURCES/wireshark-0007-cmakelists.patch
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
diff --git a/wsutil/CMakeLists.txt b/wsutil/CMakeLists.txt
|
||||||
|
index 0367cd1..6382a2c 100644
|
||||||
|
--- a/wsutil/CMakeLists.txt
|
||||||
|
+++ b/wsutil/CMakeLists.txt
|
||||||
|
@@ -69,6 +69,7 @@ set(WSUTIL_PUBLIC_HEADERS
|
||||||
|
ws_mempbrk_int.h
|
||||||
|
ws_pipe.h
|
||||||
|
ws_printf.h
|
||||||
|
+ wstmpdir.h
|
||||||
|
wsjson.h
|
||||||
|
xtea.h
|
||||||
|
)
|
||||||
|
@@ -118,6 +118,7 @@ set(WSUTIL_COMMON_FILES
|
||||||
|
unicode-utils.c
|
||||||
|
ws_mempbrk.c
|
||||||
|
ws_pipe.c
|
||||||
|
+ wstmpdir.c
|
||||||
|
wsgcrypt.c
|
||||||
|
wsjson.c
|
||||||
|
xtea.c
|
1893
SOURCES/wireshark-0009-smc-support.patch
Normal file
1893
SOURCES/wireshark-0009-smc-support.patch
Normal file
File diff suppressed because it is too large
Load Diff
1267
SPECS/wireshark.spec
Normal file
1267
SPECS/wireshark.spec
Normal file
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user