+static struct ldaptls *
+tlsm_copy_config ( const struct ldaptls *config )
+{
+ struct ldaptls *copy;
+
+ assert(config);
+
+ copy = LDAP_MALLOC(sizeof(*copy));
+ if (!copy)
+ return NULL;
+
+ memset(copy, 0, sizeof(*copy));
+
+ if (config->lt_certfile)
+ copy->lt_certfile = LDAP_STRDUP(config->lt_certfile);
+ if (config->lt_keyfile)
+ copy->lt_keyfile = LDAP_STRDUP(config->lt_keyfile);
+ if (config->lt_dhfile)
+ copy->lt_dhfile = LDAP_STRDUP(config->lt_dhfile);
+ if (config->lt_cacertfile)
+ copy->lt_cacertfile = LDAP_STRDUP(config->lt_cacertfile);
+ if (config->lt_cacertdir)
+ copy->lt_cacertdir = LDAP_STRDUP(config->lt_cacertdir);
+ if (config->lt_ciphersuite)
+ copy->lt_ciphersuite = LDAP_STRDUP(config->lt_ciphersuite);
+ if (config->lt_crlfile)
+ copy->lt_crlfile = LDAP_STRDUP(config->lt_crlfile);
+ if (config->lt_randfile)
+ copy->lt_randfile = LDAP_STRDUP(config->lt_randfile);
+
+ copy->lt_protocol_min = config->lt_protocol_min;
+
+ return copy;
+}
+
+static void
+tlsm_free_config ( struct ldaptls *config )
+{
+ assert(config);
+
+ if (config->lt_certfile)
+ LDAP_FREE(config->lt_certfile);
+ if (config->lt_keyfile)
+ LDAP_FREE(config->lt_keyfile);
+ if (config->lt_dhfile)
+ LDAP_FREE(config->lt_dhfile);
+ if (config->lt_cacertfile)
+ LDAP_FREE(config->lt_cacertfile);
+ if (config->lt_cacertdir)
+ LDAP_FREE(config->lt_cacertdir);
+ if (config->lt_ciphersuite)
+ LDAP_FREE(config->lt_ciphersuite);
+ if (config->lt_crlfile)
+ LDAP_FREE(config->lt_crlfile);
+ if (config->lt_randfile)
+ LDAP_FREE(config->lt_randfile);
+
+ LDAP_FREE(config);
+}
+