mirror of
				https://github.com/ohmyzsh/ohmyzsh.git
				synced 2025-11-04 13:21:19 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			45 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
# Handle completions insecurities (i.e., completion-dependent directories with
 | 
						|
# insecure ownership or permissions) by:
 | 
						|
#
 | 
						|
# * Human-readably notifying the user of these insecurities.
 | 
						|
function handle_completion_insecurities() {
 | 
						|
  # List of the absolute paths of all unique insecure directories, split on
 | 
						|
  # newline from compaudit()'s output resembling:
 | 
						|
  #
 | 
						|
  #     There are insecure directories:
 | 
						|
  #     /usr/share/zsh/site-functions
 | 
						|
  #     /usr/share/zsh/5.0.6/functions
 | 
						|
  #     /usr/share/zsh
 | 
						|
  #     /usr/share/zsh/5.0.6
 | 
						|
  #
 | 
						|
  # Since the ignorable first line is printed to stderr and thus not captured,
 | 
						|
  # stderr is squelched to prevent this output from leaking to the user.
 | 
						|
  local -aU insecure_dirs
 | 
						|
  insecure_dirs=( ${(f@):-"$(compaudit 2>/dev/null)"} )
 | 
						|
 | 
						|
  # If no such directories exist, get us out of here.
 | 
						|
  [[ -z "${insecure_dirs}" ]] && return
 | 
						|
 | 
						|
  # List ownership and permissions of all insecure directories.
 | 
						|
  print "[oh-my-zsh] Insecure completion-dependent directories detected:"
 | 
						|
  ls -ld "${(@)insecure_dirs}"
 | 
						|
 | 
						|
  cat <<EOD
 | 
						|
 | 
						|
[oh-my-zsh] For safety, we will not load completions from these directories until
 | 
						|
[oh-my-zsh] you fix their permissions and ownership and restart zsh.
 | 
						|
[oh-my-zsh] See the above list for directories with group or other writability.
 | 
						|
 | 
						|
[oh-my-zsh] To fix your permissions you can do so by disabling
 | 
						|
[oh-my-zsh] the write permission of "group" and "others" and making sure that the
 | 
						|
[oh-my-zsh] owner of these directories is either root or your current user.
 | 
						|
[oh-my-zsh] The following command may help:
 | 
						|
[oh-my-zsh]     compaudit | xargs chmod g-w,o-w
 | 
						|
 | 
						|
[oh-my-zsh] If the above didn't help or you want to skip the verification of
 | 
						|
[oh-my-zsh] insecure directories you can set the variable ZSH_DISABLE_COMPFIX to
 | 
						|
[oh-my-zsh] "true" before oh-my-zsh is sourced in your zshrc file.
 | 
						|
 | 
						|
EOD
 | 
						|
}
 |