2021-01-08 13:41:50 +01:00
|
|
|
From 67e8afba4c33e65470dae3e39908868620f3ed11 Mon Sep 17 00:00:00 2001
|
2019-09-06 14:06:25 +02:00
|
|
|
From: Jochen Breuer <jbreuer@suse.de>
|
|
|
|
Date: Fri, 30 Aug 2019 14:20:06 +0200
|
|
|
|
Subject: [PATCH] Restore default behaviour of pkg list return
|
|
|
|
|
|
|
|
The default behaviour for pkg list return was to not include patches,
|
|
|
|
even when installing patches. Only the packages where returned. There
|
|
|
|
is now parameter to also return patches if that is needed.
|
|
|
|
|
|
|
|
Co-authored-by: Mihai Dinca <mdinca@suse.de>
|
|
|
|
---
|
2021-01-08 13:41:50 +01:00
|
|
|
salt/modules/zypperpkg.py | 38 ++++++++++++++++++++++++++------------
|
|
|
|
1 file changed, 26 insertions(+), 12 deletions(-)
|
2019-09-06 14:06:25 +02:00
|
|
|
|
|
|
|
diff --git a/salt/modules/zypperpkg.py b/salt/modules/zypperpkg.py
|
2021-01-08 13:41:50 +01:00
|
|
|
index b099f3e5d7..2daec0f380 100644
|
2019-09-06 14:06:25 +02:00
|
|
|
--- a/salt/modules/zypperpkg.py
|
|
|
|
+++ b/salt/modules/zypperpkg.py
|
2021-01-08 13:41:50 +01:00
|
|
|
@@ -1422,10 +1422,10 @@ def refresh_db(force=None, root=None):
|
2019-09-06 14:06:25 +02:00
|
|
|
return ret
|
|
|
|
|
|
|
|
|
|
|
|
-def _find_types(pkgs):
|
2021-01-08 13:41:50 +01:00
|
|
|
- """
|
|
|
|
- Form a package names list, find prefixes of packages types.
|
|
|
|
- """
|
2019-09-06 14:06:25 +02:00
|
|
|
+def _detect_includes(pkgs, inclusion_detection):
|
2021-01-08 13:41:50 +01:00
|
|
|
+ """Form a package names list, find prefixes of packages types."""
|
2019-09-06 14:06:25 +02:00
|
|
|
+ if not inclusion_detection:
|
|
|
|
+ return None
|
2021-01-08 13:41:50 +01:00
|
|
|
return sorted({pkg.split(":", 1)[0] for pkg in pkgs if len(pkg.split(":", 1)) == 2})
|
|
|
|
|
|
|
|
|
|
|
|
@@ -1441,6 +1441,7 @@ def install(
|
|
|
|
ignore_repo_failure=False,
|
|
|
|
no_recommends=False,
|
|
|
|
root=None,
|
|
|
|
+ inclusion_detection=False,
|
|
|
|
**kwargs
|
|
|
|
):
|
|
|
|
"""
|
|
|
|
@@ -1556,6 +1557,9 @@ def install(
|
2019-09-06 14:06:25 +02:00
|
|
|
|
|
|
|
.. versionadded:: 2018.3.0
|
|
|
|
|
|
|
|
+ inclusion_detection:
|
|
|
|
+ Detect ``includes`` based on ``sources``
|
|
|
|
+ By default packages are always included
|
|
|
|
|
|
|
|
Returns a dict containing the new package names and versions::
|
|
|
|
|
2021-01-08 13:41:50 +01:00
|
|
|
@@ -1626,7 +1630,8 @@ def install(
|
2019-09-06 14:06:25 +02:00
|
|
|
|
|
|
|
diff_attr = kwargs.get("diff_attr")
|
|
|
|
|
|
|
|
- includes = _find_types(targets)
|
|
|
|
+ includes = _detect_includes(targets, inclusion_detection)
|
|
|
|
+
|
2021-01-08 13:41:50 +01:00
|
|
|
old = (
|
|
|
|
list_pkgs(attr=diff_attr, root=root, includes=includes)
|
|
|
|
if not downloadonly
|
|
|
|
@@ -1850,7 +1855,7 @@ def upgrade(
|
2019-09-06 14:06:25 +02:00
|
|
|
return ret
|
|
|
|
|
|
|
|
|
|
|
|
-def _uninstall(name=None, pkgs=None, root=None):
|
|
|
|
+def _uninstall(inclusion_detection, name=None, pkgs=None, root=None):
|
2021-01-08 13:41:50 +01:00
|
|
|
"""
|
2019-09-06 14:06:25 +02:00
|
|
|
Remove and purge do identical things but with different Zypper commands,
|
|
|
|
this function performs the common logic.
|
2021-01-08 13:41:50 +01:00
|
|
|
@@ -1860,7 +1865,7 @@ def _uninstall(name=None, pkgs=None, root=None):
|
2019-09-06 14:06:25 +02:00
|
|
|
except MinionError as exc:
|
|
|
|
raise CommandExecutionError(exc)
|
|
|
|
|
|
|
|
- includes = _find_types(pkg_params.keys())
|
|
|
|
+ includes = _detect_includes(pkg_params.keys(), inclusion_detection)
|
|
|
|
old = list_pkgs(root=root, includes=includes)
|
|
|
|
targets = []
|
|
|
|
for target in pkg_params:
|
2021-01-08 13:41:50 +01:00
|
|
|
@@ -1923,7 +1928,7 @@ def normalize_name(name):
|
2019-09-06 14:06:25 +02:00
|
|
|
|
|
|
|
|
2021-01-08 13:41:50 +01:00
|
|
|
def remove(
|
|
|
|
- name=None, pkgs=None, root=None, **kwargs
|
|
|
|
+ name=None, pkgs=None, root=None, inclusion_detection=False, **kwargs
|
|
|
|
): # pylint: disable=unused-argument
|
|
|
|
"""
|
2019-09-06 14:06:25 +02:00
|
|
|
.. versionchanged:: 2015.8.12,2016.3.3,2016.11.0
|
2021-01-08 13:41:50 +01:00
|
|
|
@@ -1955,8 +1960,11 @@ def remove(
|
2019-09-06 14:06:25 +02:00
|
|
|
root
|
|
|
|
Operate on a different root directory.
|
|
|
|
|
|
|
|
- .. versionadded:: 0.16.0
|
|
|
|
+ inclusion_detection:
|
|
|
|
+ Detect ``includes`` based on ``pkgs``
|
|
|
|
+ By default packages are always included
|
|
|
|
|
|
|
|
+ .. versionadded:: 0.16.0
|
|
|
|
|
|
|
|
Returns a dict containing the changes.
|
|
|
|
|
2021-01-08 13:41:50 +01:00
|
|
|
@@ -1968,10 +1976,12 @@ def remove(
|
2019-09-06 14:06:25 +02:00
|
|
|
salt '*' pkg.remove <package1>,<package2>,<package3>
|
|
|
|
salt '*' pkg.remove pkgs='["foo", "bar"]'
|
2021-01-08 13:41:50 +01:00
|
|
|
"""
|
2019-09-06 14:06:25 +02:00
|
|
|
- return _uninstall(name=name, pkgs=pkgs, root=root)
|
|
|
|
+ return _uninstall(inclusion_detection, name=name, pkgs=pkgs, root=root)
|
|
|
|
|
|
|
|
|
|
|
|
-def purge(name=None, pkgs=None, root=None, **kwargs): # pylint: disable=unused-argument
|
2021-01-08 13:41:50 +01:00
|
|
|
+def purge(
|
|
|
|
+ name=None, pkgs=None, root=None, inclusion_detection=False, **kwargs
|
|
|
|
+): # pylint: disable=unused-argument
|
|
|
|
"""
|
2019-09-06 14:06:25 +02:00
|
|
|
.. versionchanged:: 2015.8.12,2016.3.3,2016.11.0
|
|
|
|
On minions running systemd>=205, `systemd-run(1)`_ is now used to
|
2021-01-08 13:41:50 +01:00
|
|
|
@@ -2003,6 +2013,10 @@ def purge(name=None, pkgs=None, root=None, **kwargs): # pylint: disable=unused-
|
2019-09-06 14:06:25 +02:00
|
|
|
root
|
|
|
|
Operate on a different root directory.
|
|
|
|
|
|
|
|
+ inclusion_detection:
|
|
|
|
+ Detect ``includes`` based on ``pkgs``
|
|
|
|
+ By default packages are always included
|
|
|
|
+
|
|
|
|
.. versionadded:: 0.16.0
|
|
|
|
|
|
|
|
|
2021-01-08 13:41:50 +01:00
|
|
|
@@ -2016,7 +2030,7 @@ def purge(name=None, pkgs=None, root=None, **kwargs): # pylint: disable=unused-
|
2019-09-06 14:06:25 +02:00
|
|
|
salt '*' pkg.purge <package1>,<package2>,<package3>
|
|
|
|
salt '*' pkg.purge pkgs='["foo", "bar"]'
|
2021-01-08 13:41:50 +01:00
|
|
|
"""
|
2019-09-06 14:06:25 +02:00
|
|
|
- return _uninstall(name=name, pkgs=pkgs, root=root)
|
|
|
|
+ return _uninstall(inclusion_detection, name=name, pkgs=pkgs, root=root)
|
|
|
|
|
|
|
|
|
|
|
|
def list_locks(root=None):
|
|
|
|
--
|
2021-01-08 13:41:50 +01:00
|
|
|
2.29.2
|
2019-09-06 14:06:25 +02:00
|
|
|
|
|
|
|
|