2 # -*- coding: utf-8 -*-
3 ##############################################################################
4 # Copyright (c) 2017 Luke Hinds <lhinds@redhat.com>, Red Hat
6 # All rights reserved. This program and the accompanying materials
7 # are made available under the terms of the Apache License, Version 2.0
8 # which accompanies this distribution, and is available at
9 # http://www.apache.org/licenses/LICENSE-2.0
10 ##############################################################################
13 Gathers various values from the gate check yaml file and return them to the
16 from __future__ import absolute_import
18 import anteater.utils.anteater_logger as antlog
19 import six.moves.configparser
26 config = six.moves.configparser.RawConfigParser()
27 config.read('anteater.conf')
28 logger = antlog.Logger(__name__).getLogger()
29 master_list = config.get('config', 'master_list')
31 with open(master_list, 'r') as f:
32 yl = yaml.safe_load(f)
35 def _remove_nullvalue(contents):
36 if contents and len(contents) > 2 and 'nullvalue' in contents:
37 contents.remove('nullvalue')
41 ret = copy.deepcopy(org)
42 for key in list(set([k for k in org] + [k for k in ded])):
43 if key in org and key in ded:
44 ret[key] = list(set(ret[key] + ded[key]))
45 _remove_nullvalue(ret[key])
51 class GetLists(object):
52 def __init__(self, *args):
53 # Placeholder for future args if more filters are needed
57 def load_project_exception_file(self, project_exceptions, project):
61 for item in project_exceptions:
63 exception_file = item.get(project)
64 if exception_file is not None:
65 with open(exception_file, 'r') as f:
66 ex = yaml.safe_load(f)
69 yl[key][project] = _merge(yl[key][project], ex.get(key, None)) \
70 if project in yl[key] else ex.get(key, None)
73 def binary_list(self, project):
75 default_list = (yl['binaries']['binary_ignore'])
77 logger.error('Key Error processing binary list values')
79 binary_re = re.compile("|".join(default_list),
83 def binary_hash(self, project, patch_file):
84 self.load_project_exception_file(yl.get('project_exceptions'), project)
85 file_name = os.path.basename(patch_file)
87 binary_hash = (yl['binaries'][project][file_name])
90 logger.info('No checksum entries found for {0}'.
96 def file_audit_list(self, project):
98 self.load_project_exception_file(yl.get('project_exceptions'), project)
100 default_list = set((yl['file_audits']['file_names']))
102 logger.error('Key Error processing file_names list values')
104 project_list = set((yl['file_audits'][project]['file_names']))
105 logger.info('file_names waivers found for {0}'.
108 logger.info('No file_names waivers found for {0}'.
111 file_names_re = re.compile("|".join(default_list),
115 file_names_proj_re = re.compile("|".join(project_list),
117 return file_names_re, file_names_proj_re
119 file_names_proj_re = re.compile("")
120 return file_names_re, file_names_proj_re
122 def file_content_list(self, project):
124 self.load_project_exception_file(yl.get('project_exceptions'), project)
126 default_list = set((yl['file_audits']['file_contents']))
128 logger.error('Key Error processing file_contents list values')
130 project_list = set((yl['file_audits'][project]['file_contents']))
132 logger.info('No file_contents waivers found for {0}'.
135 file_contents_re = re.compile("|".join(default_list),
139 file_contents_proj_re = re.compile("|".join(project_list),
141 return file_contents_re, file_contents_proj_re
143 file_contents_proj_re = re.compile("")
144 return file_contents_re, file_contents_proj_re
146 def licence_extensions(self):
148 licence_extensions = (yl['licence']['licence_ext'])
150 logger.error('Key Error processing licence_extensions list values')
151 return licence_extensions
153 def licence_ignore(self):
155 licence_ignore = (yl['licence']['licence_ignore'])
157 logger.error('Key Error processing licence_ignore list values')
158 return licence_ignore