SHA256
1
0
forked from pool/rpmlint

Accepting request 52161 from Base:System

Accepted submit request 52161 from user lnussel

OBS-URL: https://build.opensuse.org/request/show/52161
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/rpmlint?expand=0&rev=76
This commit is contained in:
Ruediger Oertel 2010-11-05 15:07:58 +00:00 committed by Git OBS Bridge
parent ce35cfa97a
commit b2da5d3790
7 changed files with 139 additions and 13 deletions

View File

@ -11,6 +11,7 @@ import AbstractCheck
import re import re
import os import os
import string import string
import rpm
_permissions_d_whitelist = ( _permissions_d_whitelist = (
"lprng", "lprng",
@ -37,15 +38,34 @@ class SUIDCheck(AbstractCheck.AbstractCheck):
self._parsefile(file) self._parsefile(file)
def _parsefile(self,file): def _parsefile(self,file):
lnr = 0
lastfn = None
for line in open(file): for line in open(file):
lnr+=1
line = line.split('#')[0].split('\n')[0] line = line.split('#')[0].split('\n')[0]
if len(line): line = line.lstrip()
line = re.split(r'\s+', line) if not len(line):
continue
if line.startswith("+capabilities "):
line = line[len("+capabilities "):]
if lastfn:
self.perms[lastfn]['fscaps'] = line
continue
line = re.split(r'\s+', line)
if len(line) == 3:
fn = line[0] fn = line[0]
owner = line[1].replace('.', ':') owner = line[1].replace('.', ':')
mode = line[2] mode = line[2]
self.perms[fn] = { "owner" : owner, "mode" : int(mode,8)&07777} self.perms[fn] = { "owner" : owner, "mode" : int(mode,8)&07777}
# for permissions that don't change and therefore
# don't need special handling
if file == '/etc/permissions':
self.perms[fn]['static'] = True
else:
print >>sys.stderr, "invalid line %d " % lnr
def check(self, pkg): def check(self, pkg):
global _permissions_d_whitelist global _permissions_d_whitelist
@ -78,10 +98,16 @@ class SUIDCheck(AbstractCheck.AbstractCheck):
else: else:
self._parsefile(f) self._parsefile(f)
need_run_permissions = False
# second pass, find permissions violations # second pass, find permissions violations
for f, pkgfile in files.items(): for f, pkgfile in files.items():
if f in pkg.ghostFiles(): if f in pkg.ghostFiles():
continue continue
if pkgfile.filecaps:
printError(pkg, 'permissions-fscaps', '%(file)s has fscaps "%(caps)s"' % \
{ 'file':f, 'caps':pkgfile.filecaps})
mode = pkgfile.mode mode = pkgfile.mode
owner = pkgfile.user+':'+pkgfile.group owner = pkgfile.user+':'+pkgfile.group
@ -94,11 +120,14 @@ class SUIDCheck(AbstractCheck.AbstractCheck):
# S_IFIFO 001 FIFO # S_IFIFO 001 FIFO
type = (mode>>12)&017; type = (mode>>12)&017;
mode &= 07777 mode &= 07777
need_verifyscript = False
if f in self.perms or (type == 04 and f+"/" in self.perms): if f in self.perms or (type == 04 and f+"/" in self.perms):
if type == 012: if type == 012:
printWarning(pkg, "permissions-symlink", f) printWarning(pkg, "permissions-symlink", f)
continue continue
need_verifyscript = True
m = 0 m = 0
o = "invalid" o = "invalid"
if type == 04: if type == 04:
@ -124,6 +153,7 @@ class SUIDCheck(AbstractCheck.AbstractCheck):
printWarning(pkg, 'permissions-file-as-dir', f+' is a file but listed as directory') printWarning(pkg, 'permissions-file-as-dir', f+' is a file but listed as directory')
if mode&06000: if mode&06000:
need_verifyscript = True
msg = '%(file)s is packaged with setuid/setgid bits (0%(mode)o)' % { 'file':f, 'mode':mode } msg = '%(file)s is packaged with setuid/setgid bits (0%(mode)o)' % { 'file':f, 'mode':mode }
if type != 04: if type != 04:
printError(pkg, 'permissions-file-setuid-bit', msg) printError(pkg, 'permissions-file-setuid-bit', msg)
@ -131,10 +161,29 @@ class SUIDCheck(AbstractCheck.AbstractCheck):
printWarning(pkg, 'permissions-directory-setuid-bit', msg) printWarning(pkg, 'permissions-directory-setuid-bit', msg)
if mode&02: if mode&02:
need_verifyscript = True
printError(pkg, 'permissions-world-writable', \ printError(pkg, 'permissions-world-writable', \
'%(file)s is packaged with world writable permissions (0%(mode)o)' % \ '%(file)s is packaged with world writable permissions (0%(mode)o)' % \
{ 'file':f, 'mode':mode }) { 'file':f, 'mode':mode })
if need_verifyscript and \
(not f in self.perms or not 'static' in self.perms[f]):
need_run_permissions = True
script = pkg[rpm.RPMTAG_VERIFYSCRIPT] or pkg[rpm.RPMTAG_VERIFYSCRIPTPROG]
if not script or not "chkstat -n -e %s"%f in script:
printError(pkg, 'permissions-missing-verifyscript', \
"missing %%verify_permissions -e %s" % f)
if need_run_permissions:
postin = pkg[rpm.RPMTAG_POSTIN] or pkg[rpm.RPMTAG_POSTINPROG]
if not postin or not "SuSEconfig --module permissions" in postin:
printError(pkg, 'permissions-missing-postin', \
"missing %run_permissions in %post")
if not 'permissions' in map(lambda x: x[0], pkg.prereq()):
printError(pkg, 'permissions-missing-requires', \
"missing 'permissions' in PreReq")
check=SUIDCheck() check=SUIDCheck()
@ -171,4 +220,15 @@ security team""",
"""If the package is intended for inclusion in any SUSE product """If the package is intended for inclusion in any SUSE product
please open a bug report to request review of the package by the please open a bug report to request review of the package by the
security team""", security team""",
'permissions-fscaps',
"""Packaging file capabilities is currently not supported. Please
use normal permissions instead. You may contact the security team to
request an entry that sets capabilities in /etc/permissions
instead.""",
'permissions-missing-postin',
"""Please add %run_permissions to %post""",
'permissions-missing-requires',
"""Please add \"PreReq: permissions\"""",
'permissions-missing-verifyscript',
"""Please add a %verifyscript section""",
) )

