forked from ungleich-public/cdist
		
	Merge branch 'feature/__package_pip/extras' into 'master'
__package_pip: add optional (extra) dependencies See merge request ungleich-public/cdist!975
This commit is contained in:
		
				commit
				
					
						6358885d26
					
				
			
		
					 6 changed files with 149 additions and 6 deletions
				
			
		
							
								
								
									
										45
									
								
								cdist/conf/type/__package_pip/explorer/distinfo-dir
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										45
									
								
								cdist/conf/type/__package_pip/explorer/distinfo-dir
									
										
									
									
									
										Executable file
									
								
							| 
						 | 
					@ -0,0 +1,45 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# 2021 Matthias Stecher (matthiasstecher at gmx.de)
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# This file is part of cdist.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# cdist 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.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# cdist 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 cdist. If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					nameparam="$__object/parameter/name"
 | 
				
			||||||
 | 
					if [ -f "$nameparam" ]; then
 | 
				
			||||||
 | 
					    name=$(cat "$nameparam")
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
					    name="$__object_id"
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					pipparam="$__object/parameter/pip"
 | 
				
			||||||
 | 
					if [ -f "$pipparam" ]; then
 | 
				
			||||||
 | 
					    pip=$(cat "$pipparam")
 | 
				
			||||||
 | 
					else
 | 
				
			||||||
 | 
					    pip="$( "$__type_explorer/pip" )"
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					if command -v "$pip" >/dev/null 2>&1; then
 | 
				
			||||||
 | 
					    # assemble the path where pip stores all pip package info
 | 
				
			||||||
 | 
					    "$pip" show "$name" \
 | 
				
			||||||
 | 
					        | awk -F': ' '
 | 
				
			||||||
 | 
					            $1 == "Name" {name=$2; gsub(/-/,"_",name); next}
 | 
				
			||||||
 | 
					            $1 == "Version" {version=$2; next}
 | 
				
			||||||
 | 
					            $1 == "Location" {location=$2; next}
 | 
				
			||||||
 | 
					            END {if (version != "") printf "%s/%s-%s.dist-info", location, name, version}'
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
							
								
								
									
										66
									
								
								cdist/conf/type/__package_pip/explorer/extras
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										66
									
								
								cdist/conf/type/__package_pip/explorer/extras
									
										
									
									
									
										Executable file
									
								
							| 
						 | 
					@ -0,0 +1,66 @@
 | 
				
			||||||
 | 
					#!/bin/sh
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# 2021 Matthias Stecher (matthiasstecher at gmx.de)
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# This file is part of cdist.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# cdist 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.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# cdist 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 cdist. If not, see <http://www.gnu.org/licenses/>.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					# Checks if the given extras are really installed or not. It will be
 | 
				
			||||||
 | 
					# done by querring all dependencies for that extra and return it as
 | 
				
			||||||
 | 
					# "to be installed" if no dependency was found.
 | 
				
			||||||
 | 
					#
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					distinfo_dir="$("$__type_explorer/distinfo-dir")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# check if we have something to check
 | 
				
			||||||
 | 
					if [ "$distinfo_dir" ] && [ -s "$__object/parameter/extra" ]
 | 
				
			||||||
 | 
					then
 | 
				
			||||||
 | 
					    # save cause freezing is slow
 | 
				
			||||||
 | 
					    mkdir "$__object/files"
 | 
				
			||||||
 | 
					    pip_freeze="$__object/files/pip-freeze.tmp"
 | 
				
			||||||
 | 
					    pip3 freeze > "$pip_freeze"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    # If all is set, it searches all available extras to separatly check them.
 | 
				
			||||||
 | 
					    # It would work with just 'all' (cause dependencies are specified for
 | 
				
			||||||
 | 
					    # 'all'), but will not update if one extra is already present. Side effect
 | 
				
			||||||
 | 
					    # is that it will not use [all] but instead name all extras seperatly.
 | 
				
			||||||
 | 
					    for extra in $(if grep -qFx all "$__object/parameter/extra";
 | 
				
			||||||
 | 
					        then awk -F': ' '$1 == "Provides-Extra" && $2 != "all"{print $2}' "$distinfo_dir/METADATA";
 | 
				
			||||||
 | 
					        else tr ',' '\n' < "$__object/parameter/extra";
 | 
				
			||||||
 | 
					        fi)
 | 
				
			||||||
 | 
					    do
 | 
				
			||||||
 | 
					        # create a grep BRE pattern to search all packages
 | 
				
			||||||
 | 
					        # maybe a file full of patterns for -F could be written
 | 
				
			||||||
 | 
					        grep_pattern="$(
 | 
				
			||||||
 | 
					            awk -F'(: | ; )' -v check="$extra" '
 | 
				
			||||||
 | 
					                $1 == "Requires-Dist" {
 | 
				
			||||||
 | 
					                    split($2, r, " ");
 | 
				
			||||||
 | 
					                    sub("extra == ", "", $3); gsub("'"'"'", "", $3);
 | 
				
			||||||
 | 
					                    if($3 == check) print r[1]
 | 
				
			||||||
 | 
					                }' "$distinfo_dir/METADATA" \
 | 
				
			||||||
 | 
					                | sed ':a; $!N; s/\n/\\|/; ta'
 | 
				
			||||||
 | 
					        )"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        # echo the extra if no packages where found for it
 | 
				
			||||||
 | 
					        # if there is no pattern, we don't need to search ;-)
 | 
				
			||||||
 | 
					        # pip matches packages case-insensetive, we need to do that, too
 | 
				
			||||||
 | 
					        if [ "$grep_pattern" ] && ! grep -qi "$grep_pattern" "$pip_freeze"
 | 
				
			||||||
 | 
					        then
 | 
				
			||||||
 | 
					            echo "$extra"
 | 
				
			||||||
 | 
					        fi
 | 
				
			||||||
 | 
					    done
 | 
				
			||||||
 | 
					fi
 | 
				
			||||||
							
								
								
									
										0
									
								
								cdist/conf/type/__package_pip/explorer/state
									
										
									
									
									
										
										
										Normal file → Executable file
									
								
							
							
						
						
									
										0
									
								
								cdist/conf/type/__package_pip/explorer/state
									
										
									
									
									
										
										
										Normal file → Executable file
									
								
							| 
						 | 
					@ -2,6 +2,7 @@
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# 2012 Nico Schottelius (nico-cdist at schottelius.org)
 | 
					# 2012 Nico Schottelius (nico-cdist at schottelius.org)
 | 
				
			||||||
