Rework read/save config to not save default values
Add and use _readaccountconf_mutable_default and _saveaccountconf_mutable_default helpers to capture common default value handling. New approach also eliminates need for separate underscore-prefixed version of each conf var.pull/3392/head
							parent
							
								
									d1cdc1c6a0
								
							
						
					
					
						commit
						d044545520
					
				
							
								
								
									
										253
									
								
								notify/smtp.sh
								
								
								
								
							
							
						
						
									
										253
									
								
								notify/smtp.sh
								
								
								
								
							|  | @ -17,155 +17,150 @@ | |||
| # SMTP_TIMEOUT="30"  # seconds for SMTP operations to timeout | ||||
| # SMTP_BIN="/path/to/curl_or_python"  # default finds first of curl, python3, or python on PATH | ||||
| 
 | ||||
| SMTP_SECURE_DEFAULT="none" | ||||
| SMTP_TIMEOUT_DEFAULT="30" | ||||
| 
 | ||||
| # subject content statuscode | ||||
| smtp_send() { | ||||
|   _SMTP_SUBJECT="$1" | ||||
|   _SMTP_CONTENT="$2" | ||||
|   SMTP_SUBJECT="$1" | ||||
|   SMTP_CONTENT="$2" | ||||
|   # UNUSED: _statusCode="$3" # 0: success, 1: error 2($RENEW_SKIP): skipped | ||||
| 
 | ||||
|   # Load config: | ||||
|   SMTP_FROM="${SMTP_FROM:-$(_readaccountconf_mutable SMTP_FROM)}" | ||||
|   SMTP_TO="${SMTP_TO:-$(_readaccountconf_mutable SMTP_TO)}" | ||||
|   SMTP_HOST="${SMTP_HOST:-$(_readaccountconf_mutable SMTP_HOST)}" | ||||
|   SMTP_PORT="${SMTP_PORT:-$(_readaccountconf_mutable SMTP_PORT)}" | ||||
|   SMTP_SECURE="${SMTP_SECURE:-$(_readaccountconf_mutable SMTP_SECURE)}" | ||||
|   SMTP_USERNAME="${SMTP_USERNAME:-$(_readaccountconf_mutable SMTP_USERNAME)}" | ||||
|   SMTP_PASSWORD="${SMTP_PASSWORD:-$(_readaccountconf_mutable SMTP_PASSWORD)}" | ||||
|   SMTP_TIMEOUT="${SMTP_TIMEOUT:-$(_readaccountconf_mutable SMTP_TIMEOUT)}" | ||||
|   SMTP_BIN="${SMTP_BIN:-$(_readaccountconf_mutable SMTP_BIN)}" | ||||
| 
 | ||||
|   _debug "SMTP_FROM" "$SMTP_FROM" | ||||
|   _debug "SMTP_TO" "$SMTP_TO" | ||||
|   _debug "SMTP_HOST" "$SMTP_HOST" | ||||
|   _debug "SMTP_PORT" "$SMTP_PORT" | ||||
|   _debug "SMTP_SECURE" "$SMTP_SECURE" | ||||
|   _debug "SMTP_USERNAME" "$SMTP_USERNAME" | ||||
|   _secure_debug "SMTP_PASSWORD" "$SMTP_PASSWORD" | ||||
|   _debug "SMTP_TIMEOUT" "$SMTP_TIMEOUT" | ||||
|   _debug "SMTP_BIN" "$SMTP_BIN" | ||||
| 
 | ||||
|   _debug "_SMTP_SUBJECT" "$_SMTP_SUBJECT" | ||||
|   _debug "_SMTP_CONTENT" "$_SMTP_CONTENT" | ||||
| 
 | ||||
|   # Validate config and apply defaults: | ||||
|   # _SMTP_* variables are the resolved (with defaults) versions of SMTP_*. | ||||
|   # (The _SMTP_* versions will not be stored in account conf.) | ||||
| 
 | ||||
|   # Load and validate config: | ||||
|   SMTP_BIN="$(_readaccountconf_mutable_default SMTP_BIN)" | ||||
|   if [ -n "$SMTP_BIN" ] && ! _exists "$SMTP_BIN"; then | ||||
|     _err "SMTP_BIN '$SMTP_BIN' does not exist." | ||||
|     return 1 | ||||
|   fi | ||||
|   _SMTP_BIN="$SMTP_BIN" | ||||
|   if [ -z "$_SMTP_BIN" ]; then | ||||
|   if [ -z "$SMTP_BIN" ]; then | ||||
|     # Look for a command that can communicate with an SMTP server. | ||||
|     # (Please don't add sendmail, ssmtp, mutt, mail, or msmtp here. | ||||
|     # Those are already handled by the "mail" notify hook.) | ||||
|     for cmd in curl python3 python2.7 python pypy3 pypy; do | ||||
|       if _exists "$cmd"; then | ||||
|         _SMTP_BIN="$cmd" | ||||
|         SMTP_BIN="$cmd" | ||||
|         break | ||||
|       fi | ||||
|     done | ||||
|     if [ -z "$_SMTP_BIN" ]; then | ||||
|     if [ -z "$SMTP_BIN" ]; then | ||||
|       _err "The smtp notify-hook requires curl or Python, but can't find any." | ||||
|       _err 'If you have one of them, define SMTP_BIN="/path/to/curl_or_python".' | ||||
|       _err 'Otherwise, see if you can use the "mail" notify-hook instead.' | ||||
|       return 1 | ||||
|     fi | ||||
|     _debug "_SMTP_BIN" "$_SMTP_BIN" | ||||
|   fi | ||||
|   _debug SMTP_BIN "$SMTP_BIN" | ||||
|   _saveaccountconf_mutable_default SMTP_BIN "$SMTP_BIN" | ||||
| 
 | ||||
|   SMTP_FROM="$(_readaccountconf_mutable_default SMTP_FROM)" | ||||
|   if [ -z "$SMTP_FROM" ]; then | ||||
|     _err "You must define SMTP_FROM as the sender email address." | ||||
|     return 1 | ||||
|   fi | ||||
|   _SMTP_FROM="$SMTP_FROM" | ||||
|   _debug SMTP_FROM "$SMTP_FROM" | ||||
|   _saveaccountconf_mutable_default SMTP_FROM "$SMTP_FROM" | ||||
| 
 | ||||
|   SMTP_TO="$(_readaccountconf_mutable_default SMTP_TO)" | ||||
|   if [ -z "$SMTP_TO" ]; then | ||||
|     _err "You must define SMTP_TO as the recipient email address." | ||||
|     return 1 | ||||
|   fi | ||||
|   _SMTP_TO="$SMTP_TO" | ||||
|   _debug SMTP_TO "$SMTP_TO" | ||||
|   _saveaccountconf_mutable_default SMTP_TO "$SMTP_TO" | ||||
| 
 | ||||
|   SMTP_HOST="$(_readaccountconf_mutable_default SMTP_HOST)" | ||||
|   if [ -z "$SMTP_HOST" ]; then | ||||
|     _err "You must define SMTP_HOST as the SMTP server hostname." | ||||
|     return 1 | ||||
|   fi | ||||
|   _SMTP_HOST="$SMTP_HOST" | ||||
|   _debug SMTP_HOST "$SMTP_HOST" | ||||
|   _saveaccountconf_mutable_default SMTP_HOST "$SMTP_HOST" | ||||
| 
 | ||||
|   _SMTP_SECURE="${SMTP_SECURE:-none}" | ||||
|   case "$_SMTP_SECURE" in | ||||
|   "none") smtp_default_port="25" ;; | ||||
|   "ssl") smtp_default_port="465" ;; | ||||
|   "tls") smtp_default_port="587" ;; | ||||
|   SMTP_SECURE="$(_readaccountconf_mutable_default SMTP_SECURE "$SMTP_SECURE_DEFAULT")" | ||||
|   case "$SMTP_SECURE" in | ||||
|   "none") smtp_port_default="25" ;; | ||||
|   "ssl") smtp_port_default="465" ;; | ||||
|   "tls") smtp_port_default="587" ;; | ||||
|   *) | ||||
|     _err "Invalid SMTP_SECURE='$SMTP_SECURE'. It must be 'ssl', 'tls' or 'none'." | ||||
|     return 1 | ||||
|     ;; | ||||
|   esac | ||||
|   _debug SMTP_SECURE "$SMTP_SECURE" | ||||
|   _saveaccountconf_mutable_default SMTP_SECURE "$SMTP_SECURE" "$SMTP_SECURE_DEFAULT" | ||||
| 
 | ||||