View File

@ -1,3 +0,0 @@
version https://git-lfs.github.com/spec/v1
oid sha256:452c65f114d445051c400d1a57e48061609fe2946dccda6d3ac52ffa425d2808
size 123463

3
rpmlint-1.0.tar.bz2 Normal file
View File

@ -0,0 +1,3 @@
version https://git-lfs.github.com/spec/v1
oid sha256:504ea4212812993b19de3e12dffb9bbe0cd9dac9e46f7c55760428f1bc77b814
size 123667

44
rpmlint-fscaps.diff Normal file
View File

@ -0,0 +1,44 @@
From 1300bf63e4f5e345329b040e3ccd982c02ee35bd Mon Sep 17 00:00:00 2001
From: Ludwig Nussel <ludwig.nussel@suse.de>
Date: Wed, 3 Nov 2010 16:57:00 +0100
Subject: [PATCH] make file capabilities available in PkgFile
---
Pkg.py | 7 +++++++
1 files changed, 7 insertions(+), 0 deletions(-)
diff --git a/Pkg.py b/Pkg.py
index 73bd0ba..a2c864d 100644
--- a/Pkg.py
+++ b/Pkg.py
@@ -603,6 +603,10 @@ class Pkg:
provides = self.header[rpm.RPMTAG_FILEPROVIDE]
files = self.header[rpm.RPMTAG_FILENAMES]
magics = self.header[rpm.RPMTAG_FILECLASS]
+ try:
+ filecaps = self.header[rpm.RPMTAG_FILECAPS]
+ except:
+ filecaps = None
# rpm-python < 4.6 does not return a list for this (or FILEDEVICES,
# FWIW) for packages containing exactly one file
@@ -629,6 +633,8 @@ class Pkg:
pkgfile.requires = parse_deps(requires[idx])
pkgfile.provides = parse_deps(provides[idx])
pkgfile.lang = langs[idx]
+ if filecaps:
+ pkgfile.filecaps = filecaps[idx]
pkgfile.magic = magics[idx]
if not pkgfile.magic and _magic:
pkgfile.magic = _magic.file(pkgfile.path)
@@ -806,6 +812,7 @@ class PkgFile(object):
self.provides = []
self.lang = ''
self.magic = ''
+ self.filecaps = None
# TODO: decompression support
--
1.7.1

