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
6010e748
Commit
6010e748
authored
Mar 12, 2014
by
Michael DeHaan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Various commits to enable no-shell or safe-shell usage, more to come.
parent
60a7f573
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
29 additions
and
22 deletions
+29
-22
library/packaging/apt_repository
+4
-1
library/packaging/cpanm
+15
-14
library/packaging/gem
+1
-1
library/packaging/macports
+4
-2
library/packaging/opkg
+2
-1
library/packaging/pacman
+3
-3
No files found.
library/packaging/apt_repository
View file @
6010e748
...
...
@@ -352,7 +352,10 @@ def get_add_ppa_signing_key_callback(module):
def
_run_command
(
command
):
module
.
run_command
(
command
,
check_rc
=
True
)
return
_run_command
if
not
module
.
check_mode
else
None
if
module
.
check_mode
:
return
_run_command
else
:
return
None
def
main
():
...
...
library/packaging/cpanm
View file @
6010e748
...
...
@@ -72,14 +72,17 @@ author: Franck Cuny
def
_is_package_installed
(
module
,
name
,
locallib
,
cpanm
):
cmd
=
""
if
locallib
:
cmd
=
"PERL5LIB={locallib}/lib/perl5"
.
format
(
locallib
=
locallib
)
cmd
=
"
{cmd} perl -M{name} -e '1'"
.
format
(
cmd
=
cmd
,
name
=
name
)
os
.
environ
[
"PERL5LIB"
]
=
"
%
s/lib/perl5"
%
locallib
cmd
=
"
%
s perl -M
%
s -e '1'"
%
(
cmd
,
name
)
res
,
stdout
,
stderr
=
module
.
run_command
(
cmd
,
check_rc
=
False
)
installed
=
True
if
res
==
0
else
False
return
installed
if
res
==
0
return
True
else
return
False
def
_build_cmd_line
(
name
,
from_path
,
notest
,
locallib
,
mirror
,
cpanm
):
# this code should use "%s" like everything else and just return early but not fixing all of it now.
# don't copy stuff like this
if
from_path
:
cmd
=
"{cpanm} {path}"
.
format
(
cpanm
=
cpanm
,
path
=
from_path
)
else
:
...
...
@@ -111,21 +114,20 @@ def main():
required_one_of
=
[[
'name'
,
'from_path'
]],
)
cpanm
=
module
.
get_bin_path
(
'cpanm'
,
True
)
name
=
module
.
params
[
'name'
]
cpanm
=
module
.
get_bin_path
(
'cpanm'
,
True
)
name
=
module
.
params
[
'name'
]
from_path
=
module
.
params
[
'from_path'
]
notest
=
module
.
boolean
(
module
.
params
.
get
(
'notest'
,
False
))
locallib
=
module
.
params
[
'locallib'
]
mirror
=
module
.
params
[
'mirror'
]
notest
=
module
.
boolean
(
module
.
params
.
get
(
'notest'
,
False
))
locallib
=
module
.
params
[
'locallib'
]
mirror
=
module
.
params
[
'mirror'
]
changed
=
False
changed
=
False
installed
=
_is_package_installed
(
module
,
name
,
locallib
,
cpanm
)
if
not
installed
:
out_cpanm
=
err_cpanm
=
''
cmd
=
_build_cmd_line
(
name
,
from_path
,
notest
,
locallib
,
mirror
,
cpanm
)
cmd
=
_build_cmd_line
(
name
,
from_path
,
notest
,
locallib
,
mirror
,
cpanm
)
rc_cpanm
,
out_cpanm
,
err_cpanm
=
module
.
run_command
(
cmd
,
check_rc
=
False
)
...
...
@@ -137,7 +139,6 @@ def main():
module
.
exit_json
(
changed
=
changed
,
binary
=
cpanm
,
name
=
name
)
# import module snippets
from
ansible.module_utils.basic
import
*
...
...
library/packaging/gem
View file @
6010e748
...
...
@@ -89,7 +89,7 @@ def get_rubygems_path(module):
return
module
.
get_bin_path
(
'gem'
,
True
)
def
get_rubygems_version
(
module
):
cmd
=
[
get_rubygems_path
(
module
),
'--version'
]
cmd
=
[
get_rubygems_path
(
module
),
'--version'
]
(
rc
,
out
,
err
)
=
module
.
run_command
(
cmd
,
check_rc
=
True
)
match
=
re
.
match
(
r'^(\d+)\.(\d+)\.(\d+)'
,
out
)
...
...
library/packaging/macports
View file @
6010e748
...
...
@@ -53,6 +53,7 @@ EXAMPLES = '''
- macports: name=foo state=inactive
'''
import
pipes
def
update_package_db
(
module
,
port_path
):
""" Updates packages list. """
...
...
@@ -68,7 +69,7 @@ def query_package(module, port_path, name, state="present"):
if
state
==
"present"
:
rc
,
out
,
err
=
module
.
run_command
(
"
%
s installed | grep -q ^.*
%
s"
%
(
p
ort_path
,
name
)
)
rc
,
out
,
err
=
module
.
run_command
(
"
%
s installed | grep -q ^.*
%
s"
%
(
p
ipes
.
quote
(
port_path
),
pipes
.
quote
(
name
)),
use_unsafe_shell
=
True
)
if
rc
==
0
:
return
True
...
...
@@ -76,7 +77,8 @@ def query_package(module, port_path, name, state="present"):
elif
state
==
"active"
:
rc
,
out
,
err
=
module
.
run_command
(
"
%
s installed
%
s | grep -q active"
%
(
port_path
,
name
))
rc
,
out
,
err
=
module
.
run_command
(
"
%
s installed
%
s | grep -q active"
%
(
pipes
.
quote
(
port_path
),
pipes
.
quote
(
name
)),
use_unsafe_shell
=
True
)
if
rc
==
0
:
return
True
...
...
library/packaging/opkg
View file @
6010e748
...
...
@@ -51,6 +51,7 @@ EXAMPLES = '''
- opkg: name=foo,bar state=absent
'''
import
pipes
def
update_package_db
(
module
,
opkg_path
):
""" Updates packages list. """
...
...
@@ -66,7 +67,7 @@ def query_package(module, opkg_path, name, state="present"):
if
state
==
"present"
:
rc
,
out
,
err
=
module
.
run_command
(
"
%
s list-installed | grep -q ^
%
s"
%
(
opkg_path
,
name
)
)
rc
,
out
,
err
=
module
.
run_command
(
"
%
s list-installed | grep -q ^
%
s"
%
(
pipes
.
quote
(
opkg_path
),
pipes
.
quote
(
name
)),
use_unsafe_shell
=
True
)
if
rc
==
0
:
return
True
...
...
library/packaging/pacman
View file @
6010e748
...
...
@@ -100,7 +100,7 @@ def query_package(module, name, state="installed"):
def
update_package_db
(
module
):
cmd
=
"pacman -Syy
> /dev/null
"
cmd
=
"pacman -Syy"
rc
,
stdout
,
stderr
=
module
.
run_command
(
cmd
,
check_rc
=
False
)
if
rc
!=
0
:
...
...
@@ -120,7 +120,7 @@ def remove_packages(module, packages):
if
not
query_package
(
module
,
package
):
continue
cmd
=
"pacman -
%
s
%
s --noconfirm
> /dev/null
"
%
(
args
,
package
)
cmd
=
"pacman -
%
s
%
s --noconfirm"
%
(
args
,
package
)
rc
,
stdout
,
stderr
=
module
.
run_command
(
cmd
,
check_rc
=
False
)
if
rc
!=
0
:
...
...
@@ -148,7 +148,7 @@ def install_packages(module, packages, package_files):
else
:
params
=
'-S
%
s'
%
package
cmd
=
"pacman
%
s --noconfirm
> /dev/null
"
%
(
params
)
cmd
=
"pacman
%
s --noconfirm"
%
(
params
)
rc
,
stdout
,
stderr
=
module
.
run_command
(
cmd
,
check_rc
=
False
)
if
rc
!=
0
:
...
...
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