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
626f9629
Commit
626f9629
authored
Mar 12, 2014
by
Michael DeHaan
Committed by
Michael DeHaan
Mar 12, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Various commits to enable no-shell or safe-shell usage, more to come.
Conflicts: library/packaging/cpanm
parent
80df6e41
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
159 additions
and
8 deletions
+159
-8
library/packaging/apt_repository
+4
-1
library/packaging/cpanm
+145
-0
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 @
626f9629
...
...
@@ -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
0 → 100644
View file @
626f9629
#!/usr/bin/python
# -*- coding: utf-8 -*-
# (c) 2012, Franck Cuny <franck@lumberjaph.net>
#
# 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/>.
#
DOCUMENTATION
=
'''
---
module: cpanm
short_description: Manages Perl library dependencies.
description:
- Manage Perl library dependencies.
version_added: "1.0"
options:
name:
description:
- The name of the Perl library to install
required: false
default: null
aliases: ["pkg"]
from_path:
description:
- The local directory from where to install
required: false
default: null
notest:
description:
- Do not run unit tests
required: false
default: false
locallib:
description:
- Specify the install base to install modules
required: false
default: false
mirror:
description:
- Specifies the base URL for the CPAN mirror to use
required: false
default: false
examples:
- code: "cpanm: name=Dancer"
description: Install I(Dancer) perl package.
- code: "cpanm: name=Dancer locallib=/srv/webapps/my_app/extlib"
description: "Install I(Dancer) (U(http://perldancer.org/)) into the specified I(locallib)"
- code: "cpanm: from_path=/srv/webapps/my_app/src/"
description: Install perl dependencies from local directory.
- code: "cpanm: name=Dancer notest=True locallib=/srv/webapps/my_app/extlib"
description: Install I(Dancer) perl package without running the unit tests in indicated I(locallib).
- code: "cpanm: name=Dancer mirror=http://cpan.cpantesters.org/"
description: Install I(Dancer) perl package from a specific mirror
notes:
- Please note that U(http://search.cpan.org/dist/App-cpanminus/bin/cpanm, cpanm) must be installed on the remote host.
author: Franck Cuny
'''
def
_is_package_installed
(
module
,
name
,
locallib
,
cpanm
):
cmd
=
""
if
locallib
:
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
)
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
:
cmd
=
"{cpanm} {name}"
.
format
(
cpanm
=
cpanm
,
name
=
name
)
if
notest
is
True
:
cmd
=
"{cmd} -n"
.
format
(
cmd
=
cmd
)
if
locallib
is
not
None
:
cmd
=
"{cmd} -l {locallib}"
.
format
(
cmd
=
cmd
,
locallib
=
locallib
)
if
mirror
is
not
None
:
cmd
=
"{cmd} --mirror {mirror}"
.
format
(
cmd
=
cmd
,
mirror
=
mirror
)
return
cmd
def
main
():
arg_spec
=
dict
(
name
=
dict
(
default
=
None
,
required
=
False
,
aliases
=
[
'pkg'
]),
from_path
=
dict
(
default
=
None
,
required
=
False
),
notest
=
dict
(
default
=
False
,
type
=
'bool'
),
locallib
=
dict
(
default
=
None
,
required
=
False
),
mirror
=
dict
(
default
=
None
,
required
=
False
)
)
module
=
AnsibleModule
(
argument_spec
=
arg_spec
,
required_one_of
=
[[
'name'
,
'from_path'
]],
)
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'
]
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
)
rc_cpanm
,
out_cpanm
,
err_cpanm
=
module
.
run_command
(
cmd
,
check_rc
=
False
)
if
rc_cpanm
!=
0
:
module
.
fail_json
(
msg
=
err_cpanm
,
cmd
=
cmd
)
if
err_cpanm
and
'is up to date'
not
in
err_cpanm
:
changed
=
True
module
.
exit_json
(
changed
=
changed
,
binary
=
cpanm
,
name
=
name
)
# import module snippets
from
ansible.module_utils.basic
import
*
main
()
library/packaging/gem
View file @
626f9629
...
...
@@ -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 @
626f9629
...
...
@@ -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 @
626f9629
...
...
@@ -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 @
626f9629
...
...
@@ -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