View File

@ -1,3 +1,21 @@
-------------------------------------------------------------------
Thu Nov 4 14:20:41 UTC 2010 - lnussel@suse.de
- enable suse-hide-unstripped-outside-build.diff again
-------------------------------------------------------------------
Thu Nov 4 13:35:33 UTC 2010 - lnussel@suse.de
- check for file system capabilities
- check for %verifyscript and %run_permissions
-------------------------------------------------------------------
Wed Nov 3 10:48:30 CET 2010 - dmueller@suse.de
- update to 1.0:
* add support for PEP 3147 when handling python bytecode
* various doc improvements
------------------------------------------------------------------- -------------------------------------------------------------------
Fri Oct 29 07:23:39 UTC 2010 - lnussel@suse.de Fri Oct 29 07:23:39 UTC 2010 - lnussel@suse.de

View File

@ -22,8 +22,8 @@
Name: rpmlint Name: rpmlint
BuildRequires: rpm-python BuildRequires: rpm-python
Summary: Rpm correctness checker Summary: Rpm correctness checker
Version: 0.99 Version: 1.0
Release: 5 Release: 1
Source0: %{name}-%{version}.tar.bz2 Source0: %{name}-%{version}.tar.bz2
Source1: config Source1: config
Source1001: config.in Source1001: config.in
@ -117,6 +117,7 @@ Patch75: stricter-interpreter-check.diff
Patch76: confusing-invalid-spec-name.patch Patch76: confusing-invalid-spec-name.patch
Patch77: rpmlint-pkg-quoting.diff Patch77: rpmlint-pkg-quoting.diff
Patch78: suse-g-ir-chech.diff Patch78: suse-g-ir-chech.diff
Patch79: rpmlint-fscaps.diff
%py_requires %py_requires
%description %description
@ -148,7 +149,7 @@ Authors:
%patch13 %patch13
%patch14 %patch14
%patch17 %patch17
#%patch18 %patch18
%patch19 %patch19
%patch20 %patch20
%patch22 %patch22
@ -190,6 +191,7 @@ Authors:
%patch76 -p1 %patch76 -p1
%patch77 %patch77
%patch78 %patch78
%patch79 -p1
cp -p %{SOURCE1} . cp -p %{SOURCE1} .
cp -p %{SOURCE2} . cp -p %{SOURCE2} .
cp -p %{SOURCE3} . cp -p %{SOURCE3} .

View File

@ -1,4 +1,6 @@
--- BinariesCheck.py Index: BinariesCheck.py
===================================================================
--- BinariesCheck.py.orig
+++ BinariesCheck.py +++ BinariesCheck.py
@@ -10,6 +10,7 @@ @@ -10,6 +10,7 @@
@ -8,18 +10,18 @@
import rpm import rpm
@@ -283,7 +284,9 @@ @@ -284,7 +285,9 @@ class BinariesCheck(AbstractCheck.Abstra
continue continue
# stripped ? # stripped ?
- if 'not stripped' in pkgfile.magic: - if 'not stripped' in pkgfile.magic:
+ if 'not stripped' in pkgfile.magic and \ + if 'not stripped' in pkgfile.magic and \
+ (os.environ.get('BUILD_DIR', None) == None or + (os.environ.get('BUILD_DIR', '') == '' or
+ os.environ.get('BUILD_DEBUG', None) != None): + os.environ.get('BUILD_DEBUG', '') != ''):
printWarning(pkg, 'unstripped-binary-or-object', fname) printWarning(pkg, 'unstripped-binary-or-object', fname)
# inspect binary file # inspect binary file
@@ -580,6 +583,12 @@ @@ -581,6 +584,12 @@ form, make sure that rpmbuild does not s
that use prelink, make sure that prelink does not strip it either, usually by that use prelink, make sure that prelink does not strip it either, usually by
placing a blacklist file in /etc/prelink.conf.d. For more information, see placing a blacklist file in /etc/prelink.conf.d. For more information, see
http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=256900#49''', http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=256900#49''',