# 2016 Darko Poljak (darko.poljak at gmail.com)
 | 
					# 2016 Darko Poljak (darko.poljak at gmail.com)
 | 
				
			||||||
 | 
					# 2021 Matthias Stecher (matthiasstecher at gmx.de)
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
# This file is part of cdist.
 | 
					# This file is part of cdist.
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
| 
						 | 
					@ -25,7 +26,10 @@
 | 
				
			||||||
state_is=$(cat "$__object/explorer/state")
 | 
					state_is=$(cat "$__object/explorer/state")
 | 
				
			||||||
state_should="$(cat "$__object/parameter/state")"
 | 
					state_should="$(cat "$__object/parameter/state")"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
[ "$state_is" = "$state_should" ] && exit 0
 | 
					# short circuit if state is the same and no extras to install
 | 
				
			||||||
 | 
					[ "$state_is" = "$state_should" ] && ! [ -s "$__object/explorer/extras" ] \
 | 
				
			||||||
 | 
					    && exit 0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
nameparam="$__object/parameter/name"
 | 
					nameparam="$__object/parameter/name"
 | 
				
			||||||
if [ -f "$nameparam" ]; then
 | 
					if [ -f "$nameparam" ]; then
 | 
				
			||||||
| 
						 | 
					@ -56,6 +60,14 @@ fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