|   _SMTP_PORT="${SMTP_PORT:-$smtp_default_port}" | ||||
|   if [ -z "$SMTP_PORT" ]; then | ||||
|     _debug "_SMTP_PORT" "$_SMTP_PORT" | ||||
|   fi | ||||
|   SMTP_PORT="$(_readaccountconf_mutable_default SMTP_PORT "$smtp_port_default")" | ||||
|   case "$SMTP_PORT" in | ||||
|   *[!0-9]*) | ||||
|     _err "Invalid SMTP_PORT='$SMTP_PORT'. It must be a port number." | ||||
|     return 1 | ||||
|     ;; | ||||
|   esac | ||||
|   _debug SMTP_PORT "$SMTP_PORT" | ||||
|   _saveaccountconf_mutable_default SMTP_PORT "$SMTP_PORT" "$smtp_port_default" | ||||
| 
 | ||||
|   _SMTP_USERNAME="$SMTP_USERNAME" | ||||
|   _SMTP_PASSWORD="$SMTP_PASSWORD" | ||||
|   _SMTP_TIMEOUT="${SMTP_TIMEOUT:-30}" | ||||
|   _SMTP_X_MAILER="${PROJECT_NAME} ${VER} --notify-hook smtp" | ||||
|   SMTP_USERNAME="$(_readaccountconf_mutable_default SMTP_USERNAME)" | ||||
|   _debug SMTP_USERNAME "$SMTP_USERNAME" | ||||
|   _saveaccountconf_mutable_default SMTP_USERNAME "$SMTP_USERNAME" | ||||
| 
 | ||||
