63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Bash
		
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Bash
		
	
	
#!/usr/bin/env sh
 | 
						|
# Here is the script to deploy the cert to your cpanel using the cpanel API.
 | 
						|
# Uses command line uapi.  --user option is needed only if run as root.
 | 
						|
# Returns 0 when success.
 | 
						|
#
 | 
						|
# Please note that I am no longer using Github. If you want to report an issue
 | 
						|
# or contact me, visit https://forum.webseodesigners.com/web-design-seo-and-hosting-f16/
 | 
						|
#
 | 
						|
# Written by Santeri Kannisto <santeri.kannisto@webseodesigners.com>
 | 
						|
# Public domain, 2017-2018
 | 
						|
 | 
						|
#export DEPLOY_CPANEL_USER=myusername
 | 
						|
 | 
						|
########  Public functions #####################
 | 
						|
 | 
						|
#domain keyfile certfile cafile fullchain
 | 
						|
 | 
						|
cpanel_uapi_deploy() {
 | 
						|
  _cdomain="$1"
 | 
						|
  _ckey="$2"
 | 
						|
  _ccert="$3"
 | 
						|
  _cca="$4"
 | 
						|
  _cfullchain="$5"
 | 
						|
 | 
						|
  _debug _cdomain "$_cdomain"
 | 
						|
  _debug _ckey "$_ckey"
 | 
						|
  _debug _ccert "$_ccert"
 | 
						|
  _debug _cca "$_cca"
 | 
						|
  _debug _cfullchain "$_cfullchain"
 | 
						|
 | 
						|
  if ! _exists uapi; then
 | 
						|
    _err "The command uapi is not found."
 | 
						|
    return 1
 | 
						|
  fi
 | 
						|
  # read cert and key files and urlencode both
 | 
						|
  _cert=$(_url_encode <"$_ccert")
 | 
						|
  _key=$(_url_encode <"$_ckey")
 | 
						|
 | 
						|
  _debug _cert "$_cert"
 | 
						|
  _debug _key "$_key"
 | 
						|
 | 
						|
  if [ "$(id -u)" = 0 ]; then
 | 
						|
    if [ -z "$DEPLOY_CPANEL_USER" ]; then
 | 
						|
      _err "It seems that you are root, please define the target user name: export DEPLOY_CPANEL_USER=username"
 | 
						|
      return 1
 | 
						|
    fi
 | 
						|
    _savedomainconf DEPLOY_CPANEL_USER "$DEPLOY_CPANEL_USER"
 | 
						|
    _response=$(uapi --user="$DEPLOY_CPANEL_USER" SSL install_ssl domain="$_cdomain" cert="$_cert" key="$_key")
 | 
						|
  else
 | 
						|
    _response=$(uapi SSL install_ssl domain="$_cdomain" cert="$_cert" key="$_key")
 | 
						|
  fi
 | 
						|
  error_response="status: 0"
 | 
						|
  if test "${_response#*$error_response}" != "$_response"; then
 | 
						|
    _err "Error in deploying certificate:"
 | 
						|
    _err "$_response"
 | 
						|
    return 1
 | 
						|
  fi
 | 
						|
 | 
						|
  _debug response "$_response"
 | 
						|
  _info "Certificate successfully deployed"
 | 
						|
  return 0
 | 
						|
}
 |