Add: mod_git permission management
This commit is contained in:
parent
0cd81cb99e
commit
6b55890034
@ -13,6 +13,7 @@ idm_git_header ()
|
||||
idm_vars_git_id $id
|
||||
|
||||
git_id_config=${IDM_CONFIG_DIR}/git/$id/local_gitconfig
|
||||
git_id_perms=${IDM_CONFIG_DIR}/git/$id/local_perms
|
||||
git_id_dir=$git_dir
|
||||
git_id_work_tree=$git_work_tree
|
||||
|
||||
@ -46,6 +47,8 @@ idm_git__help ()
|
||||
printf " %-20s: %s\n" "git repo rm" "Delete remote"
|
||||
printf " %-20s: %s\n" "git repo check" "Check remote availability"
|
||||
printf " %-20s: %s\n" "git repo sync" "Sync with remotes"
|
||||
printf " %-20s: %s\n" "git perm_save" "Save current file permissions"
|
||||
printf " %-20s: %s\n" "git perm_restore" "Restore file permissions"
|
||||
echo
|
||||
printf " %-20s: %s\n" "git --help" "Git wrapper"
|
||||
printf " %-20s: %s\n" "git [cmd]" "Git wrapper"
|
||||
@ -114,12 +117,18 @@ idm_git__init ()
|
||||
idm_git__repo()
|
||||
{
|
||||
local id=$1
|
||||
local sub=$2
|
||||
shift 2
|
||||
local opts=${@-}
|
||||
idm_git__repo_$sub $id $opts
|
||||
local sub=${2:-ls}
|
||||
local opts=
|
||||
|
||||
shift 2 &&
|
||||
opts=${@-} ||
|
||||
true
|
||||
|
||||
idm_git__repo_$sub $id ${opts}
|
||||
}
|
||||
|
||||
idm_git__repo_help () { idm_git__help ${@-}; }
|
||||
|
||||
idm_git__repo_ls()
|
||||
{
|
||||
local id=$1
|
||||
@ -129,9 +138,9 @@ idm_git__repo_ls()
|
||||
return 1
|
||||
idm_git_header $id
|
||||
if [ -z "$name" ]; then
|
||||
git config -f $git_id_config -l
|
||||
git config -f $git_id_config -l | grep idmgr-sources || true
|
||||
else
|
||||
git config -f $git_id_config --get idmgr-sources.$name
|
||||
git config -f $git_id_config --get idmgr-sources.$name || true
|
||||
#git config -f $git_id_config --get-all idmgr-sources
|
||||
fi
|
||||
|
||||
@ -169,6 +178,7 @@ idm_git__repo_check ()
|
||||
opts=${*-}
|
||||
local static_repos=
|
||||
local fqdn=
|
||||
local clone_first=0
|
||||
|
||||
# Loading
|
||||
lib_id_is_enabled $id ||
|
||||
@ -176,13 +186,20 @@ idm_git__repo_check ()
|
||||
idm_git_header $id
|
||||
|
||||
# load infos
|
||||
static_repos=$( git config -f $git_id_config -l | grep ^idmgr-sources)
|
||||
fqdn=$( hostname -f )
|
||||
static_repos=$( git config -f $git_id_config -l | grep ^idmgr-sources || true)
|
||||
fqdn="$( hostname -f )"
|
||||
|
||||
# Check if local repo is present
|
||||
if ! lib_git_is_repo id ; then
|
||||
# Clone first one
|
||||
clone_first=1
|
||||
fi
|
||||
|
||||
# Load static remotes
|
||||
while IFS== read -r name uri; do
|
||||
|
||||
# Guess missing fields
|
||||
[ ! -z "$uri" ] || continue
|
||||
if ! [[ "$uri" =~ @ ]]; then
|
||||
uri="${USER:-(id -n -u)}@$uri"
|
||||
fi
|
||||
@ -205,18 +222,27 @@ idm_git__repo_check ()
|
||||
|
||||
# Test ssh conenction
|
||||
lib_log INFO "Testing: $name $user on $host in $path ..."
|
||||
set -x
|
||||
ssh_script="$(idm_git_ssh_scan_script $id $path)"
|
||||
path=$(ssh -l $user $host "$ssh_script" < /dev/null || true )
|
||||
uri="$user@$host:$path"
|
||||
|
||||
# Act according result
|
||||
if [ ! -z "$path" ]; then
|
||||
|
||||
if [ "$clone_first" -eq 1 ]; then
|
||||
# No repo yet
|
||||
idm_git__init $id
|
||||
clone_first=0
|
||||
fi
|
||||
|
||||
# Local repo is a repo
|
||||
lib_git id config --add idmgr-online-sources.$name $uri
|
||||
|
||||
if ! lib_git id remote get-url $name &>/dev/null; then
|
||||
lib_git id remote add $name $user@$host:$path
|
||||
lib_git id remote add $name "$uri"
|
||||
fi
|
||||
lib_log INFO "Remote $name is online"
|
||||
|
||||
continue
|
||||
else
|
||||
lib_git id config --unset idmgr-online-sources.$name
|
||||
@ -233,6 +259,49 @@ idm_git__repo_check ()
|
||||
|
||||
}
|
||||
|
||||
idm_git__install ()
|
||||
{
|
||||
local id=$1
|
||||
shift 1
|
||||
opts=${*-}
|
||||
local static_repos=
|
||||
local fqdn=
|
||||
local clone_first=0
|
||||
|
||||
# Loading
|
||||
lib_id_is_enabled $id ||
|
||||
return 1
|
||||
idm_git_header $id
|
||||
|
||||
# Check if repo has NO commits
|
||||
|
||||
set -x
|
||||
# git co xpjez/master
|
||||
stash_list="$(lib_git id ls-tree --name-only -r xpjez/master | xargs )"
|
||||
local files=
|
||||
#while IFS=$' ' read -r f ; do
|
||||
for f in $stash_list; do
|
||||
[ -f "$f" ] &&
|
||||
files="${files+$files }$f"
|
||||
done
|
||||
#done <<<"$stash_list"
|
||||
|
||||
# Check status
|
||||
if [ ! -z "$files" ]; then
|
||||
|
||||
# Add all files
|
||||
lib_git id add $files
|
||||
local commit_msg='Saving_existing_files'
|
||||
lib_git id commit -m $commit_msg
|
||||
|
||||
fi
|
||||
|
||||
# merge with master
|
||||
lib_git id co xpjez/master
|
||||
|
||||
|
||||
}
|
||||
|
||||
idm_git_ssh_scan_script ()
|
||||
{
|
||||
local id=$1
|
||||
@ -269,6 +338,9 @@ idm_git__repo_sync ()
|
||||
return 1
|
||||
idm_git_header $id
|
||||
|
||||
lib_git_is_repo id ||
|
||||
return 1
|
||||
|
||||
# Check repo presence ?
|
||||
# idm_git__repo_check $id
|
||||
|
||||
@ -337,9 +409,16 @@ idm_git__ls ()
|
||||
if lib_git_is_repo id &> /dev/null; then
|
||||
# Show files
|
||||
lib_git id ls-files | sort | sed 's/^/ /'
|
||||
echo ""
|
||||
else
|
||||
echo " Repository is absent"
|
||||
echo " Status : absent"
|
||||
fi
|
||||
|
||||
# Display repo infos
|
||||
echo " Work tree : $git_id_work_tree"
|
||||
echo " Local config : $git_id_config"
|
||||
echo " Git dir : $git_id_dir"
|
||||
|
||||
}
|
||||
|
||||
idm_git__enable ()
|
||||
@ -362,6 +441,56 @@ idm_git__disable ()
|
||||
idm_git__kill () { idm_git__disable ${@-}; }
|
||||
|
||||
|
||||
idm_git__perm_save ()
|
||||
{
|
||||
local id=$1
|
||||
local files
|
||||
|
||||
# Loading
|
||||
lib_id_is_enabled $id ||
|
||||
return 1
|
||||
idm_git_header $id
|
||||
|
||||
# Check if it is a valid repo
|
||||
lib_git_is_repo id ||
|
||||
return 1
|
||||
|
||||
# Show files
|
||||
files=$(lib_git id ls-files | sort | xargs )
|
||||
{
|
||||
cd ~
|
||||
find $files -exec stat -c '%a %n' {} \; > $git_id_perms
|
||||
}
|
||||
|
||||
lib_log NOTICE "Permissions saved into $git_id_perms"
|
||||
}
|
||||
|
||||
idm_git__perm_restore ()
|
||||
{
|
||||
local id=$1
|
||||
local files
|
||||
|
||||
# Loading
|
||||
lib_id_is_enabled $id ||
|
||||
return 1
|
||||
idm_git_header $id
|
||||
|
||||
# Check if it is a valid repo
|
||||
lib_git_is_repo id ||
|
||||
return 1
|
||||
|
||||
# Show files
|
||||
{
|
||||
cd ~
|
||||
while read line; do
|
||||
chmod $line ||
|
||||
true
|
||||
done < $git_id_perms
|
||||
}
|
||||
|
||||
|
||||
lib_log NOTICE "Permissions restored from $git_id_perms"
|
||||
}
|
||||
|
||||
## Internal lib
|
||||
##############################
|
||||
@ -370,8 +499,6 @@ idm_git_get_files_of_interest ()
|
||||
{
|
||||
local id=${1}
|
||||
|
||||
git_id_config
|
||||
|
||||
find_args="-maxdepth 2 -type f "
|
||||
{
|
||||
# ssh
|
||||
@ -392,8 +519,8 @@ idm_git_get_files_of_interest ()
|
||||
find $IDM_CONFIG_DIR/ $find_args -name "*$id*" 2>/dev/null
|
||||
|
||||
# Git
|
||||
echo "${git_id_config}"
|
||||
} | sed -E "s@$HOME/?@@g"
|
||||
find ${IDM_CONFIG_DIR}/git/$id/ $find_args 2>/dev/null
|
||||
} | grep -v "enc/" | sed -E "s@$HOME/?@@g"
|
||||
|
||||
}
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user