|   SMTP_PASSWORD="$(_readaccountconf_mutable_default SMTP_PASSWORD)" | ||||
|   _secure_debug SMTP_PASSWORD "$SMTP_PASSWORD" | ||||
|   _saveaccountconf_mutable_default SMTP_PASSWORD "$SMTP_PASSWORD" | ||||
| 
 | ||||
|   SMTP_TIMEOUT="$(_readaccountconf_mutable_default SMTP_TIMEOUT "$SMTP_TIMEOUT_DEFAULT")" | ||||
|   _debug SMTP_TIMEOUT "$SMTP_TIMEOUT" | ||||
|   _saveaccountconf_mutable_default SMTP_TIMEOUT "$SMTP_TIMEOUT" "$SMTP_TIMEOUT_DEFAULT" | ||||
| 
 | ||||
|   SMTP_X_MAILER="${PROJECT_NAME} ${VER} --notify-hook smtp" | ||||
| 
 | ||||
|   # Run with --debug 2 (or above) to echo the transcript of the SMTP session. | ||||
|   # Careful: this may include SMTP_PASSWORD in plaintext! | ||||
|   if [ "${DEBUG:-$DEBUG_LEVEL_NONE}" -ge "$DEBUG_LEVEL_2" ]; then | ||||
|     _SMTP_SHOW_TRANSCRIPT="True" | ||||
|     SMTP_SHOW_TRANSCRIPT="True" | ||||
|   else | ||||
|     _SMTP_SHOW_TRANSCRIPT="" | ||||
|     SMTP_SHOW_TRANSCRIPT="" | ||||
|   fi | ||||
| 
 | ||||
|   _debug SMTP_SUBJECT "$SMTP_SUBJECT" | ||||
|   _debug SMTP_CONTENT "$SMTP_CONTENT" | ||||
| 
 | ||||
|   # Send the message: | ||||
|   case "$(basename "$_SMTP_BIN")" in | ||||
|   case "$(basename "$SMTP_BIN")" in | ||||
|   curl) _smtp_send=_smtp_send_curl ;; | ||||
|   py*) _smtp_send=_smtp_send_python ;; | ||||
|   *) | ||||
|     _err "Can't figure out how to invoke $_SMTP_BIN." | ||||
|     _err "Can't figure out how to invoke '$SMTP_BIN'." | ||||
|     _err "Check your SMTP_BIN setting." | ||||
|     return 1 | ||||
|     ;; | ||||
|   esac | ||||
| 
 | ||||
|   if ! smtp_output="$($_smtp_send)"; then | ||||
|     _err "Error sending message with $_SMTP_BIN." | ||||
|     _err "Error sending message with $SMTP_BIN." | ||||
|     if [ -n "$smtp_output" ]; then | ||||
|       _err "$smtp_output" | ||||
|     fi | ||||
|     return 1 | ||||
|   fi | ||||
| 
 | ||||
