forked from pool/bash-git-prompt
- add use-safe-tempfile.diff: this fixes bsc#1247489 CVE-2025-61659, an
insecure predictable /tmp file usage in bash-git-prompt. OBS-URL: https://build.opensuse.org/package/show/devel:tools:scm/bash-git-prompt?expand=0&rev=8
This commit is contained in:
23
.gitattributes
vendored
Normal file
23
.gitattributes
vendored
Normal file
@@ -0,0 +1,23 @@
|
||||
## Default LFS
|
||||
*.7z filter=lfs diff=lfs merge=lfs -text
|
||||
*.bsp filter=lfs diff=lfs merge=lfs -text
|
||||
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
||||
*.gem filter=lfs diff=lfs merge=lfs -text
|
||||
*.gz filter=lfs diff=lfs merge=lfs -text
|
||||
*.jar filter=lfs diff=lfs merge=lfs -text
|
||||
*.lz filter=lfs diff=lfs merge=lfs -text
|
||||
*.lzma filter=lfs diff=lfs merge=lfs -text
|
||||
*.obscpio filter=lfs diff=lfs merge=lfs -text
|
||||
*.oxt filter=lfs diff=lfs merge=lfs -text
|
||||
*.pdf filter=lfs diff=lfs merge=lfs -text
|
||||
*.png filter=lfs diff=lfs merge=lfs -text
|
||||
*.rpm filter=lfs diff=lfs merge=lfs -text
|
||||
*.tbz filter=lfs diff=lfs merge=lfs -text
|
||||
*.tbz2 filter=lfs diff=lfs merge=lfs -text
|
||||
*.tgz filter=lfs diff=lfs merge=lfs -text
|
||||
*.ttf filter=lfs diff=lfs merge=lfs -text
|
||||
*.txz filter=lfs diff=lfs merge=lfs -text
|
||||
*.whl filter=lfs diff=lfs merge=lfs -text
|
||||
*.xz filter=lfs diff=lfs merge=lfs -text
|
||||
*.zip filter=lfs diff=lfs merge=lfs -text
|
||||
*.zst filter=lfs diff=lfs merge=lfs -text
|
||||
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@@ -0,0 +1 @@
|
||||
.osc
|
||||
3
bash-git-prompt-2.7.1.tar.gz
Normal file
3
bash-git-prompt-2.7.1.tar.gz
Normal file
@@ -0,0 +1,3 @@
|
||||
version https://git-lfs.github.com/spec/v1
|
||||
oid sha256:5e5fc6f5133b65760fede8050d4c3bc8edb8e78bc7ce26c16db442aa94b8a709
|
||||
size 50922
|
||||
26
bash-git-prompt.changes
Normal file
26
bash-git-prompt.changes
Normal file
@@ -0,0 +1,26 @@
|
||||
-------------------------------------------------------------------
|
||||
Mon Sep 22 13:59:46 UTC 2025 - Matthias Gerstner <matthias.gerstner@suse.com>
|
||||
|
||||
- add use-safe-tempfile.diff: this fixes bsc#1247489 CVE-2025-61659, an
|
||||
insecure predictable /tmp file usage in bash-git-prompt.
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Sun May 10 08:51:18 UTC 2020 - Michal Suchanek <msuchanek@suse.com>
|
||||
|
||||
- Add configuration file.
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Mon Feb 24 16:58:27 UTC 2020 - Michal Suchanek <msuchanek@suse.de>
|
||||
|
||||
- Use profile.d instead of editing /etc/bashrc.
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Thu Feb 20 18:06:58 UTC 2020 - Michal Suchanek <msuchanek@suse.de>
|
||||
|
||||
- Version 2.7.1
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Fri Aug 08 00:00:00 UTC 2014 - Justin Zhang <schnell18@gmail.com>
|
||||
|
||||
bash-git-prompt 1.0.1-1
|
||||
- Initial version of package
|
||||
118
bash-git-prompt.spec
Normal file
118
bash-git-prompt.spec
Normal file
@@ -0,0 +1,118 @@
|
||||
#
|
||||
# spec file for package bash-git-prompt
|
||||
#
|
||||
# Copyright (c) 2025 SUSE LLC and contributors
|
||||
#
|
||||
# All modifications and additions to the file contributed by third parties
|
||||
# remain the property of their copyright owners, unless otherwise agreed
|
||||
# upon. The license for this file, and modifications and additions to the
|
||||
# file, is the same license as for the pristine package itself (unless the
|
||||
# license for the pristine package is not an Open Source License, in which
|
||||
# case the license is the MIT License). An "Open Source License" is a
|
||||
# license that conforms to the Open Source Definition (Version 1.9)
|
||||
# published by the Open Source Initiative.
|
||||
|
||||
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
||||
#
|
||||
|
||||
|
||||
%if ! %{defined _fillupdir}
|
||||
%define _fillupdir /var/adm/fillup-templates
|
||||
%endif
|
||||
|
||||
Name: bash-git-prompt
|
||||
Version: 2.7.1
|
||||
Release: 0
|
||||
Summary: Informative git prompt for bash and fish
|
||||
License: BSD-2-Clause
|
||||
Group: Development/Tools/Version Control
|
||||
URL: https://github.com/magicmonty/bash-git-prompt
|
||||
Source0: https://github.com/magicmonty/%{name}/archive/%{version}/%{name}-%{version}.tar.gz
|
||||
Patch0: use-safe-tempfile.diff
|
||||
Requires: git-core
|
||||
Requires(post): %fillup_prereq
|
||||
BuildArch: noarch
|
||||
|
||||
%description
|
||||
A bash prompt that displays information about the current git repository. In particular the branch name, difference with remote branch, number of files staged, changed, etc.
|
||||
|
||||
This package will automatically enable the git prompt for bash after
|
||||
install. It will disable the prompt accordingly after uninstall.
|
||||
|
||||
%prep
|
||||
%setup -q
|
||||
%autopatch -p1
|
||||
|
||||
%build
|
||||
sed -i -e 's,#!/usr/bin/env bash,#!/bin/bash,' $(find . -name \*.sh)
|
||||
|
||||
%install
|
||||
install -dm 755 %{buildroot}%{_datadir}/%{name}
|
||||
install -pm 755 *.sh %{buildroot}%{_datadir}/%{name}
|
||||
#install -pm 755 *.py %{buildroot}%{_datadir}/%{name}
|
||||
install -pm 755 *.fish %{buildroot}%{_datadir}/%{name}
|
||||
install -pm 644 README.md %{buildroot}%{_datadir}/%{name}
|
||||
install -dm 755 %{buildroot}%{_datadir}/%{name}/themes
|
||||
install -pm 644 themes/*.bgptheme %{buildroot}%{_datadir}/%{name}/themes
|
||||
install -pm 644 themes/*.bgptemplate %{buildroot}%{_datadir}/%{name}/themes
|
||||
|
||||
# enable bash-git-prompt
|
||||
mkdir -p %{buildroot}%{_sysconfdir}/profile.d
|
||||
mkdir -p %{buildroot}%{_fillupdir}
|
||||
cat << EOF >> %{buildroot}%{_fillupdir}/sysconfig.%{name}
|
||||
GIT_PROMPT_SYSTEMWIDE_ENABLE=1
|
||||
|
||||
GIT_PROMPT_ONLY_IN_REPO=1
|
||||
|
||||
# GIT_PROMPT_FETCH_REMOTE_STATUS=0 # uncomment to avoid fetching remote status
|
||||
# GIT_PROMPT_IGNORE_SUBMODULES=1 # uncomment to avoid searching for changed files in submodules
|
||||
|
||||
# GIT_PROMPT_SHOW_UPSTREAM=1 # uncomment to show upstream tracking branch
|
||||
# GIT_PROMPT_SHOW_UNTRACKED_FILES=all # can be no, normal or all; determines counting of untracked files
|
||||
# Set to `no` or `normal` to speed things up if you have lots of
|
||||
# untracked files in your repository. This can be the case for
|
||||
# build systems that put their build artifacts in the subdirectory
|
||||
# structure of the git repository.
|
||||
|
||||
# GIT_PROMPT_SHOW_CHANGED_FILES_COUNT=0 # uncomment to avoid printing the number of changed files
|
||||
|
||||
# GIT_PROMPT_STATUS_COMMAND=gitstatus_pre-1.7.10.sh # uncomment to support Git older than 1.7.10
|
||||
|
||||
# GIT_PROMPT_START=... # uncomment for custom prompt start sequence
|
||||
# GIT_PROMPT_END=... # uncomment for custom prompt end sequence
|
||||
|
||||
# Color curtomization
|
||||
GIT_PROMPT_THEME=Default
|
||||
# GIT_PROMPT_THEME=Custom # use custom theme specified in file GIT_PROMPT_THEME_FILE (default ~/.git-prompt-colors.sh)
|
||||
# GIT_PROMPT_THEME_FILE=~/.git-prompt-colors.sh
|
||||
# GIT_PROMPT_THEME=Solarized # use theme optimized for solarized color scheme
|
||||
EOF
|
||||
|
||||
cat << EOF >> %{buildroot}%{_sysconfdir}/profile.d/%{name}.sh
|
||||
if [ -n "\${BASH_VERSION-}" ] && [ -f %{_datadir}/%{name}/gitprompt.sh ]; then
|
||||
# Set config variables first
|
||||
[ -f %{_sysconfdir}/sysconfig/%{name} ] && source %{_sysconfdir}/sysconfig/%{name}
|
||||
|
||||
[ "\${GIT_PROMPT_SYSTEMWIDE_ENABLE}" = 1 ] && source %{_datadir}/%{name}/gitprompt.sh
|
||||
fi
|
||||
EOF
|
||||
|
||||
%pre
|
||||
|
||||
%post
|
||||
%fillup_only
|
||||
|
||||
%preun
|
||||
|
||||
%postun
|
||||
|
||||
%files
|
||||
%{_datadir}/%{name}
|
||||
%{_sysconfdir}/profile.d/%{name}.sh
|
||||
%{_fillupdir}/sysconfig.%{name}
|
||||
|
||||
%doc README.md
|
||||
|
||||
%license LICENSE.txt
|
||||
|
||||
%changelog
|
||||
27
use-safe-tempfile.diff
Normal file
27
use-safe-tempfile.diff
Normal file
@@ -0,0 +1,27 @@
|
||||
Index: bash-git-prompt-2.7.1/gitprompt.sh
|
||||
===================================================================
|
||||
--- bash-git-prompt-2.7.1.orig/gitprompt.sh
|
||||
+++ bash-git-prompt-2.7.1/gitprompt.sh
|
||||
@@ -466,8 +466,11 @@ function createPrivateIndex {
|
||||
else
|
||||
__GIT_INDEX_FILE="$GIT_INDEX_FILE"
|
||||
fi
|
||||
- __GIT_INDEX_PRIVATE="/tmp/git-index-private$$"
|
||||
+ __GIT_INDEX_PRIVATE=`mktemp "/tmp/git-index-private-$$.XXXX"`
|
||||
command cp "$__GIT_INDEX_FILE" "$__GIT_INDEX_PRIVATE" 2>/dev/null
|
||||
+ if [ $? -ne 0 ]; then
|
||||
+ return
|
||||
+ fi
|
||||
echo "$__GIT_INDEX_PRIVATE"
|
||||
}
|
||||
|
||||
@@ -500,6 +503,9 @@ function updatePrompt() {
|
||||
local GIT_INDEX_PRIVATE="$(createPrivateIndex)"
|
||||
#important to define GIT_INDEX_FILE as local: This way it only affects this function (and below) - even with the export afterwards
|
||||
local GIT_INDEX_FILE
|
||||
+ if [ -z "$GIT_INDEX_PRIVATE" ]; then
|
||||
+ return
|
||||
+ fi
|
||||
export GIT_INDEX_FILE="$GIT_INDEX_PRIVATE"
|
||||
|
||||
local -a git_status_fields
|
||||
Reference in New Issue
Block a user