return res;
 }
 
+/*!
+ * \brief Check if configuration file is valid
+ */
+static inline int valid_config(const struct ast_config *cfg)
+{
+       return cfg && cfg != CONFIG_STATUS_FILEINVALID;
+}
+
 /*! 
  * \brief The handler for the change password option.
  * \param vmu The voicemail user to work with.
                }
                /* Fall-through */
        case OPT_PWLOC_VOICEMAILCONF:
-               if ((cfg = ast_config_load(VOICEMAIL_CONFIG, config_flags)) && cfg != CONFIG_STATUS_FILEINVALID) {
+               if ((cfg = ast_config_load(VOICEMAIL_CONFIG, config_flags)) && valid_config(cfg)) {
                        while ((category = ast_category_browse(cfg, category))) {
                                if (!strcasecmp(category, vmu->context)) {
                                        if (!(tmp = ast_variable_retrieve(cfg, category, vmu->mailbox))) {
                                reset_user_pw(vmu->context, vmu->mailbox, newpassword);
                                ast_copy_string(vmu->password, newpassword, sizeof(vmu->password));
                                ast_config_text_file_save(VOICEMAIL_CONFIG, cfg, "AppVoicemail");
+                               ast_config_destroy(cfg);
                                break;
                        }
+
+                       ast_config_destroy(cfg);
                }
                /* Fall-through */
        case OPT_PWLOC_USERSCONF:
                /* check users.conf and update the password stored for the mailbox */
                /* if no vmsecret entry exists create one. */
-               if ((cfg = ast_config_load("users.conf", config_flags)) && cfg != CONFIG_STATUS_FILEINVALID) {
+               if ((cfg = ast_config_load("users.conf", config_flags)) && valid_config(cfg)) {
                        ast_debug(4, "we are looking for %s\n", vmu->mailbox);
                        for (category = ast_category_browse(cfg, NULL); category; category = ast_category_browse(cfg, category)) {
                                ast_debug(4, "users.conf: %s\n", category);
                                ast_copy_string(vmu->password, newpassword, sizeof(vmu->password));
                                ast_config_text_file_save("users.conf", cfg, "AppVoicemail");
                        }
+
+                       ast_config_destroy(cfg);
                }
        }
 }
                        res = -1;
                        break;
                }
-               if (cfg && cfg != CONFIG_STATUS_FILEINVALID) {
+               if (valid_config(cfg)) {
                        if (!(idata.context = ast_variable_retrieve(cfg, "message", "context"))) {
                                idata.context = "";
                        }
        if (obj) {
                ast_odbc_release_obj(obj);
        }
-       if (cfg)
+       if (valid_config(cfg))
                ast_config_destroy(cfg);
        if (fdm != MAP_FAILED)
                munmap(fdm, fdlen);
        if (strlen(fromfile) < sizeof(fromfile) - 5) {
                strcat(fromfile, ".txt");
        }
-       if (!(msg_cfg = ast_config_load(fromfile, config_flags))) {
+       if (!(msg_cfg = ast_config_load(fromfile, config_flags)) || !(valid_config(msg_cfg))) {
                ast_debug(1, "Config load for message text file '%s' failed\n", fromfile);
                return;
        }
                        if (strlen(fromfile) < sizeof(fromfile) - 5) {
                                strcat(fromfile, ".txt");
                        }
-                       if ((msg_cfg = ast_config_load(fromfile, config_flags))) {
+                       if ((msg_cfg = ast_config_load(fromfile, config_flags)) && valid_config(msg_cfg)) {
                                if ((v = ast_variable_retrieve(msg_cfg, "message", "callerid"))) {
                                        ast_copy_string(origcallerid, v, sizeof(origcallerid));
                                }
        strncat(backup, "-bak", sizeof(backup) - strlen(backup) - 1);
        strncat(backup_textfile, "-bak.txt", sizeof(backup_textfile) - strlen(backup_textfile) - 1);
 
-       if ((msg_cfg = ast_config_load(textfile, config_flags)) && msg_cfg != CONFIG_STATUS_FILEINVALID && (duration_str = ast_variable_retrieve(msg_cfg, "message", "duration"))) {
+       if ((msg_cfg = ast_config_load(textfile, config_flags)) && valid_config(msg_cfg) && (duration_str = ast_variable_retrieve(msg_cfg, "message", "duration"))) {
                *duration = atoi(duration_str);
        } else {
                *duration = 0;
                        *duration = 0;
 
                        /* if we can't read the message metadata, stop now */
-                       if (!msg_cfg) {
+                       if (!valid_config(msg_cfg)) {
                                cmd = 0;
                                break;
                        }
                }
        }
 
-       if (msg_cfg)
+       if (valid_config(msg_cfg))
                ast_config_destroy(msg_cfg);
        if (prepend_duration)
                *duration = prepend_duration;
        snprintf(filename, sizeof(filename), "%s.txt", vms->fn);
        RETRIEVE(vms->curdir, vms->curmsg, vmu->mailbox, vmu->context);
        msg_cfg = ast_config_load(filename, config_flags);
-       if (!msg_cfg || msg_cfg == CONFIG_STATUS_FILEINVALID) {
+       if (!valid_config(msg_cfg)) {
                ast_log(LOG_WARNING, "No message attribute file?!! (%s)\n", filename);
                return 0;
        }
                }
        }
 
-       if (!msg_cfg) {
+       if (!valid_config(msg_cfg)) {
                ast_log(AST_LOG_WARNING, "No message attribute file?!! (%s)\n", filename);
                return 0;
        }
        struct ast_flags config_flags = { 0 };
 
        pwconf = ast_config_load(secretfn, config_flags);
-       if (pwconf) {
+       if (valid_config(pwconf)) {
                const char *val = ast_variable_retrieve(pwconf, "general", "password");
                if (val) {
                        ast_copy_string(password, val, passwordlen);
        fputs("00000002 => 9999,Mrs. Test\n", file);
        fclose(file);
 
-       if (!(cfg = ast_config_load(config_filename, config_flags))) {
+       if (!(cfg = ast_config_load(config_filename, config_flags)) || !valid_config(cfg)) {
                res = AST_TEST_FAIL;
                goto cleanup;
        }
        RETRIEVE(vms->curdir, vms->curmsg, vmu->mailbox, vmu->context);
        msg_cfg = ast_config_load(filename, config_flags);
        DISPOSE(vms->curdir, vms->curmsg);
-       if (!msg_cfg || msg_cfg == CONFIG_STATUS_FILEINVALID) {
+       if (!valid_config(msg_cfg)) {
                ast_log(AST_LOG_WARNING, "No message attribute file?!! (%s)\n", filename);
                return 0;
        }
                break;
        }
 
-#ifndef IMAP_STORAGE
        ast_config_destroy(msg_cfg);
 
+#ifndef IMAP_STORAGE
        if (!res) {
                make_file(vms->fn, sizeof(vms->fn), vms->curdir, msg);
                vms->heard[msg] = 1;