|   # Save config only if send was successful: | ||||
|   _saveaccountconf_mutable SMTP_BIN "$SMTP_BIN" | ||||
|   _saveaccountconf_mutable SMTP_FROM "$SMTP_FROM" | ||||
|   _saveaccountconf_mutable SMTP_TO "$SMTP_TO" | ||||
|   _saveaccountconf_mutable SMTP_HOST "$SMTP_HOST" | ||||
|   _saveaccountconf_mutable SMTP_PORT "$SMTP_PORT" | ||||
|   _saveaccountconf_mutable SMTP_SECURE "$SMTP_SECURE" | ||||
|   _saveaccountconf_mutable SMTP_USERNAME "$SMTP_USERNAME" | ||||
|   _saveaccountconf_mutable SMTP_PASSWORD "$SMTP_PASSWORD" | ||||
|   _saveaccountconf_mutable SMTP_TIMEOUT "$SMTP_TIMEOUT" | ||||
| 
 | ||||
|   return 0 | ||||
| } | ||||
| 
 | ||||
| # Send the message via curl using _SMTP_* variables | ||||
| ## | ||||
| ## curl smtp sending | ||||
| ## | ||||
| 
 | ||||
| # Send the message via curl using SMTP_* variables | ||||
| _smtp_send_curl() { | ||||
|   # curl passes --mail-from and --mail-rcpt directly to the SMTP protocol without | ||||
|   # additional parsing, and SMTP requires addr-spec only (no display names). | ||||
|   # In the future, maybe try to parse the addr-spec out for curl args (non-trivial). | ||||
|   if _email_has_display_name "$_SMTP_FROM"; then | ||||
|   if _email_has_display_name "$SMTP_FROM"; then | ||||
|     _err "curl smtp only allows a simple email address in SMTP_FROM." | ||||
|     _err "Change your SMTP_FROM='$SMTP_FROM' to remove the display name." | ||||
|     return 1 | ||||
|   fi | ||||
|   if _email_has_display_name "$_SMTP_TO"; then | ||||
|   if _email_has_display_name "$SMTP_TO"; then | ||||
|     _err "curl smtp only allows simple email addresses in SMTP_TO." | ||||
|     _err "Change your SMTP_TO='$SMTP_TO' to remove the display name(s)." | ||||
|     return 1 | ||||
|  | @ -173,20 +168,20 @@ _smtp_send_curl() { | |||
| 
 | ||||
|   # Build curl args in $@ | ||||
| 
 | ||||
|   case "$_SMTP_SECURE" in | ||||
|   case "$SMTP_SECURE" in | ||||
|   none) | ||||
|     set -- --url "smtp://${_SMTP_HOST}:${_SMTP_PORT}" | ||||
|     set -- --url "smtp://${SMTP_HOST}:${SMTP_PORT}" | ||||
|     ;; | ||||
|   ssl) | ||||
|     set -- --url "smtps://${_SMTP_HOST}:${_SMTP_PORT}" | ||||
|     set -- --url "smtps://${SMTP_HOST}:${SMTP_PORT}" | ||||
|     ;; | ||||
|   tls) | ||||
|     set -- --url "smtp://${_SMTP_HOST}:${_SMTP_PORT}" --ssl-reqd | ||||
|     set -- --url "smtp://${SMTP_HOST}:${SMTP_PORT}" --ssl-reqd | ||||
|     ;; | ||||
|   *) | ||||
|     # This will only occur if someone adds a new SMTP_SECURE option above | ||||
|     # without updating this code for it. | ||||
|     _err "Unhandled _SMTP_SECURE='$_SMTP_SECURE' in _smtp_send_curl" | ||||
|     _err "Unhandled SMTP_SECURE='$SMTP_SECURE' in _smtp_send_curl" | ||||
|     _err "Please re-run with --debug and report a bug." | ||||
|     return 1 | ||||
|     ;; | ||||
|  | @ -194,23 +189,23 @@ _smtp_send_curl() { | |||
| 
 | ||||
|   set -- "$@" \ | ||||
|     --upload-file - \ | ||||
|     --mail-from "$_SMTP_FROM" \ | ||||
|     --max-time "$_SMTP_TIMEOUT" | ||||
|     --mail-from "$SMTP_FROM" \ | ||||
|     --max-time "$SMTP_TIMEOUT" | ||||
| 
 | ||||
|   # Burst comma-separated $_SMTP_TO into individual --mail-rcpt args. | ||||
|   _to="${_SMTP_TO}," | ||||
|   # Burst comma-separated $SMTP_TO into individual --mail-rcpt args. | ||||
|   _to="${SMTP_TO}," | ||||
|   while [ -n "$_to" ]; do | ||||
|     _rcpt="${_to%%,*}" | ||||
|     _to="${_to#*,}" | ||||
|     set -- "$@" --mail-rcpt "$_rcpt" | ||||
|   done | ||||
| 
 | ||||
|   _smtp_login="${_SMTP_USERNAME}:${_SMTP_PASSWORD}" | ||||
|   _smtp_login="${SMTP_USERNAME}:${SMTP_PASSWORD}" | ||||
|   if [ "$_smtp_login" != ":" ]; then | ||||
|     set -- "$@" --user "$_smtp_login" | ||||
|   fi | ||||
| 
 | ||||
|   if [ "$_SMTP_SHOW_TRANSCRIPT" = "True" ]; then | ||||
|   if [ "$SMTP_SHOW_TRANSCRIPT" = "True" ]; then | ||||
|     set -- "$@" --verbose | ||||
|   else | ||||
|     set -- "$@" --silent --show-error | ||||
|  | @ -218,24 +213,24 @@ _smtp_send_curl() { | |||
| 
 | ||||
|   raw_message="$(_smtp_raw_message)" | ||||
| 
 | ||||
|   _debug2 "curl command:" "$_SMTP_BIN" "$*" | ||||
|   _debug2 "curl command:" "$SMTP_BIN" "$*" | ||||
|   _debug2 "raw_message:\n$raw_message" | ||||
| 
 | ||||
|   echo "$raw_message" | "$_SMTP_BIN" "$@" | ||||
|   echo "$raw_message" | "$SMTP_BIN" "$@" | ||||
| } | ||||
| 
 | ||||
| # Output an RFC-822 / RFC-5322 email message using _SMTP_* variables | ||||
| # Output an RFC-822 / RFC-5322 email message using SMTP_* variables | ||||
| _smtp_raw_message() { | ||||
|   echo "From: $_SMTP_FROM" | ||||
|   echo "To: $_SMTP_TO" | ||||
|   echo "Subject: $(_mime_encoded_word "$_SMTP_SUBJECT")" | ||||
|   echo "From: $SMTP_FROM" | ||||
|   echo "To: $SMTP_TO" | ||||
|   echo "Subject: $(_mime_encoded_word "$SMTP_SUBJECT")" | ||||
|   if _exists date; then | ||||
|     echo "Date: $(date +'%a, %-d %b %Y %H:%M:%S %z')" | ||||
|   fi | ||||
|   echo "Content-Type: text/plain; charset=utf-8" | ||||
|   echo "X-Mailer: $_SMTP_X_MAILER" | ||||
|   echo "X-Mailer: $SMTP_X_MAILER" | ||||
|   echo | ||||
|   echo "$_SMTP_CONTENT" | ||||
|   echo "$SMTP_CONTENT" | ||||
| } | ||||
| 
 | ||||
| # Convert text to RFC-2047 MIME "encoded word" format if it contains non-ASCII chars | ||||
|  | @ -260,12 +255,16 @@ _email_has_display_name() { | |||
|   expr "$_email" : '^.*[<>"]' >/dev/null | ||||
| } | ||||
| 
 | ||||
| # Send the message via Python using _SMTP_* variables | ||||
| ## | ||||
| ## Python smtp sending | ||||
| ## | ||||
| 
 | ||||
| # Send the message via Python using SMTP_* variables | ||||
| _smtp_send_python() { | ||||
|   _debug "Python version" "$("$_SMTP_BIN" --version 2>&1)" | ||||
|   _debug "Python version" "$("$SMTP_BIN" --version 2>&1)" | ||||
| 
 | ||||
|   # language=Python | ||||
|   "$_SMTP_BIN" <<EOF | ||||
|   "$SMTP_BIN" <<PYTHON | ||||
| # This code is meant to work with either Python 2.7.x or Python 3.4+. | ||||
| try: | ||||
|     try: | ||||
|  | @ -279,20 +278,20 @@ except ImportError as err: | |||
|           " a reduced version of Python unsuitable for sending mail: %s" % err) | ||||
|     exit(1) | ||||
| 
 | ||||
| show_transcript = """$_SMTP_SHOW_TRANSCRIPT""" == "True" | ||||
| show_transcript = """$SMTP_SHOW_TRANSCRIPT""" == "True" | ||||
| 
 | ||||
| smtp_host = """$_SMTP_HOST""" | ||||
| smtp_port = int("""$_SMTP_PORT""") | ||||
| smtp_secure = """$_SMTP_SECURE""" | ||||
| username = """$_SMTP_USERNAME""" | ||||
| password = """$_SMTP_PASSWORD""" | ||||
| timeout=int("""$_SMTP_TIMEOUT""")  # seconds | ||||
| x_mailer="""$_SMTP_X_MAILER""" | ||||
| smtp_host = """$SMTP_HOST""" | ||||
| smtp_port = int("""$SMTP_PORT""") | ||||
| smtp_secure = """$SMTP_SECURE""" | ||||
| username = """$SMTP_USERNAME""" | ||||
| password = """$SMTP_PASSWORD""" | ||||
| timeout=int("""$SMTP_TIMEOUT""")  # seconds | ||||
| x_mailer="""$SMTP_X_MAILER""" | ||||
| 
 | ||||
| from_email="""$_SMTP_FROM""" | ||||
| to_emails="""$_SMTP_TO"""  # can be comma-separated | ||||
| subject="""$_SMTP_SUBJECT""" | ||||
| content="""$_SMTP_CONTENT""" | ||||
| from_email="""$SMTP_FROM""" | ||||
| to_emails="""$SMTP_TO"""  # can be comma-separated | ||||
| subject="""$SMTP_SUBJECT""" | ||||
| content="""$SMTP_CONTENT""" | ||||
| 
 | ||||
| try: | ||||
|     msg = EmailMessage() | ||||
|  | @ -330,5 +329,49 @@ except SocketError as err: | |||
| finally: | ||||
|     if smtp is not None: | ||||
|         smtp.quit() | ||||
| EOF | ||||
| PYTHON | ||||
| } | ||||
| 
 | ||||
