Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
A
ansible
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
OpenEdx
ansible
Commits
b2c7b911
Commit
b2c7b911
authored
Feb 02, 2015
by
Toshio Kuratomi
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
v2/plugins/filter is now a symlink as it does not differ between v1 and v2
parent
03e213a2
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
2 additions
and
390 deletions
+2
-390
v2/ansible/plugins/filter
+2
-0
v2/ansible/plugins/filter/__init__.py
+0
-0
v2/ansible/plugins/filter/core.py
+0
-390
No files found.
v2/ansible/plugins/filter
0 → 120000
View file @
b2c7b911
../../../lib/ansible/runner/filter_plugins
\ No newline at end of file
v2/ansible/plugins/filter/__init__.py
deleted
100644 → 0
View file @
03e213a2
v2/ansible/plugins/filter/core.py
deleted
100644 → 0
View file @
03e213a2
# (c) 2012, Jeroen Hoekx <jeroen@hoekx.be>
#
# This file is part of Ansible
#
# Ansible is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Ansible is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
import
sys
import
base64
import
json
import
os.path
import
types
import
pipes
import
glob
import
re
import
collections
import
crypt
import
hashlib
import
string
import
operator
as
py_operator
from
random
import
SystemRandom
,
shuffle
import
uuid
import
yaml
from
jinja2.filters
import
environmentfilter
from
distutils.version
import
LooseVersion
,
StrictVersion
from
ansible
import
errors
from
ansible.utils.hashing
import
md5s
,
checksum_s
UUID_NAMESPACE_ANSIBLE
=
uuid
.
UUID
(
'361E6D51-FAEC-444A-9079-341386DA8E2E'
)
def
to_nice_yaml
(
*
a
,
**
kw
):
'''Make verbose, human readable yaml'''
return
yaml
.
safe_dump
(
*
a
,
indent
=
4
,
allow_unicode
=
True
,
default_flow_style
=
False
,
**
kw
)
def
to_json
(
a
,
*
args
,
**
kw
):
''' Convert the value to JSON '''
return
json
.
dumps
(
a
,
*
args
,
**
kw
)
def
to_nice_json
(
a
,
*
args
,
**
kw
):
'''Make verbose, human readable JSON'''
# python-2.6's json encoder is buggy (can't encode hostvars)
if
sys
.
version_info
<
(
2
,
7
):
try
:
import
simplejson
except
ImportError
:
pass
else
:
try
:
major
=
int
(
simplejson
.
__version__
.
split
(
'.'
)[
0
])
except
:
pass
else
:
if
major
>=
2
:
return
simplejson
.
dumps
(
a
,
indent
=
4
,
sort_keys
=
True
,
*
args
,
**
kw
)
# Fallback to the to_json filter
return
to_json
(
a
,
*
args
,
**
kw
)
return
json
.
dumps
(
a
,
indent
=
4
,
sort_keys
=
True
,
*
args
,
**
kw
)
def
failed
(
*
a
,
**
kw
):
''' Test if task result yields failed '''
item
=
a
[
0
]
if
type
(
item
)
!=
dict
:
raise
errors
.
AnsibleFilterError
(
"|failed expects a dictionary"
)
rc
=
item
.
get
(
'rc'
,
0
)
failed
=
item
.
get
(
'failed'
,
False
)
if
rc
!=
0
or
failed
:
return
True
else
:
return
False
def
success
(
*
a
,
**
kw
):
''' Test if task result yields success '''
return
not
failed
(
*
a
,
**
kw
)
def
changed
(
*
a
,
**
kw
):
''' Test if task result yields changed '''
item
=
a
[
0
]
if
type
(
item
)
!=
dict
:
raise
errors
.
AnsibleFilterError
(
"|changed expects a dictionary"
)
if
not
'changed'
in
item
:
changed
=
False
if
(
'results'
in
item
# some modules return a 'results' key
and
type
(
item
[
'results'
])
==
list
and
type
(
item
[
'results'
][
0
])
==
dict
):
for
result
in
item
[
'results'
]:
changed
=
changed
or
result
.
get
(
'changed'
,
False
)
else
:
changed
=
item
.
get
(
'changed'
,
False
)
return
changed
def
skipped
(
*
a
,
**
kw
):
''' Test if task result yields skipped '''
item
=
a
[
0
]
if
type
(
item
)
!=
dict
:
raise
errors
.
AnsibleFilterError
(
"|skipped expects a dictionary"
)
skipped
=
item
.
get
(
'skipped'
,
False
)
return
skipped
def
mandatory
(
a
):
''' Make a variable mandatory '''
try
:
a
except
NameError
:
raise
errors
.
AnsibleFilterError
(
'Mandatory variable not defined.'
)
else
:
return
a
def
bool
(
a
):
''' return a bool for the arg '''
if
a
is
None
or
type
(
a
)
==
bool
:
return
a
if
type
(
a
)
in
types
.
StringTypes
:
a
=
a
.
lower
()
if
a
in
[
'yes'
,
'on'
,
'1'
,
'true'
,
1
]:
return
True
else
:
return
False
def
quote
(
a
):
''' return its argument quoted for shell usage '''
return
pipes
.
quote
(
a
)
def
fileglob
(
pathname
):
''' return list of matched files for glob '''
return
glob
.
glob
(
pathname
)
def
regex
(
value
=
''
,
pattern
=
''
,
ignorecase
=
False
,
match_type
=
'search'
):
''' Expose `re` as a boolean filter using the `search` method by default.
This is likely only useful for `search` and `match` which already
have their own filters.
'''
if
ignorecase
:
flags
=
re
.
I
else
:
flags
=
0
_re
=
re
.
compile
(
pattern
,
flags
=
flags
)
_bool
=
__builtins__
.
get
(
'bool'
)
return
_bool
(
getattr
(
_re
,
match_type
,
'search'
)(
value
))
def
match
(
value
,
pattern
=
''
,
ignorecase
=
False
):
''' Perform a `re.match` returning a boolean '''
return
regex
(
value
,
pattern
,
ignorecase
,
'match'
)
def
search
(
value
,
pattern
=
''
,
ignorecase
=
False
):
''' Perform a `re.search` returning a boolean '''
return
regex
(
value
,
pattern
,
ignorecase
,
'search'
)
def
regex_replace
(
value
=
''
,
pattern
=
''
,
replacement
=
''
,
ignorecase
=
False
):
''' Perform a `re.sub` returning a string '''
if
not
isinstance
(
value
,
basestring
):
value
=
str
(
value
)
if
ignorecase
:
flags
=
re
.
I
else
:
flags
=
0
_re
=
re
.
compile
(
pattern
,
flags
=
flags
)
return
_re
.
sub
(
replacement
,
value
)
def
unique
(
a
):
if
isinstance
(
a
,
collections
.
Hashable
):
c
=
set
(
a
)
else
:
c
=
[]
for
x
in
a
:
if
x
not
in
c
:
c
.
append
(
x
)
return
c
def
intersect
(
a
,
b
):
if
isinstance
(
a
,
collections
.
Hashable
)
and
isinstance
(
b
,
collections
.
Hashable
):
c
=
set
(
a
)
&
set
(
b
)
else
:
c
=
unique
(
filter
(
lambda
x
:
x
in
b
,
a
))
return
c
def
difference
(
a
,
b
):
if
isinstance
(
a
,
collections
.
Hashable
)
and
isinstance
(
b
,
collections
.
Hashable
):
c
=
set
(
a
)
-
set
(
b
)
else
:
c
=
unique
(
filter
(
lambda
x
:
x
not
in
b
,
a
))
return
c
def
symmetric_difference
(
a
,
b
):
if
isinstance
(
a
,
collections
.
Hashable
)
and
isinstance
(
b
,
collections
.
Hashable
):
c
=
set
(
a
)
^
set
(
b
)
else
:
c
=
unique
(
filter
(
lambda
x
:
x
not
in
intersect
(
a
,
b
),
union
(
a
,
b
)))
return
c
def
union
(
a
,
b
):
if
isinstance
(
a
,
collections
.
Hashable
)
and
isinstance
(
b
,
collections
.
Hashable
):
c
=
set
(
a
)
|
set
(
b
)
else
:
c
=
unique
(
a
+
b
)
return
c
def
min
(
a
):
_min
=
__builtins__
.
get
(
'min'
)
return
_min
(
a
);
def
max
(
a
):
_max
=
__builtins__
.
get
(
'max'
)
return
_max
(
a
);
def
version_compare
(
value
,
version
,
operator
=
'eq'
,
strict
=
False
):
''' Perform a version comparison on a value '''
op_map
=
{
'=='
:
'eq'
,
'='
:
'eq'
,
'eq'
:
'eq'
,
'<'
:
'lt'
,
'lt'
:
'lt'
,
'<='
:
'le'
,
'le'
:
'le'
,
'>'
:
'gt'
,
'gt'
:
'gt'
,
'>='
:
'ge'
,
'ge'
:
'ge'
,
'!='
:
'ne'
,
'<>'
:
'ne'
,
'ne'
:
'ne'
}
if
strict
:
Version
=
StrictVersion
else
:
Version
=
LooseVersion
if
operator
in
op_map
:
operator
=
op_map
[
operator
]
else
:
raise
errors
.
AnsibleFilterError
(
'Invalid operator type'
)
try
:
method
=
getattr
(
py_operator
,
operator
)
return
method
(
Version
(
str
(
value
)),
Version
(
str
(
version
)))
except
Exception
,
e
:
raise
errors
.
AnsibleFilterError
(
'Version comparison:
%
s'
%
e
)
@environmentfilter
def
rand
(
environment
,
end
,
start
=
None
,
step
=
None
):
r
=
SystemRandom
()
if
isinstance
(
end
,
(
int
,
long
)):
if
not
start
:
start
=
0
if
not
step
:
step
=
1
return
r
.
randrange
(
start
,
end
,
step
)
elif
hasattr
(
end
,
'__iter__'
):
if
start
or
step
:
raise
errors
.
AnsibleFilterError
(
'start and step can only be used with integer values'
)
return
r
.
choice
(
end
)
else
:
raise
errors
.
AnsibleFilterError
(
'random can only be used on sequences and integers'
)
def
randomize_list
(
mylist
):
try
:
mylist
=
list
(
mylist
)
shuffle
(
mylist
)
except
:
pass
return
mylist
def
get_hash
(
data
,
hashtype
=
'sha1'
):
try
:
# see if hash is supported
h
=
hashlib
.
new
(
hashtype
)
except
:
return
None
h
.
update
(
data
)
return
h
.
hexdigest
()
def
get_encrypted_password
(
password
,
hashtype
=
'sha512'
,
salt
=
None
):
# TODO: find a way to construct dynamically from system
cryptmethod
=
{
'md5'
:
'1'
,
'blowfish'
:
'2a'
,
'sha256'
:
'5'
,
'sha512'
:
'6'
,
}
hastype
=
hashtype
.
lower
()
if
hashtype
in
cryptmethod
:
if
salt
is
None
:
r
=
SystemRandom
()
salt
=
''
.
join
([
r
.
choice
(
string
.
ascii_letters
+
string
.
digits
)
for
_
in
range
(
16
)])
saltstring
=
"$
%
s$
%
s"
%
(
cryptmethod
[
hashtype
],
salt
)
encrypted
=
crypt
.
crypt
(
password
,
saltstring
)
return
encrypted
return
None
def
to_uuid
(
string
):
return
str
(
uuid
.
uuid5
(
UUID_NAMESPACE_ANSIBLE
,
str
(
string
)))
class
FilterModule
(
object
):
''' Ansible core jinja2 filters '''
def
filters
(
self
):
return
{
# base 64
'b64decode'
:
base64
.
b64decode
,
'b64encode'
:
base64
.
b64encode
,
# uuid
'to_uuid'
:
to_uuid
,
# json
'to_json'
:
to_json
,
'to_nice_json'
:
to_nice_json
,
'from_json'
:
json
.
loads
,
# yaml
'to_yaml'
:
yaml
.
safe_dump
,
'to_nice_yaml'
:
to_nice_yaml
,
'from_yaml'
:
yaml
.
safe_load
,
# path
'basename'
:
os
.
path
.
basename
,
'dirname'
:
os
.
path
.
dirname
,
'expanduser'
:
os
.
path
.
expanduser
,
'realpath'
:
os
.
path
.
realpath
,
'relpath'
:
os
.
path
.
relpath
,
# failure testing
'failed'
:
failed
,
'success'
:
success
,
# changed testing
'changed'
:
changed
,
# skip testing
'skipped'
:
skipped
,
# variable existence
'mandatory'
:
mandatory
,
# value as boolean
'bool'
:
bool
,
# quote string for shell usage
'quote'
:
quote
,
# hash filters
# md5 hex digest of string
'md5'
:
md5s
,
# sha1 hex digeset of string
'sha1'
:
checksum_s
,
# checksum of string as used by ansible for checksuming files
'checksum'
:
checksum_s
,
# generic hashing
'password_hash'
:
get_encrypted_password
,
'hash'
:
get_hash
,
# file glob
'fileglob'
:
fileglob
,
# regex
'match'
:
match
,
'search'
:
search
,
'regex'
:
regex
,
'regex_replace'
:
regex_replace
,
# list
'unique'
:
unique
,
'intersect'
:
intersect
,
'difference'
:
difference
,
'symmetric_difference'
:
symmetric_difference
,
'union'
:
union
,
'min'
:
min
,
'max'
:
max
,
# version comparison
'version_compare'
:
version_compare
,
# random stuff
'random'
:
rand
,
'shuffle'
:
randomize_list
,
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment