Brian Candler
7 years ago
2 changed files with 123 additions and 5 deletions
@ -0,0 +1,100 @@ |
|||||||
|
#!/usr/bin/env sh |
||||||
|
|
||||||
|
#Here is a script to deploy cert to unifi server. |
||||||
|
|
||||||
|
#returns 0 means success, otherwise error. |
||||||
|
|
||||||
|
#DEPLOY_UNIFI_KEYSTORE="/usr/lib/unifi/data/keystore" |
||||||
|
#DEPLOY_UNIFI_KEYPASS="aircontrolenterprise" |
||||||
|
#DEPLOY_UNIFI_RELOAD="service unifi restart" |
||||||
|
|
||||||
|
######## Public functions ##################### |
||||||
|
|
||||||
|
#domain keyfile certfile cafile fullchain |
||||||
|
unifi_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 keytool; then |
||||||
|
_err "keytool not found" |
||||||
|
return 1 |
||||||
|
fi |
||||||
|
|
||||||
|
DEFAULT_UNIFI_KEYSTORE="/usr/lib/unifi/data/keystore" |
||||||
|
_unifi_keystore="${DEPLOY_UNIFI_KEYSTORE:-$DEFAULT_UNIFI_KEYSTORE}" |
||||||
|
DEFAULT_UNIFI_KEYPASS="aircontrolenterprise" |
||||||
|
_unifi_keypass="${DEPLOY_UNIFI_KEYPASS:-$DEFAULT_UNIFI_KEYPASS}" |
||||||
|
DEFAULT_UNIFI_RELOAD="service unifi restart" |
||||||
|
_reload="${DEPLOY_UNIFI_RELOAD:-$DEFAULT_UNIFI_RELOAD}" |
||||||
|
|
||||||
|
_debug _unifi_keystore "$_unifi_keystore" |
||||||
|
if [ ! -f "$_unifi_keystore" ]; then |
||||||
|
if [ -z "$DEPLOY_UNIFI_KEYSTORE" ]; then |
||||||
|
_err "unifi keystore is not found, please define DEPLOY_UNIFI_KEYSTORE" |
||||||
|
return 1 |
||||||
|
else |
||||||
|
_err "It seems that the specified unifi keystore is not valid, please check." |
||||||
|
return 1 |
||||||
|
fi |
||||||
|
fi |
||||||
|
if [ ! -w "$_unifi_keystore" ]; then |
||||||
|
_err "The file $_unifi_keystore is not writable, please change the permission." |
||||||
|
return 1 |
||||||
|
fi |
||||||
|
|
||||||
|
_info "Generate import pkcs12" |
||||||
|
_import_pkcs12="$(_mktemp)" |
||||||
|
_toPkcs "$_import_pkcs12" "$_ckey" "$_ccert" "$_cca" "$_unifi_keypass" unifi root |
||||||
|
if [ "$?" != "0" ]; then |
||||||
|
_err "Oops, error creating import pkcs12, please report bug to us." |
||||||
|
return 1 |
||||||
|
fi |
||||||
|
|
||||||
|
_info "Modify unifi keystore: $_unifi_keystore" |
||||||
|
if keytool -importkeystore \ |
||||||
|
-deststorepass "$_unifi_keypass" -destkeypass "$_unifi_keypass" -destkeystore "$_unifi_keystore" \ |
||||||
|
-srckeystore "$_import_pkcs12" -srcstoretype PKCS12 -srcstorepass "$_unifi_keypass" \ |
||||||
|
-alias unifi -noprompt; then |
||||||
|
_info "Import keystore success!" |
||||||
|
rm "$_import_pkcs12" |
||||||
|
else |
||||||
|
_err "Import unifi keystore error, please report bug to us." |
||||||
|
rm "$_import_pkcs12" |
||||||
|
return 1 |
||||||
|
fi |
||||||
|
|
||||||
|
_info "Run reload: $_reload" |
||||||
|
if eval "$_reload"; then |
||||||
|
_info "Reload success!" |
||||||
|
if [ "$DEPLOY_UNIFI_KEYSTORE" ]; then |
||||||
|
_savedomainconf DEPLOY_UNIFI_KEYSTORE "$DEPLOY_UNIFI_KEYSTORE" |
||||||
|
else |
||||||
|
_cleardomainconf DEPLOY_UNIFI_KEYSTORE |
||||||
|
fi |
||||||
|
if [ "$DEPLOY_UNIFI_KEYPASS" ]; then |
||||||
|
_savedomainconf DEPLOY_UNIFI_KEYPASS "$DEPLOY_UNIFI_KEYPASS" |
||||||
|
else |
||||||
|
_cleardomainconf DEPLOY_UNIFI_KEYPASS |
||||||
|
fi |
||||||
|
if [ "$DEPLOY_UNIFI_RELOAD" ]; then |
||||||
|
_savedomainconf DEPLOY_UNIFI_RELOAD "$DEPLOY_UNIFI_RELOAD" |
||||||
|
else |
||||||
|
_cleardomainconf DEPLOY_UNIFI_RELOAD |
||||||
|
fi |
||||||
|
return 0 |
||||||
|
else |
||||||
|
_err "Reload error" |
||||||
|
return 1 |
||||||
|
fi |
||||||
|
return 0 |
||||||
|
|
||||||
|
} |
Loading…
Reference in new issue