| ## | ||||
| ## Conf helpers | ||||
| ## | ||||
| 
 | ||||
| #_readaccountconf_mutable_default name default_value | ||||
| # Given a name like MY_CONF: | ||||
| #   - if MY_CONF is set and non-empty, output $MY_CONF | ||||
| #   - if MY_CONF is set _empty_, output $default_value | ||||
| #     (lets user `export MY_CONF=` to clear previous saved value | ||||
| #     and return to default, without user having to know default) | ||||
| #   - otherwise if _readaccountconf_mutable $name is non-empty, return that | ||||
| #     (value of SAVED_MY_CONF from account.conf) | ||||
| #   - otherwise output $default_value | ||||
| _readaccountconf_mutable_default() { | ||||
|   _name="$1" | ||||
|   _default_value="$2" | ||||
| 
 | ||||
|   eval "_value=\"\$$_name\"" | ||||
|   eval "_explicit_empty_value=\"\${${_name}+empty}\"" | ||||
|   if [ -z "${_value}" ] && [ "${_explicit_empty_value:-}" != "empty" ]; then | ||||
|     _value="$(_readaccountconf_mutable "$_name")" | ||||
|   fi | ||||
|   if [ -z "${_value}" ]; then | ||||
|     _value="$_default_value" | ||||
|   fi | ||||
|   printf "%s" "$_value" | ||||
| } | ||||
| 
 | ||||
| #_saveaccountconf_mutable_default name value default_value base64encode | ||||
| # Like _saveaccountconf_mutable, but if value is default_value | ||||
| # then _clearaccountconf_mutable instead | ||||
| _saveaccountconf_mutable_default() { | ||||
|   _name="$1" | ||||
|   _value="$2" | ||||
|   _default_value="$3" | ||||
|   _base64encode="$4" | ||||
| 
 | ||||
|   if [ "$_value" != "$_default_value" ]; then | ||||
|     _saveaccountconf_mutable "$_name" "$_value" "$_base64encode" | ||||
|   else | ||||
|     _clearaccountconf_mutable "$_name" | ||||
|   fi | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 medmunds
						medmunds