summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--source4/build/smb_build/makefile.pm2
-rw-r--r--source4/script/installswat.sh7
-rwxr-xr-xsource4/script/tests/selftest.sh1
-rw-r--r--source4/scripting/libjs/base.js53
-rw-r--r--source4/scripting/libjs/samr.js (renamed from swat/scripting/samr.js)41
-rwxr-xr-xtestprogs/ejs/echo.js43
-rwxr-xr-xtestprogs/ejs/samr.js122
7 files changed, 111 insertions, 158 deletions
diff --git a/source4/build/smb_build/makefile.pm b/source4/build/smb_build/makefile.pm
index a32a93af0a..2edda7408e 100644
--- a/source4/build/smb_build/makefile.pm
+++ b/source4/build/smb_build/makefile.pm
@@ -696,7 +696,7 @@ installdat: installdirs
@$(SHELL) $(srcdir)/script/installdat.sh $(DESTDIR)$(LIBDIR) $(srcdir)
installswat: installdirs
- @$(SHELL) $(srcdir)/script/installswat.sh $(DESTDIR)$(SWATDIR) $(srcdir)
+ @$(SHELL) $(srcdir)/script/installswat.sh $(DESTDIR)$(SWATDIR) $(srcdir) $(DESTDIR)$(LIBDIR)
installman: installdirs
@$(SHELL) $(srcdir)/script/installman.sh $(DESTDIR)$(MANDIR) $(MANPAGES)
diff --git a/source4/script/installswat.sh b/source4/script/installswat.sh
index 1d89c2e86c..05245d8f06 100644
--- a/source4/script/installswat.sh
+++ b/source4/script/installswat.sh
@@ -2,6 +2,7 @@
SWATDIR=$1
SRCDIR=$2
+LIBDIR=$3
echo Installing swat files in $SWATDIR
@@ -26,6 +27,12 @@ installdir scripting/*.ejs scripting/*.esp scripting/*.js
installdir style/*.css
installdir docs/*.js
+
+echo "Installing js libs"
+cd ../source/scripting || exit 1
+mkdir -p $LIBDIR/js
+cp libjs/*.js $LIBDIR/js
+
cat << EOF
======================================================================
The swat files have been installed.
diff --git a/source4/script/tests/selftest.sh b/source4/script/tests/selftest.sh
index 2993b0590e..5e94ea13e2 100755
--- a/source4/script/tests/selftest.sh
+++ b/source4/script/tests/selftest.sh
@@ -68,6 +68,7 @@ cat >$CONFFILE<<EOF
pid directory = $PIDDIR
ncalrpc dir = $NCALRPCDIR
lock dir = $LOCKDIR
+ js include = $LIBDIR/js
name resolve order = bcast
interfaces = lo*
diff --git a/source4/scripting/libjs/base.js b/source4/scripting/libjs/base.js
new file mode 100644
index 0000000000..504cd82259
--- /dev/null
+++ b/source4/scripting/libjs/base.js
@@ -0,0 +1,53 @@
+/*
+ base js library functions
+ Copyright Andrew Tridgell 2005
+ released under the GNU GPL v2 or later
+*/
+
+if (global["HAVE_BASE_JS"] != undefined) {
+ return;
+}
+HAVE_BASE_JS=1
+
+/*
+ helper function to setup a rpc io object, ready for input
+*/
+function irpcObj()
+{
+ var o = new Object();
+ o.input = new Object();
+ return o;
+}
+
+/*
+ check that a status result is OK
+*/
+function check_status_ok(status)
+{
+ if (status.is_ok != true) {
+ printVars(status);
+ }
+ assert(status.is_ok == true);
+}
+
+/*
+ check that two arrays are equal
+*/
+function check_array_equal(a1, a2)
+{
+ assert(a1.length == a2.length);
+ for (i=0; i<a1.length; i++) {
+ assert(a1[i] == a2[i]);
+ }
+}
+
+/*
+ check that an array is all zeros
+*/
+function check_array_zero(a)
+{
+ for (i=0; i<a.length; i++) {
+ assert(a[i] == 0);
+ }
+}
+
diff --git a/swat/scripting/samr.js b/source4/scripting/libjs/samr.js
index 474e704550..a1f79b541a 100644
--- a/swat/scripting/samr.js
+++ b/source4/scripting/libjs/samr.js
@@ -1,27 +1,13 @@
/*
samr rpc utility functions
+ Copyright Andrew Tridgell 2005
+ released under the GNU GPL v2 or later
*/
-/*
- helper function to setup a rpc io object, ready for input
-*/
-function irpcObj()
-{
- var o = new Object();
- o.input = new Object();
- return o;
-}
-
-/*
- check that a status result is OK
-*/
-function check_status_ok(status)
-{
- if (status.is_ok != true) {
- printVars(status);
- }
- assert(status.is_ok == true);
+if (global["HAVE_SAMR_JS"] != undefined) {
+ return;
}
+HAVE_SAMR_JS=1
/*
return a list of names and indexes from a samArray
@@ -122,6 +108,21 @@ function samrEnumDomainUsers(conn, dom_handle)
}
/*
+ return a list of all groups
+*/
+function samrEnumDomainGroups(conn, dom_handle)
+{
+ var io = irpcObj();
+ io.input.domain_handle = dom_handle;
+ io.input.resume_handle = 0;
+ io.input.acct_flags = 0;
+ io.input.max_size = -1;
+ status = dcerpc_samr_EnumDomainGroups(conn, io);
+ check_status_ok(status);
+ return samArray(io.output);
+}
+
+/*
return a list of domains
*/
function samrEnumDomains(conn, handle)
@@ -165,3 +166,5 @@ function samrFillUserInfo(conn, dom_handle, users, level)
samrClose(conn, user_handle);
}
}
+
+
diff --git a/testprogs/ejs/echo.js b/testprogs/ejs/echo.js
index 4f0fc79f9a..312e599d50 100755
--- a/testprogs/ejs/echo.js
+++ b/testprogs/ejs/echo.js
@@ -3,16 +3,7 @@
test echo pipe calls from ejs
*/
-
-/*
- helper function to setup a rpc io object, ready for input
-*/
-function irpcObj()
-{
- var o = new Object();
- o.input = new Object();
- return o;
-}
+libinclude("base.js");
/*
generate a ramp as an integer array
@@ -28,38 +19,6 @@ function ramp_array(N)
/*
- check that a status result is OK
-*/
-function check_status_ok(status)
-{
- if (status.is_ok != true) {
- printVars(status);
- }
- assert(status.is_ok == true);
-}
-
-/*
- check that two arrays are equal
-*/
-function check_array_equal(a1, a2)
-{
- assert(a1.length == a2.length);
- for (i=0; i<a1.length; i++) {
- assert(a1[i] == a2[i]);
- }
-}
-
-/*
- check that an array is all zeros
-*/
-function check_array_zero(a)
-{
- for (i=0; i<a.length; i++) {
- assert(a[i] == 0);
- }
-}
-
-/*
test the echo_AddOne interface
*/
function test_AddOne(conn)
diff --git a/testprogs/ejs/samr.js b/testprogs/ejs/samr.js
index ec2096b818..1c613d5619 100755
--- a/testprogs/ejs/samr.js
+++ b/testprogs/ejs/samr.js
@@ -3,65 +3,28 @@
test samr calls from ejs
*/
+libinclude("base.js");
+libinclude("samr.js");
+libinclude("samr.js");
-/*
- helper function to setup a rpc io object, ready for input
-*/
-function irpcObj()
-{
- var o = new Object();
- o.input = new Object();
- return o;
-}
-
-/*
- check that a status result is OK
-*/
-function check_status_ok(status)
-{
- if (status.is_ok != true) {
- printVars(status);
- }
- assert(status.is_ok == true);
-}
/*
test the samr_Connect interface
*/
function test_Connect(conn)
{
- var io = irpcObj();
print("Testing samr_Connect\n");
- io.input.system_name = NULL;
- io.input.access_mask = SEC_FLAG_MAXIMUM_ALLOWED;
- status = dcerpc_samr_Connect(conn, io);
- check_status_ok(status);
- return io.output.connect_handle;
+ return samrConnect(conn);
}
-/*
- test the samr_Close interface
-*/
-function test_Close(conn, handle)
-{
- var io = irpcObj();
- io.input.handle = handle;
- status = dcerpc_samr_Close(conn, io);
- check_status_ok(status);
-}
/*
test the samr_LookupDomain interface
*/
function test_LookupDomain(conn, handle, domain)
{
- var io = irpcObj();
print("Testing samr_LookupDomain\n");
- io.input.connect_handle = handle;
- io.input.domain_name = domain;
- status = dcerpc_samr_LookupDomain(conn, io);
- check_status_ok(status);
- return io.output.sid;
+ return samrLookupDomain(conn, handle, domain);
}
/*
@@ -69,14 +32,8 @@ function test_LookupDomain(conn, handle, domain)
*/
function test_OpenDomain(conn, handle, sid)
{
- var io = irpcObj();
print("Testing samr_OpenDomain\n");
- io.input.connect_handle = handle;
- io.input.access_mask = SEC_FLAG_MAXIMUM_ALLOWED;
- io.input.sid = sid;
- status = dcerpc_samr_OpenDomain(conn, io);
- check_status_ok(status);
- return io.output.domain_handle;
+ return samrOpenDomain(conn, handle, sid);
}
/*
@@ -84,21 +41,12 @@ function test_OpenDomain(conn, handle, sid)
*/
function test_EnumDomainUsers(conn, dom_handle)
{
- var i, io = irpcObj();
+ var i, users;
print("Testing samr_EnumDomainUsers\n");
- io.input.domain_handle = dom_handle;
- io.input.resume_handle = 0;
- io.input.acct_flags = 0;
- io.input.max_size = -1;
- status = dcerpc_samr_EnumDomainUsers(conn, io);
- check_status_ok(status);
- print("Found " + io.output.num_entries + " users\n");
- if (io.output.sam == NULL) {
- return;
- }
- var entries = io.output.sam.entries;
- for (i=0;i<io.output.num_entries;i++) {
- print("\t" + entries[i].name + "\n");
+ users = samrEnumDomainUsers(conn, dom_handle);
+ print("Found " + users.length + " users\n");
+ for (i=0;i<users.length;i++) {
+ println("\t" + users[i].name + "\t(" + users[i].idx + ")");
}
}
@@ -107,21 +55,11 @@ function test_EnumDomainUsers(conn, dom_handle)
*/
function test_EnumDomainGroups(conn, dom_handle)
{
- var i, io = irpcObj();
print("Testing samr_EnumDomainGroups\n");
- io.input.domain_handle = dom_handle;
- io.input.resume_handle = 0;
- io.input.acct_flags = 0;
- io.input.max_size = -1;
- status = dcerpc_samr_EnumDomainGroups(conn, io);
- check_status_ok(status);
- print("Found " + io.output.num_entries + " groups\n");
- if (io.output.sam == NULL) {
- return;
- }
- var entries = io.output.sam.entries;
- for (i=0;i<io.output.num_entries;i++) {
- print("\t" + entries[i].name + "\n");
+ var i, groups = samrEnumDomainGroups(conn, dom_handle);
+ print("Found " + groups.length + " groups\n");
+ for (i=0;i<groups.length;i++) {
+ println("\t" + groups[i].name + "\t(" + groups[i].idx + ")");
}
}
@@ -141,28 +79,20 @@ function test_domain_ops(conn, dom_handle)
*/
function test_EnumDomains(conn, handle)
{
- var i, io = irpcObj();
+ var i, domains;
print("Testing samr_EnumDomains\n");
- io.input.connect_handle = handle;
- io.input.resume_handle = 0;
- io.input.buf_size = -1;
- status = dcerpc_samr_EnumDomains(conn, io);
- check_status_ok(status);
- print("Found " + io.output.num_entries + " domains\n");
- if (io.output.sam == NULL) {
- return;
- }
- var entries = io.output.sam.entries;
- for (i=0;i<io.output.num_entries;i++) {
- print("\t" + entries[i].name + "\n");
+
+ domains = samrEnumDomains(conn, handle);
+ print("Found " + domains.length + " domains\n");
+ for (i=0;i<domains.length;i++) {
+ print("\t" + domains[i].name + "\n");
}
- for (i=0;i<io.output.num_entries;i++) {
- domain = entries[i].name;
- print("Testing domain " + domain + "\n");
- sid = test_LookupDomain(conn, handle, domain);
+ for (i=0;i<domains.length;i++) {
+ print("Testing domain " + domains[i].name + "\n");
+ sid = samrLookupDomain(conn, handle, domains[i].name);
dom_handle = test_OpenDomain(conn, handle, sid);
test_domain_ops(conn, dom_handle);
- test_Close(conn, dom_handle);
+ samrClose(conn, dom_handle);
}
}
@@ -185,7 +115,7 @@ if (status.is_ok != true) {
handle = test_Connect(conn);
test_EnumDomains(conn, handle);
-test_Close(conn, handle);
+samrClose(conn, handle);
print("All OK\n");
return 0;