e650d58583
When trying to identify various RedHat releases, RHEL was not being picked up as a centos release because the Oracle Linux regex was too permissive: it would match any release name with '<something> Linux Server release' in the name. By being more restrictive with the Oracle regex, RHEL is now properly identified. I don't know why the Oracle regex used such a permissive matcher for the name but it still passes all the tests by replacing it with the word 'Oracle'. Fixes #436
88 lines
2.6 KiB
Go
88 lines
2.6 KiB
Go
// Copyright 2017 clair authors
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
// Package redhatrelease implements a featurens.Detector for container image
|
|
// layers containing an redhat-release-like files.
|
|
//
|
|
// This detector is typically useful for detecting CentOS and Red-Hat like
|
|
// systems.
|
|
package redhatrelease
|
|
|
|
import (
|
|
"regexp"
|
|
"strings"
|
|
|
|
"github.com/coreos/clair/database"
|
|
"github.com/coreos/clair/ext/featurens"
|
|
"github.com/coreos/clair/ext/versionfmt/rpm"
|
|
"github.com/coreos/clair/pkg/tarutil"
|
|
)
|
|
|
|
var (
|
|
oracleReleaseRegexp = regexp.MustCompile(`(?P<os>Oracle) (Linux Server release) (?P<version>[\d]+)`)
|
|
centosReleaseRegexp = regexp.MustCompile(`(?P<os>[^\s]*) (Linux release|release) (?P<version>[\d]+)`)
|
|
redhatReleaseRegexp = regexp.MustCompile(`(?P<os>Red Hat Enterprise Linux) (Client release|Server release|Workstation release) (?P<version>[\d]+)`)
|
|
)
|
|
|
|
type detector struct{}
|
|
|
|
func init() {
|
|
featurens.RegisterDetector("redhat-release", &detector{})
|
|
}
|
|
|
|
func (d detector) Detect(files tarutil.FilesMap) (*database.Namespace, error) {
|
|
for _, filePath := range d.RequiredFilenames() {
|
|
f, hasFile := files[filePath]
|
|
if !hasFile {
|
|
continue
|
|
}
|
|
|
|
var r []string
|
|
|
|
// Attempt to match Oracle Linux.
|
|
r = oracleReleaseRegexp.FindStringSubmatch(string(f))
|
|
if len(r) == 4 {
|
|
return &database.Namespace{
|
|
Name: strings.ToLower(r[1]) + ":" + r[3],
|
|
VersionFormat: rpm.ParserName,
|
|
}, nil
|
|
}
|
|
|
|
// Attempt to match RHEL.
|
|
r = redhatReleaseRegexp.FindStringSubmatch(string(f))
|
|
if len(r) == 4 {
|
|
// TODO(vbatts): this is a hack until https://github.com/coreos/clair/pull/193
|
|
return &database.Namespace{
|
|
Name: "centos" + ":" + r[3],
|
|
VersionFormat: rpm.ParserName,
|
|
}, nil
|
|
}
|
|
|
|
// Atempt to match CentOS.
|
|
r = centosReleaseRegexp.FindStringSubmatch(string(f))
|
|
if len(r) == 4 {
|
|
return &database.Namespace{
|
|
Name: strings.ToLower(r[1]) + ":" + r[3],
|
|
VersionFormat: rpm.ParserName,
|
|
}, nil
|
|
}
|
|
}
|
|
|
|
return nil, nil
|
|
}
|
|
|
|
func (d detector) RequiredFilenames() []string {
|
|
return []string{"etc/oracle-release", "etc/centos-release", "etc/redhat-release", "etc/system-release"}
|
|
}
|