mirror of
https://github.com/saltstack/salt.git
synced 2025-04-17 10:10:20 +00:00
backport salt.utils.pkg.rpm to 2015.5
This commit is contained in:
parent
a1ad14994a
commit
50befbc149
2 changed files with 106 additions and 0 deletions
4
salt/utils/pkg/__init__.py
Normal file
4
salt/utils/pkg/__init__.py
Normal file
|
@ -0,0 +1,4 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
'''
|
||||
Helper modules used by lowpkg modules
|
||||
'''
|
102
salt/utils/pkg/rpm.py
Normal file
102
salt/utils/pkg/rpm.py
Normal file
|
@ -0,0 +1,102 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
'''
|
||||
Common functions for working with RPM packages
|
||||
'''
|
||||
|
||||
# Import python libs
|
||||
from __future__ import absolute_import
|
||||
import collections
|
||||
import logging
|
||||
|
||||
# Import salt libs
|
||||
from salt._compat import subprocess
|
||||
|
||||
log = logging.getLogger(__name__)
|
||||
|
||||
# These arches compiled from the rpmUtils.arch python module source
|
||||
ARCHES_64 = ('x86_64', 'athlon', 'amd64', 'ia32e', 'ia64', 'geode')
|
||||
ARCHES_32 = ('i386', 'i486', 'i586', 'i686')
|
||||
ARCHES_PPC = ('ppc', 'ppc64', 'ppc64iseries', 'ppc64pseries')
|
||||
ARCHES_S390 = ('s390', 's390x')
|
||||
ARCHES_SPARC = (
|
||||
'sparc', 'sparcv8', 'sparcv9', 'sparcv9v', 'sparc64', 'sparc64v'
|
||||
)
|
||||
ARCHES_ALPHA = (
|
||||
'alpha', 'alphaev4', 'alphaev45', 'alphaev5', 'alphaev56',
|
||||
'alphapca56', 'alphaev6', 'alphaev67', 'alphaev68', 'alphaev7'
|
||||
)
|
||||
ARCHES_ARM = ('armv5tel', 'armv5tejl', 'armv6l', 'armv7l')
|
||||
ARCHES_SH = ('sh3', 'sh4', 'sh4a')
|
||||
|
||||
ARCHES = ARCHES_64 + ARCHES_32 + ARCHES_PPC + ARCHES_S390 + \
|
||||
ARCHES_ALPHA + ARCHES_ARM + ARCHES_SH
|
||||
|
||||
# EPOCHNUM can't be used until RHEL5 is EOL as it is not present
|
||||
QUERYFORMAT = '%{NAME}_|-%{EPOCH}_|-%{VERSION}_|-%{RELEASE}_|-%{ARCH}_|-%{REPOID}'
|
||||
|
||||
|
||||
def get_osarch():
|
||||
'''
|
||||
Get the os architecture using rpm --eval
|
||||
'''
|
||||
ret = subprocess.Popen(
|
||||
'rpm --eval "%{_host_cpu}"',
|
||||
shell=True,
|
||||
close_fds=True,
|
||||
stdout=subprocess.PIPE,
|
||||
stderr=subprocess.PIPE).communicate()[0]
|
||||
return ret or 'unknown'
|
||||
|
||||
|
||||
def check_32(arch, osarch=None):
|
||||
'''
|
||||
Returns True if both the OS arch and the passed arch are 32-bit
|
||||
'''
|
||||
if osarch is None:
|
||||
osarch = get_osarch()
|
||||
return all(x in ARCHES_32 for x in (osarch, arch))
|
||||
|
||||
|
||||
def pkginfo(name, version, arch, repoid):
|
||||
'''
|
||||
Build and return a pkginfo namedtuple
|
||||
'''
|
||||
pkginfo_tuple = collections.namedtuple(
|
||||
'PkgInfo',
|
||||
('name', 'version', 'arch', 'repoid')
|
||||
)
|
||||
return pkginfo_tuple(name, version, arch, repoid)
|
||||
|
||||
|
||||
def resolve_name(name, arch, osarch=None):
|
||||
'''
|
||||
Resolve the package name and arch into a unique name referred to by salt.
|
||||
For example, on a 64-bit OS, a 32-bit package will be pkgname.i386.
|
||||
'''
|
||||
if osarch is None:
|
||||
osarch = get_osarch()
|
||||
|
||||
if not check_32(arch, osarch) and arch not in (osarch, 'noarch'):
|
||||
name += '.{0}'.format(arch)
|
||||
return name
|
||||
|
||||
|
||||
def parse_pkginfo(line, osarch=None):
|
||||
'''
|
||||
A small helper to parse an rpm/repoquery command's output. Returns a
|
||||
pkginfo namedtuple.
|
||||
'''
|
||||
try:
|
||||
name, epoch, version, release, arch, repoid = line.split('_|-')
|
||||
# Handle unpack errors (should never happen with the queryformat we are
|
||||
# using, but can't hurt to be careful).
|
||||
except ValueError:
|
||||
return None
|
||||
|
||||
name = resolve_name(name, arch, osarch)
|
||||
if release:
|
||||
version += '-{0}'.format(release)
|
||||
if epoch not in ('(none)', '0'):
|
||||
version = ':'.join((epoch, version))
|
||||
|
||||
return pkginfo(name, version, arch, repoid)
|
Loading…
Add table
Reference in a new issue