case "$state_should" in
 | 
					case "$state_should" in
 | 
				
			||||||
    present)
 | 
					    present)
 | 
				
			||||||
 | 
					        if [ -s "$__object/explorer/extras" ]
 | 
				
			||||||
 | 
					        then
 | 
				
			||||||
 | 
					            # all extras are passed to pip in a comma-separated list in the name
 | 
				
			||||||
 | 
					            # sed loops through all input lines and add commas between them
 | 
				
			||||||
 | 
					            extras="$(sed ':a; $!N; s/\n/,/; ta' "$__object/explorer/extras")"
 | 
				
			||||||
 | 
					            name="${name}[${extras}]"
 | 
				
			||||||
 | 
					        fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if [ "$runas" ]
 | 
					        if [ "$runas" ]
 | 
				
			||||||
        then
 | 
					        then
 | 
				
			||||||
            echo "su -c '$pip install -q $name' $runas"
 | 
					            echo "su -c '$pip install -q $name' $runas"
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -22,6 +22,16 @@ OPTIONAL PARAMETERS
 | 
				
			||||||
name
 | 
					name
 | 
				
			||||||
    If supplied, use the name and not the object id as the package name.
 | 
					    If supplied, use the name and not the object id as the package name.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					extra
 | 
				
			||||||
 | 
					    Extra optional dependencies which should be installed along the selected
 | 
				
			||||||
 | 
					    package. Can be specified multiple times. Multiple extras can be passed
 | 
				
			||||||
 | 
					    in one `--extra` as a comma-separated list.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    Extra optional dependencies will be installed even when the base package
 | 
				
			||||||
 | 
					    is already installed. Notice that the type will not remove installed extras
 | 
				
			||||||
 | 
					    that are not explicitly named for the type because pip does not offer a
 | 
				
			||||||
 | 
					    management for orphaned packages and they may be used by other packages.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
pip
 | 
					pip
 | 
				
			||||||
    Instead of using pip from PATH, use the specific pip path.
 | 
					    Instead of using pip from PATH, use the specific pip path.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -46,6 +56,14 @@ EXAMPLES
 | 
				
			||||||
    # Use pip in a virtualenv located at /foo/shinken_virtualenv as user foo
 | 
					    # Use pip in a virtualenv located at /foo/shinken_virtualenv as user foo
 | 
				
			||||||
    __package_pip pyro --state present --pip /foo/shinken_virtualenv/bin/pip --runas foo
 | 
					    __package_pip pyro --state present --pip /foo/shinken_virtualenv/bin/pip --runas foo
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    # Install package with optional dependencies
 | 
				
			||||||
 | 
					    __package_pip mautrix-telegram --extra speedups --extra webp_convert --extra hq_thumbnails
 | 
				
			||||||
 | 
					    # the extras can also be specified comma-separated
 | 
				
			||||||
 | 
					    __package_pip mautrix-telegram --extra speedups,webp_convert,hq_thumbnails --extra postgres
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    # or take all extras
 | 
				
			||||||
 | 
					    __package_pip mautrix-telegram --extra all
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
SEE ALSO
 | 
					SEE ALSO
 | 
				
			||||||
--------
 | 
					--------
 | 
				
			||||||
| 
						 | 
					@ -54,12 +72,13 @@ SEE ALSO
 | 
				
			||||||
 | 
					
 | 
				
			||||||
AUTHORS
 | 
					AUTHORS
 | 
				
			||||||
-------
 | 
					-------
 | 
				
			||||||
Nico Schottelius <nico-cdist--@--schottelius.org>
 | 
					| Nico Schottelius <nico-cdist--@--schottelius.org>
 | 
				
			||||||
 | 
					| Matthias Stecher <matthiasstecher--@--gmx.de>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
COPYING
 | 
					COPYING
 | 
				
			||||||
-------
 | 
					-------
 | 
				
			||||||
Copyright \(C) 2012 Nico Schottelius. You can redistribute it
 | 
					Copyright \(C) 2012 Nico Schottelius, 2021 Matthias Stecher. You can
 | 
				
			||||||
and/or modify it under the terms of the GNU General Public License as
 | 
					redistribute it and/or modify it under the terms of the GNU General
 | 
				
			||||||
published by the Free Software Foundation, either version 3 of the
 | 
					Public License as published by the Free Software Foundation, either
 | 
				
			||||||
License, or (at your option) any later version.
 | 
					version 3 of the License, or (at your option) any later version.
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -0,0 +1 @@
 | 
				
			||||||
 | 
					extra
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue