1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-25 06:04:04 +03:00

r22324: Another step closer to nice listing of user accounts.

rafal
(This used to be commit 3f717e7fc7b0876de01cac375ef3151700066e0d)
This commit is contained in:
Rafal Szczesniak 2007-04-17 23:10:57 +00:00 committed by Gerald (Jerry) Carter
parent 4a23a696b9
commit 671d785c16
3 changed files with 329 additions and 75 deletions

View File

@ -11,19 +11,30 @@ jsonrpc_include("resources.esp");
function _NetContext(params, error) function _NetContext(params, error)
{ {
var credParams, credentials; var hostName, credParams, credentials;
var resName; var resName = "netCtx";
if (params.length < 1)
{
/* create default NetContext based on already provided credentials */
credentials = session.authinfo.credentials; credentials = session.authinfo.credentials;
resName = "netCtx";
if (params.length > 0)
{
/* first expected argument is host name that this context is going
to be attached to */
hostName = params[0];
if (typeof(hostName) != "string" || hostName == "")
{
error.setError(jsonrpc.Constant.ServerError.ParameterMismatch,
"hostName parameter is expected to be a valid non zero-length string");
return error;
} }
else
resName = "netCtx[" + hostName + "]";
/* check whether credentials are supplied as well */
if (params.length > 1)
{ {
/* create user specified credentials object */ /* create user specified credentials object */
credParams = params[0]; credParams = params[1];
if (typeof(credParams) != "object") if (typeof(credParams) != "object")
{ {
error.setError(jsonrpc.Constant.ServerError.ParameterMismatch, error.setError(jsonrpc.Constant.ServerError.ParameterMismatch,
@ -56,12 +67,11 @@ function _NetContext(params, error)
credentials.set_domain(credParams.domain); credentials.set_domain(credParams.domain);
credentials.set_username(credParams.username); credentials.set_username(credParams.username);
credentials.set_password(credParams.password); credentials.set_password(credParams.password);
}
resName = "netCtx[" + credParams.domain + "/" + credParams.username + "]";
} }
/* was this NetContext created yet ? */ /* was this NetContext created yet ? */
var resId = session.resources.find(key, error); var resId = session.resources.find(resName, error);
if (resId != undefined) if (resId != undefined)
{ {
/* yes, return its resource id */ /* yes, return its resource id */
@ -76,10 +86,93 @@ function _NetContext(params, error)
jsonrpc.method.NetContext = _NetContext; jsonrpc.method.NetContext = _NetContext;
/* function _NetContextCreds(params, error)
* Local Variables: {
* mode: c if (params.length != 1)
* End: {
*/ error.setError(jsonrpc.Constant.ServerError.ParameterMismatch,
"missing resource id parameter");
return error;
}
var resId = params[0];
if (typeof(resId) != "number")
{
error.setError(jsonrpc.Constant.ServerError.ParameterMismatch,
"an integer parameter is required");
return error;
}
var netCtx = session.resources.get(resId, error);
if (typeof(netCtx) != "object")
{
return null;
}
var creds = netCtx.credentials;
var result = new Object();
result.username = creds.get_username();
result.domain = creds.get_domain();
return result;
}
jsonrpc.method.NetContextCreds = _NetContextCreds;
function _UserMgr(params, error)
{
var domainName = null, netCtxId;
var resId = -1;
var resName = "usrCtx";
var netCtx = undefined;
var usrCtx = undefined;
if (params.length == 0)
{
error.setError(jsonrpc.Constant.ServerError.ParameterMismatch,
"NetContext parameter missing");
return error;
}
/* checking NetContext parameter */
netCtxId = params[0];
if (netCtxId == undefined || typeof(netCtxId) != "number")
{
error.setError(jsonrpc.Constant.ServerError.ParameterMismatch,
"NetContext parameter is expected to be a number");
}
netCtx = session.resources.get(netCtxId, error);
if (netCtx == undefined || typeof(netCtx) != "object")
{
error.setError(jsonrpc.Constant.ServerError.ParameterMismatch,
"Incorrect NetContext passed");
return error;
}
if (params.length > 1)
{
domainName = params[1];
if (domainName == undefined || typeof(domainName) != "string")
{
error.setError(jsonrpc.Constant.ServerError.ParameterMismatch,
"domainName parameter is expected to be a valid non zero-length string");
return error;
}
}
if (domainName == "")
{
usrCtx = netCtx.UserMgr();
}
else
{
usrCtx = netCtx.UserMgr(domainName);
}
resId = session.resources.set(usrCtx, resName, error);
return resId;
}
jsonrpc.method.UserMgr = _UserMgr;
%> %>

View File

@ -70,7 +70,13 @@ qx.Proto.buildFsm = function(module)
"changeSelection" : "changeSelection" :
{ {
"tree" : "tree" :
"Transition_Idle_to_AwaitRpcResult_via_tree_selection_changed" "Transition_Idle_to_Idle_via_tree_selection_changed"
},
"changeNetCtx" :
{
"swat.module.netmgr.Gui" :
"Transition_Idle_to_AwaitRpcResult_via_netCtx_changed"
} }
} }
}); });
@ -85,6 +91,7 @@ qx.Proto.buildFsm = function(module)
"ontransition" : function(fsm, event) "ontransition" : function(fsm, event)
{ {
// Create default NetContext
var request = _this.callRpc(fsm, "samba.ejsnet", "NetContext", []); var request = _this.callRpc(fsm, "samba.ejsnet", "NetContext", []);
request.setUserData("requestType", "NetContext"); request.setUserData("requestType", "NetContext");
} }
@ -111,9 +118,9 @@ qx.Proto.buildFsm = function(module)
state.addTransition(trans); state.addTransition(trans);
var trans = new qx.util.fsm.Transition( var trans = new qx.util.fsm.Transition(
"Transition_Idle_to_AwaitRpcResult_via_tree_selection_changed", "Transition_Idle_to_Idle_via_tree_selection_changed",
{ {
"nextState" : "State_AwaitRpcResult", "nextState" : "State_Idle",
"ontransition" : function(fsm, event) "ontransition" : function(fsm, event)
{ {
@ -123,7 +130,37 @@ qx.Proto.buildFsm = function(module)
var gui = swat.module.netmgr.Gui.getInstance(); var gui = swat.module.netmgr.Gui.getInstance();
var parentNode = gui.getParentNode(module, selectedNode); var parentNode = gui.getParentNode(module, selectedNode);
var params = (parentNode.credentials == undefined) ? [] : [ parentNode.credentials ]; // Change current NetContext if necessary for this host
if (parentNode.netCtx != undefined)
{
module.setNetCtx(parentNode.netCtx);
}
var nodeName = selectedNode.label;
var callName = undefined; // rpc call name
var callArgs = [ gui.getNetCtx() ]; // NetContex goes first
switch (nodeName)
{
case "Users":
callName = "UserMgr";
break;
case "Groups":
case "Domain":
case "Services":
alert("View not implemented yet");
break;
default:
alert("Undefined call selected for node=['" + nodeName + "']");
}
// Bail out if no appropriate call name has been found
if (callName == undefined) return;
var req = _this.callRpc(fsm, "samba.ejsnet", callName, callArgs);
req.setUserData("requestType", "UserMgr");
} }
}); });
@ -131,6 +168,21 @@ qx.Proto.buildFsm = function(module)
// Add the new transition // Add the new transition
state.addTransition(trans); state.addTransition(trans);
var trans = new qx.util.fsm.Transition(
"Transition_Idle_to_AwaitRpcResult_via_netCtx_changed",
{
"nextState" : "State_AwaitRpcResult",
"ontransition" : function(fsm, event)
{
var netCtxId = 0;
var req = _this.callRpc(fsm, "samba.ejsnet", "NetContextCreds", [ netCtxId ]);
req.setUserData("requestType", "NetContextCreds");
}
});
state.addTransition(trans);
blockedEvents = blockedEvents =
{ {
"appear": "appear":

View File

@ -5,20 +5,38 @@
/** /**
* Swat Net Manager class graphical user interface * Swat Net Manager class graphical user interface
*/ */
qx.OO.defineClass("swat.module.netmgr.Gui", qx.core.Object, qx.OO.defineClass("swat.module.netmgr.Gui", qx.core.Target,
function() function()
{ {
qx.core.Object.call(this); qx.core.Target.call(this);
}); });
//qx.OO.addProperty({ name : "_tree", type : "object" }); //qx.OO.addProperty({ name : "_tree", type : "object" });
//qx.OO.addProperty({ name : "_panel", type : "object" }); //qx.OO.addProperty({ name : "_panel", type : "object" });
//qx.OO.addProperty({ name : "_view", type : "object" });
//qx.OO.addProperty({ name : "_txtDomain", type : "object" });
//qx.OO.addProperty({ name : "_txtUsername", type : "object" });
/* NetContex resource number assigned on the server side.
Necessary for every ejsnet call */
qx.OO.addProperty({ name : "netCtx", type : "number" });
qx.Proto.buildGui = function(module) qx.Proto.buildGui = function(module)
{ {
var fsm = module.fsm; var fsm = module.fsm;
// Main layout composing the whole form
var vlayout = new qx.ui.layout.VerticalBoxLayout();
vlayout.set({
top: 20,
left: 20,
width: "100%",
bottom: 20
});
// Horizontal layout holding TreeView and a "panel" for ListView
var hlayout = new qx.ui.layout.HorizontalBoxLayout(); var hlayout = new qx.ui.layout.HorizontalBoxLayout();
hlayout.set({ hlayout.set({
top: 0, top: 0,
@ -55,38 +73,105 @@ qx.Proto.buildGui = function(module)
panel.set({ panel.set({
top: 0, top: 0,
right: 20, left: 10,
width: "80%", width: "80%",
height: "100%" height: "100%"
}); });
// Setup some initial columns and (empty) item list - to be replaced soon
// with default view loading
var columns = { name : { label: "Name", width: 120, type: "text" }};
var items = [];
// Setup the list view
this._view = new qx.ui.listview.ListView(items, columns);
var view = this._view;
view.setBorder(qx.renderer.border.BorderPresets.getInstance().shadow);
view.setBackgroundColor("white");
view.set({
top: 0,
left: 0,
width: "80%",
height: "100%"
});
// Give a list view name to handle
fsm.addObject("view", view);
// and the list view to the panel
panel.add(view);
// Add the tree view and panel for list view to the layout // Add the tree view and panel for list view to the layout
hlayout.add(tree); hlayout.add(tree);
hlayout.add(panel); hlayout.add(panel);
// Status layout containing informative labels and status information
var statusLayout = new qx.ui.layout.HorizontalBoxLayout(); var statusLayout = new qx.ui.layout.HorizontalBoxLayout();
statusLayout.set({ statusLayout.set({
top: 0, top: 10,
left: 0, left: 0,
right: 0, right: 0,
height: "100%" height: "100%"
}); });
var vlayout = new qx.ui.layout.VerticalBoxLayout(); // First "column" of status fields
vlayout.set({ var colALayout = new qx.ui.layout.VerticalBoxLayout();
top: 20, colALayout.set({
left: 20, top: 0,
width: "100%", left: 0,
bottom: 20 width: 150,
height: "100%"
}); });
// Domain name (credentials) - label and text box
var statusDomain = new qx.ui.layout.HorizontalBoxLayout();
statusDomain.set({ top: 0, left: 0, width: "100%", height: 20,
verticalChildrenAlign: "middle" });
var lblDomain = new qx.ui.basic.Atom();
lblDomain.setLabel("Domain:");
lblDomain.set({ width: 70, right: 5, horizontalChildrenAlign: "right" });
var txtDomain = new qx.ui.form.TextField();
txtDomain.set({ width: 80, readOnly: true });
this._txtDomain = txtDomain;
statusDomain.add(lblDomain);
statusDomain.add(txtDomain);
// Username (credentials) - label and text box
var statusUsername = new qx.ui.layout.HorizontalBoxLayout();
statusUsername.set({ top: 0, left: 0, width: "100%", height: 20,
verticalChildrenAlign: "middle" });
var lblUsername = new qx.ui.basic.Atom();
lblUsername.setLabel("Username:");
lblUsername.set({ width: 70, right: 5, horizontalChildrenAlign: "right" });
var txtUsername = new qx.ui.form.TextField();
txtUsername.set({ width: 80, readOnly: true });
this._txtUsername = txtUsername;
statusUsername.add(lblUsername);
statusUsername.add(txtUsername);
colALayout.add(statusDomain);
colALayout.add(statusUsername);
statusLayout.add(colALayout);
vlayout.add(hlayout); vlayout.add(hlayout);
vlayout.add(statusLayout); vlayout.add(statusLayout);
vlayout.addEventListener("appear", fsm.eventListener, fsm); vlayout.addEventListener("appear", fsm.eventListener, fsm);
fsm.addObject("vlayout", vlayout); fsm.addObject("vlayout", vlayout);
// place everything on canvas
module.canvas.add(vlayout); module.canvas.add(vlayout);
// Add event handler to netCtx property change
this.addEventListener("changeNetCtx", fsm.eventListener, fsm);
fsm.addObject("swat.module.netmgr.Gui", this);
}; };
@ -114,6 +199,14 @@ qx.Proto.displayData = function(module, rpcRequest)
case "NetContext": case "NetContext":
this._initNetContext(module, rpcRequest); this._initNetContext(module, rpcRequest);
break; break;
case "NetContextCreds":
this._updateNetContextCreds(module, rpcRequest);
break;
case "UserMgr":
this._initUserManager(module, rpcRequest);
break;
} }
qx.ui.core.Widget.flushGlobalQueues(); qx.ui.core.Widget.flushGlobalQueues();
@ -163,8 +256,8 @@ qx.Proto._addHostNode = function(module, rpcRequest, local)
var hostNode = dataModel.getData()[hostNodeId]; var hostNode = dataModel.getData()[hostNodeId];
// Set host-specific properties // Set host-specific properties
hostNode.credentials = undefined; hostNode.netCtx = undefined;
hostNode.local = local hostNode.local = local;
}; };
@ -172,7 +265,23 @@ qx.Proto._initNetContext = function(module, rpcRequest)
{ {
// Gather obtained NetContext handle // Gather obtained NetContext handle
var result = rpcRequest.getUserData("result").data; var result = rpcRequest.getUserData("result").data;
module.netCtx = result; this.setNetCtx(result);
};
qx.Proto._updateNetContextCreds = function(module, rpcRequest)
{
// Get requested credentials from the current NetContext
var result = rpcRequest.getUserData("result").data;
this._txtUsername.setValue(result.username);
this._txtDomain.setValue(result.domain);
};
qx.Proto._initUserManager = function(module, rpcRequest)
{
// Get obtained UsrCtx handle
var result = rpcRequest.getUserData("result").data;
}; };