Skip to content
This repository has been archived by the owner on Jun 24, 2022. It is now read-only.

Commit

Permalink
Merge pull request #619 from jmlrt/fix-attribute-error
Browse files Browse the repository at this point in the history
[python] fix AttributeError + format code with black
  • Loading branch information
jmlrt authored Oct 4, 2019
2 parents 0f132c9 + c90e17c commit 3e9e7be
Showing 1 changed file with 41 additions and 23 deletions.
64 changes: 41 additions & 23 deletions filter_plugins/custom.py
Original file line number Diff line number Diff line change
@@ -1,57 +1,75 @@
__author__ = 'dale mcdiarmid'
__author__ = "dale mcdiarmid"

import re
import os.path
from six import string_types

def modify_list(values=[], pattern='', replacement='', ignorecase=False):
''' Perform a `re.sub` on every item in the list'''

def modify_list(values=[], pattern="", replacement="", ignorecase=False):
""" Perform a `re.sub` on every item in the list"""
if ignorecase:
flags = re.I
else:
flags = 0
_re = re.compile(pattern, flags=flags)
return [_re.sub(replacement, value) for value in values]

def append_to_list(values=[], suffix=''):

def append_to_list(values=[], suffix=""):
if isinstance(values, string_types):
values = values.split(',')
return [str(value+suffix) for value in values]
values = values.split(",")
return [str(value + suffix) for value in values]

def array_to_str(values=[],separator=','):

def array_to_str(values=[], separator=","):
return separator.join(values)

def extract_role_users(users={},exclude_users=[]):
role_users=[]
for user,details in users.iteritems():

def extract_role_users(users={}, exclude_users=[]):
role_users = []
for user, details in users.items():
if user not in exclude_users and "roles" in details:
for role in details["roles"]:
role_users.append(role+":"+user)
role_users.append(role + ":" + user)
return role_users

def filename(filename=''):

def filename(filename=""):
return os.path.splitext(os.path.basename(filename))[0]


def remove_reserved(user_roles={}):
not_reserved = []
for user_role,details in user_roles.items():
if not "metadata" in details or not "_reserved" in details["metadata"] or not details["metadata"]["_reserved"]:
for user_role, details in user_roles.items():
if (
not "metadata" in details
or not "_reserved" in details["metadata"]
or not details["metadata"]["_reserved"]
):
not_reserved.append(user_role)
return not_reserved


def filter_reserved(users_role={}):
reserved = []
for user_role,details in users_role.items():
if "metadata" in details and "_reserved" in details["metadata"] and details["metadata"]["_reserved"]:
for user_role, details in users_role.items():
if (
"metadata" in details
and "_reserved" in details["metadata"]
and details["metadata"]["_reserved"]
):
reserved.append(user_role)
return reserved


class FilterModule(object):
def filters(self):
return {'modify_list': modify_list,
'append_to_list':append_to_list,
'filter_reserved':filter_reserved,
'array_to_str':array_to_str,
'extract_role_users':extract_role_users,
'remove_reserved':remove_reserved,
'filename':filename}
return {
"modify_list": modify_list,
"append_to_list": append_to_list,
"filter_reserved": filter_reserved,
"array_to_str": array_to_str,
"extract_role_users": extract_role_users,
"remove_reserved": remove_reserved,
"filename": filename,
}

0 comments on commit 3e9e7be

Please sign in to comment.