prosodyctl: Ask about the distinguished name in a in a consistent order
authorKim Alvefur <zash@zash.se>
Mon, 29 Apr 2013 12:00:44 +0000 (14:00 +0200)
committerKim Alvefur <zash@zash.se>
Mon, 29 Apr 2013 12:00:44 +0000 (14:00 +0200)
prosodyctl

index 06590d1cca64fa2cb946cb04675b5c2855d0f677..88daf11b16296b645134090395ddfceb66e8ec78 100755 (executable)
@@ -662,19 +662,22 @@ function cert_commands.config(arg)
                conf:from_prosody(hosts, config, arg);
                show_message("Please provide details to include in the certificate config file.");
                show_message("Leave the field empty to use the default value or '.' to exclude the field.")
-               for k, v in pairs(conf.distinguished_name) do
-                       local nv;
-                       if k == "commonName" then 
-                               v = arg[1]
-                       elseif k == "emailAddress" then
-                               v = "xmpp@" .. arg[1];
-                       end
-                       nv = show_prompt(("%s (%s):"):format(k, nv or v));
-                       nv = (not nv or nv == "") and v or nv;
-                       if nv:find"[\192-\252][\128-\191]+" then
-                               conf.req.string_mask = "utf8only"
+               for i, k in ipairs(openssl._DN_order) do
+                       local v = conf.distinguished_name[k];
+                       if v then
+                               local nv;
+                               if k == "commonName" then
+                                       v = arg[1]
+                               elseif k == "emailAddress" then
+                                       v = "xmpp@" .. arg[1];
+                               end
+                               nv = show_prompt(("%s (%s):"):format(k, nv or v));
+                               nv = (not nv or nv == "") and v or nv;
+                               if nv:find"[\192-\252][\128-\191]+" then
+                                       conf.req.string_mask = "utf8only"
+                               end
+                               conf.distinguished_name[k] = nv ~= "." and nv or nil;
                        end
-                       conf.distinguished_name[k] = nv ~= "." and nv or nil;
                end
                local conf_file = io.open(conf_filename, "w");
                conf_file:write(conf:serialize());