diff options
-rw-r--r-- | swat/scripting/client/regedit.js | 47 | ||||
-rw-r--r-- | swat/scripting/server/regedit.esp | 30 |
2 files changed, 66 insertions, 11 deletions
diff --git a/swat/scripting/client/regedit.js b/swat/scripting/client/regedit.js index 5769a88785..60ee95a483 100644 --- a/swat/scripting/client/regedit.js +++ b/swat/scripting/client/regedit.js @@ -5,10 +5,17 @@ released under the GNU GPL Version 2 or later */ -function __folder_list(fParent, list) + +/* + callback from the key enumeration call +*/ +function __folder_keys(fParent, list) { var i; - fParent.removeAll(); + if (fParent.working == 1) { + fParent.working = 0; + fParent.removeAll(); + } for (i=0;i<list.length;i++) { var fChild; fChild = new QxTreeFolder(list[i]); @@ -19,20 +26,50 @@ function __folder_list(fParent, list) } else { fChild.reg_path = fParent.reg_path + '\\' + list[i]; } + fChild.working = 1; fChild.add(new QxTreeFolder('Working ...')); fChild.addEventListener("click", function() { var el = this; __folder_click(el); }); - fParent.setOpen(1); } + fParent.setOpen(1); } +/* + callback from the key enumeration call +*/ +function __folder_values(fParent, list) +{ + var i; + if (list.length == 0) { + return; + } + if (fParent.working == 1) { + fParent.working = 0; + fParent.removeAll(); + } + for (i=0;i<list.length;i++) { + var fChild; + fChild = new QxTreeFile(list[i].name); + fChild.parent = fParent; + fChild.details = list[i]; + fParent.add(fChild); + } + fParent.setOpen(1); +} + +/* + called when someone clicks on a folder +*/ function __folder_click(node) { if (!node.populated) { node.populated = true; - server_call_url("/scripting/server/regedit.esp", 'enum_path', - function(list) { __folder_list(node, list); }, + server_call_url("/scripting/server/regedit.esp", 'enum_keys', + function(list) { __folder_keys(node, list); }, + node.binding, node.reg_path); + server_call_url("/scripting/server/regedit.esp", 'enum_values', + function(list) { __folder_values(node, list); }, node.binding, node.reg_path); } } diff --git a/swat/scripting/server/regedit.esp b/swat/scripting/server/regedit.esp index 31977d5a51..a13ad8afe5 100644 --- a/swat/scripting/server/regedit.esp +++ b/swat/scripting/server/regedit.esp @@ -8,10 +8,10 @@ libinclude("winreg.js"); libinclude("server_call.js"); /* - server side call to return a listing of elements in a winreg path + server side call to return a listing of keys in a winreg path */ -function enum_path(binding, path) { - printf("enum_path(%s, %s)\n", binding, path); +function enum_keys(binding, path) { + printf("enum_keys(%s, %s)\n", binding, path); var reg = winreg_init(); security_init(reg); @@ -22,13 +22,31 @@ function enum_path(binding, path) { printVars(status); return undefined; } - var list = winreg_enum_path(reg, path); - return list; + return winreg_enum_path(reg, path); +} + +/* + server side call to return a listing of values in a winreg path +*/ +function enum_values(binding, path) { + printf("enum_values(%s, %s)\n", binding, path); + var reg = winreg_init(); + security_init(reg); + + reg.credentials = session.authinfo.credentials; + + var status = reg.connect(binding); + if (status.is_ok != true) { + printVars(status); + return undefined; + } + return winreg_enum_values(reg, path); } /* register a call for clients to make */ var call = servCallObj(); -call.add('enum_path', enum_path); +call.add('enum_keys', enum_keys); +call.add('enum_values', enum_values); /* run the function that was asked for */ call.run(); |