2 Unix SMB/CIFS implementation.
4 endpoint server for the srvsvc pipe
6 Copyright (C) Stefan (metze) Metzmacher 2004-2006
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>.
23 #include "ntvfs/ntvfs.h"
24 #include "rpc_server/dcerpc_server.h"
25 #include "librpc/gen_ndr/ndr_srvsvc.h"
26 #include "rpc_server/common/common.h"
27 #include "auth/auth.h"
28 #include "libcli/security/security.h"
29 #include "system/time.h"
30 #include "rpc_server/srvsvc/proto.h"
32 #define SRVSVC_CHECK_ADMIN_ACCESS do { \
33 struct security_token *t = dce_call->conn->auth_state.session_info->security_token; \
34 if (!security_token_has_builtin_administrators(t) && \
35 !security_token_has_sid_string(t, SID_BUILTIN_SERVER_OPERATORS)) { \
36 return WERR_ACCESS_DENIED; \
43 static WERROR dcesrv_srvsvc_NetCharDevEnum(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
44 struct srvsvc_NetCharDevEnum *r)
46 r->out.level = r->in.level;
47 r->out.totalentries = 0;
48 r->out.resume_handle = NULL;
50 switch (r->in.level) {
52 r->out.ctr.ctr0 = talloc(mem_ctx, struct srvsvc_NetCharDevCtr0);
53 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr0);
55 r->out.ctr.ctr0->count = 0;
56 r->out.ctr.ctr0->array = NULL;
58 return WERR_NOT_SUPPORTED;
61 r->out.ctr.ctr1 = talloc(mem_ctx, struct srvsvc_NetCharDevCtr1);
62 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr1);
64 r->out.ctr.ctr1->count = 0;
65 r->out.ctr.ctr1->array = NULL;
67 return WERR_NOT_SUPPORTED;
70 return WERR_UNKNOWN_LEVEL;
78 srvsvc_NetCharDevGetInfo
80 static WERROR dcesrv_srvsvc_NetCharDevGetInfo(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
81 struct srvsvc_NetCharDevGetInfo *r)
85 switch (r->in.level) {
88 return WERR_NOT_SUPPORTED;
92 return WERR_NOT_SUPPORTED;
95 return WERR_UNKNOWN_LEVEL;
98 return WERR_UNKNOWN_LEVEL;
103 srvsvc_NetCharDevControl
105 static WERROR dcesrv_srvsvc_NetCharDevControl(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
106 struct srvsvc_NetCharDevControl *r)
108 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
113 srvsvc_NetCharDevQEnum
115 static WERROR dcesrv_srvsvc_NetCharDevQEnum(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
116 struct srvsvc_NetCharDevQEnum *r)
118 r->out.level = r->in.level;
119 r->out.totalentries = 0;
120 r->out.resume_handle = NULL;
122 switch (r->in.level) {
125 r->out.ctr.ctr0 = talloc(mem_ctx, struct srvsvc_NetCharDevQCtr0);
126 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr0);
128 r->out.ctr.ctr0->count = 0;
129 r->out.ctr.ctr0->array = NULL;
131 return WERR_NOT_SUPPORTED;
135 r->out.ctr.ctr1 = talloc(mem_ctx, struct srvsvc_NetCharDevQCtr1);
136 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr1);
138 r->out.ctr.ctr1->count = 0;
139 r->out.ctr.ctr1->array = NULL;
141 return WERR_NOT_SUPPORTED;
144 return WERR_UNKNOWN_LEVEL;
147 return WERR_UNKNOWN_LEVEL;
152 srvsvc_NetCharDevQGetInfo
154 static WERROR dcesrv_srvsvc_NetCharDevQGetInfo(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
155 struct srvsvc_NetCharDevQGetInfo *r)
159 switch (r->in.level) {
162 return WERR_NOT_SUPPORTED;
166 return WERR_NOT_SUPPORTED;
169 return WERR_UNKNOWN_LEVEL;
172 return WERR_UNKNOWN_LEVEL;
177 srvsvc_NetCharDevQSetInfo
179 static WERROR dcesrv_srvsvc_NetCharDevQSetInfo(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
180 struct srvsvc_NetCharDevQSetInfo *r)
182 switch (r->in.level) {
185 if (r->in.parm_error) {
186 r->out.parm_error = r->in.parm_error;
188 return WERR_NOT_SUPPORTED;
192 if (r->in.parm_error) {
193 r->out.parm_error = r->in.parm_error;
195 return WERR_NOT_SUPPORTED;
198 return WERR_UNKNOWN_LEVEL;
201 return WERR_UNKNOWN_LEVEL;
206 srvsvc_NetCharDevQPurge
208 static WERROR dcesrv_srvsvc_NetCharDevQPurge(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
209 struct srvsvc_NetCharDevQPurge *r)
211 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
216 srvsvc_NetCharDevQPurgeSelf
218 static WERROR dcesrv_srvsvc_NetCharDevQPurgeSelf(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
219 struct srvsvc_NetCharDevQPurgeSelf *r)
221 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
228 static WERROR dcesrv_srvsvc_NetConnEnum(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
229 struct srvsvc_NetConnEnum *r)
231 r->out.level = r->in.level;
232 r->out.totalentries = 0;
233 r->out.resume_handle = NULL;
235 switch (r->in.level) {
238 r->out.ctr.ctr0 = talloc(mem_ctx, struct srvsvc_NetConnCtr0);
239 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr0);
241 r->out.ctr.ctr0->count = 0;
242 r->out.ctr.ctr0->array = NULL;
244 return WERR_NOT_SUPPORTED;
248 r->out.ctr.ctr1 = talloc(mem_ctx, struct srvsvc_NetConnCtr1);
249 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr1);
251 r->out.ctr.ctr1->count = 0;
252 r->out.ctr.ctr1->array = NULL;
254 return WERR_NOT_SUPPORTED;
257 return WERR_UNKNOWN_LEVEL;
260 return WERR_UNKNOWN_LEVEL;
267 static WERROR dcesrv_srvsvc_NetFileEnum(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
268 struct srvsvc_NetFileEnum *r)
270 r->out.level = r->in.level;
271 r->out.totalentries = 0;
272 r->out.resume_handle = NULL;
274 switch (r->in.level) {
277 r->out.ctr.ctr2 = talloc(mem_ctx, struct srvsvc_NetFileCtr2);
278 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr2);
280 r->out.ctr.ctr2->count = 0;
281 r->out.ctr.ctr2->array = NULL;
283 return WERR_NOT_SUPPORTED;
287 r->out.ctr.ctr3 = talloc(mem_ctx, struct srvsvc_NetFileCtr3);
288 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr3);
290 r->out.ctr.ctr3->count = 0;
291 r->out.ctr.ctr3->array = NULL;
293 return WERR_NOT_SUPPORTED;
296 return WERR_UNKNOWN_LEVEL;
299 return WERR_UNKNOWN_LEVEL;
304 srvsvc_NetFileGetInfo
306 static WERROR dcesrv_srvsvc_NetFileGetInfo(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
307 struct srvsvc_NetFileGetInfo *r)
311 switch (r->in.level) {
314 return WERR_NOT_SUPPORTED;
318 return WERR_NOT_SUPPORTED;
321 return WERR_UNKNOWN_LEVEL;
324 return WERR_UNKNOWN_LEVEL;
331 static WERROR dcesrv_srvsvc_NetFileClose(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
332 struct srvsvc_NetFileClose *r)
334 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
341 static WERROR dcesrv_srvsvc_NetSessEnum(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
342 struct srvsvc_NetSessEnum *r)
344 r->out.level = r->in.level;
345 r->out.totalentries = 0;
346 r->out.resume_handle = NULL;
348 switch (r->in.level) {
351 r->out.ctr.ctr0 = talloc(mem_ctx, struct srvsvc_NetSessCtr0);
352 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr0);
354 r->out.ctr.ctr0->count = 0;
355 r->out.ctr.ctr0->array = NULL;
357 return WERR_NOT_SUPPORTED;
361 r->out.ctr.ctr1 = talloc(mem_ctx, struct srvsvc_NetSessCtr1);
362 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr1);
364 r->out.ctr.ctr1->count = 0;
365 r->out.ctr.ctr1->array = NULL;
367 return WERR_NOT_SUPPORTED;
371 r->out.ctr.ctr2 = talloc(mem_ctx, struct srvsvc_NetSessCtr2);
372 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr2);
374 r->out.ctr.ctr2->count = 0;
375 r->out.ctr.ctr2->array = NULL;
377 return WERR_NOT_SUPPORTED;
381 r->out.ctr.ctr10 = talloc(mem_ctx, struct srvsvc_NetSessCtr10);
382 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr10);
384 r->out.ctr.ctr2->count = 0;
385 r->out.ctr.ctr2->array = NULL;
387 return WERR_NOT_SUPPORTED;
391 r->out.ctr.ctr502 = talloc(mem_ctx, struct srvsvc_NetSessCtr502);
392 W_ERROR_HAVE_NO_MEMORY(r->out.ctr.ctr502);
394 r->out.ctr.ctr2->count = 0;
395 r->out.ctr.ctr2->array = NULL;
397 return WERR_NOT_SUPPORTED;
400 return WERR_UNKNOWN_LEVEL;
403 return WERR_UNKNOWN_LEVEL;
410 static WERROR dcesrv_srvsvc_NetSessDel(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
411 struct srvsvc_NetSessDel *r)
413 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
420 static WERROR dcesrv_srvsvc_NetShareAdd(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
421 struct srvsvc_NetShareAdd *r)
423 switch (r->in.level) {
426 if (r->in.parm_error) {
427 r->out.parm_error = r->in.parm_error;
429 return WERR_NOT_SUPPORTED;
433 if (r->in.parm_error) {
434 r->out.parm_error = r->in.parm_error;
436 return WERR_NOT_SUPPORTED;
441 struct share_info *info;
442 struct share_context *sctx;
446 nterr = share_get_context(mem_ctx, &sctx);
447 if (!NT_STATUS_IS_OK(nterr)) {
448 return ntstatus_to_werror(nterr);
451 /* there are no more than 8 options in struct srvsvc_NetShareInfo2 */
452 info = talloc_array(mem_ctx, struct share_info, count);
453 W_ERROR_HAVE_NO_MEMORY(info);
457 info[i].name = SHARE_TYPE;
458 info[i].type = SHARE_INFO_STRING;
459 switch (r->in.info.info2->type) {
461 info[i].value = talloc_strdup(info, "DISK");
464 info[i].value = talloc_strdup(info, "PRINTER");
467 info[i].value = talloc_strdup(info, "IPC");
470 return WERR_INVALID_PARAM;
472 W_ERROR_HAVE_NO_MEMORY(info[i].value);
475 if (r->in.info.info2->path && r->in.info.info2->path[0]) {
476 info[i].name = SHARE_PATH;
477 info[i].type = SHARE_INFO_STRING;
479 /* Windows will send a path in a form of C:\example\path */
480 if (r->in.info.info2->path[1] == ':') {
481 info[i].value = talloc_strdup(info, &r->in.info.info2->path[2]);
483 /* very strange let's try to set as is */
484 info[i].value = talloc_strdup(info, r->in.info.info2->path);
486 W_ERROR_HAVE_NO_MEMORY(info[i].value);
487 all_string_sub((char *)info[i].value, "\\", "/", 0);
492 if (r->in.info.info2->comment && r->in.info.info2->comment[0]) {
493 info[i].name = SHARE_COMMENT;
494 info[i].type = SHARE_INFO_STRING;
495 info[i].value = talloc_strdup(info, r->in.info.info2->comment);
496 W_ERROR_HAVE_NO_MEMORY(info[i].value);
501 if (r->in.info.info2->password && r->in.info.info2->password[0]) {
502 info[i].name = SHARE_PASSWORD;
503 info[i].type = SHARE_INFO_STRING;
504 info[i].value = talloc_strdup(info, r->in.info.info502->password);
505 W_ERROR_HAVE_NO_MEMORY(info[i].value);
510 info[i].name = SHARE_MAX_CONNECTIONS;
511 info[i].type = SHARE_INFO_INT;
512 info[i].value = talloc(info, int);
513 *((int *)info[i].value) = r->in.info.info2->max_users;
516 /* TODO: security descriptor */
518 nterr = share_create(sctx, r->in.info.info2->name, info, i);
519 if (!NT_STATUS_IS_OK(nterr)) {
520 return ntstatus_to_werror(nterr);
523 if (r->in.parm_error) {
524 r->out.parm_error = r->in.parm_error;
531 if (r->in.parm_error) {
532 r->out.parm_error = r->in.parm_error;
534 return WERR_NOT_SUPPORTED;
539 struct share_info *info;
540 struct share_context *sctx;
544 nterr = share_get_context(mem_ctx, &sctx);
545 if (!NT_STATUS_IS_OK(nterr)) {
546 return ntstatus_to_werror(nterr);
549 /* there are no more than 10 options in struct srvsvc_NetShareInfo502 */
550 info = talloc_array(mem_ctx, struct share_info, count);
551 W_ERROR_HAVE_NO_MEMORY(info);
555 info[i].name = SHARE_TYPE;
556 info[i].type = SHARE_INFO_STRING;
557 switch (r->in.info.info502->type) {
559 info[i].value = talloc_strdup(info, "DISK");
562 info[i].value = talloc_strdup(info, "PRINTER");
565 info[i].value = talloc_strdup(info, "IPC");
568 return WERR_INVALID_PARAM;
570 W_ERROR_HAVE_NO_MEMORY(info[i].value);
573 if (r->in.info.info502->path && r->in.info.info502->path[0]) {
574 info[i].name = SHARE_PATH;
575 info[i].type = SHARE_INFO_STRING;
577 /* Windows will send a path in a form of C:\example\path */
578 if (r->in.info.info2->path[1] == ':') {
579 info[i].value = talloc_strdup(info, &r->in.info.info502->path[2]);
581 /* very strange let's try to set as is */
582 info[i].value = talloc_strdup(info, r->in.info.info502->path);
584 W_ERROR_HAVE_NO_MEMORY(info[i].value);
585 all_string_sub((char *)info[i].value, "\\", "/", 0);
590 if (r->in.info.info502->comment && r->in.info.info502->comment[0]) {
591 info[i].name = SHARE_COMMENT;
592 info[i].type = SHARE_INFO_STRING;
593 info[i].value = talloc_strdup(info, r->in.info.info502->comment);
594 W_ERROR_HAVE_NO_MEMORY(info[i].value);
599 if (r->in.info.info502->password && r->in.info.info502->password[0]) {
600 info[i].name = SHARE_PASSWORD;
601 info[i].type = SHARE_INFO_STRING;
602 info[i].value = talloc_strdup(info, r->in.info.info502->password);
603 W_ERROR_HAVE_NO_MEMORY(info[i].value);
608 info[i].name = SHARE_MAX_CONNECTIONS;
609 info[i].type = SHARE_INFO_INT;
610 info[i].value = talloc(info, int);
611 *((int *)info[i].value) = r->in.info.info502->max_users;
614 /* TODO: security descriptor */
616 nterr = share_create(sctx, r->in.info.info502->name, info, i);
617 if (!NT_STATUS_IS_OK(nterr)) {
618 return ntstatus_to_werror(nterr);
621 if (r->in.parm_error) {
622 r->out.parm_error = r->in.parm_error;
628 return WERR_UNKNOWN_LEVEL;
631 return WERR_UNKNOWN_LEVEL;
634 static WERROR dcesrv_srvsvc_fiel_ShareInfo(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
635 struct share_config *scfg, uint32_t level,
636 union srvsvc_NetShareInfo *info)
638 struct dcesrv_context *dce_ctx = dce_call->conn->dce_ctx;
643 info->info0->name = talloc_strdup(mem_ctx, scfg->name);
644 W_ERROR_HAVE_NO_MEMORY(info->info0->name);
650 info->info1->name = talloc_strdup(mem_ctx, scfg->name);
651 W_ERROR_HAVE_NO_MEMORY(info->info1->name);
652 info->info1->type = dcesrv_common_get_share_type(mem_ctx, dce_ctx, scfg);
653 info->info1->comment = talloc_strdup(mem_ctx, share_string_option(scfg, SHARE_COMMENT, ""));
654 W_ERROR_HAVE_NO_MEMORY(info->info1->comment);
660 info->info2->name = talloc_strdup(mem_ctx, scfg->name);
661 W_ERROR_HAVE_NO_MEMORY(info->info2->name);
662 info->info2->type = dcesrv_common_get_share_type(mem_ctx, dce_ctx, scfg);
663 info->info2->comment = talloc_strdup(mem_ctx, share_string_option(scfg, SHARE_COMMENT, ""));
664 W_ERROR_HAVE_NO_MEMORY(info->info2->comment);
665 info->info2->permissions = dcesrv_common_get_share_permissions(mem_ctx, dce_ctx, scfg);
666 info->info2->max_users = share_int_option(scfg, SHARE_MAX_CONNECTIONS, SHARE_MAX_CONNECTIONS_DEFAULT);
667 info->info2->current_users = dcesrv_common_get_share_current_users(mem_ctx, dce_ctx, scfg);
668 info->info2->path = dcesrv_common_get_share_path(mem_ctx, dce_ctx, scfg);
669 W_ERROR_HAVE_NO_MEMORY(info->info2->path);
670 info->info2->password = talloc_strdup(mem_ctx, share_string_option(scfg, SHARE_PASSWORD, NULL));
676 info->info501->name = talloc_strdup(mem_ctx, scfg->name);
677 W_ERROR_HAVE_NO_MEMORY(info->info501->name);
678 info->info501->type = dcesrv_common_get_share_type(mem_ctx, dce_ctx, scfg);
679 info->info501->comment = talloc_strdup(mem_ctx, share_string_option(scfg, SHARE_COMMENT, ""));
680 W_ERROR_HAVE_NO_MEMORY(info->info501->comment);
681 info->info501->csc_policy = share_int_option(scfg, SHARE_CSC_POLICY, SHARE_CSC_POLICY_DEFAULT);
687 info->info502->name = talloc_strdup(mem_ctx, scfg->name);
688 W_ERROR_HAVE_NO_MEMORY(info->info502->name);
689 info->info502->type = dcesrv_common_get_share_type(mem_ctx, dce_ctx, scfg);
690 info->info502->comment = talloc_strdup(mem_ctx, share_string_option(scfg, SHARE_COMMENT, ""));
691 W_ERROR_HAVE_NO_MEMORY(info->info502->comment);
692 info->info502->permissions = dcesrv_common_get_share_permissions(mem_ctx, dce_ctx, scfg);
693 info->info502->max_users = share_int_option(scfg, SHARE_MAX_CONNECTIONS, SHARE_MAX_CONNECTIONS_DEFAULT);
694 info->info502->current_users = dcesrv_common_get_share_current_users(mem_ctx, dce_ctx, scfg);
695 info->info502->path = dcesrv_common_get_share_path(mem_ctx, dce_ctx, scfg);
696 W_ERROR_HAVE_NO_MEMORY(info->info502->path);
697 info->info502->password = talloc_strdup(mem_ctx, share_string_option(scfg, SHARE_PASSWORD, NULL));
698 info->info502->unknown = dcesrv_common_get_share_unknown(mem_ctx, dce_ctx, scfg);
699 info->info502->sd = dcesrv_common_get_security_descriptor(mem_ctx, dce_ctx, scfg);
705 info->info1005->dfs_flags = dcesrv_common_get_share_dfs_flags(mem_ctx, dce_ctx, scfg);
710 return WERR_UNKNOWN_LEVEL;
713 return WERR_UNKNOWN_LEVEL;
717 srvsvc_NetShareEnumAll
719 static WERROR dcesrv_srvsvc_NetShareEnumAll(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
720 struct srvsvc_NetShareEnumAll *r)
725 struct share_context *sctx;
726 struct share_config *scfg;
728 r->out.level = r->in.level;
729 ZERO_STRUCT(r->out.ctr);
730 r->out.totalentries = 0;
731 r->out.resume_handle = NULL;
733 /* TODO: - paging of results
736 nterr = share_get_context(mem_ctx, &sctx);
737 if (!NT_STATUS_IS_OK(nterr)) {
738 return ntstatus_to_werror(nterr);
741 nterr = share_list_all(mem_ctx, sctx, &numshares, &snames);
742 if (!NT_STATUS_IS_OK(nterr)) {
743 return ntstatus_to_werror(nterr);
746 switch (r->in.level) {
750 struct srvsvc_NetShareCtr0 *ctr0;
752 ctr0 = talloc(mem_ctx, struct srvsvc_NetShareCtr0);
753 W_ERROR_HAVE_NO_MEMORY(ctr0);
755 ctr0->count = numshares;
758 if (ctr0->count == 0) {
759 r->out.ctr.ctr0 = ctr0;
763 ctr0->array = talloc_array(mem_ctx, struct srvsvc_NetShareInfo0, ctr0->count);
764 W_ERROR_HAVE_NO_MEMORY(ctr0->array);
766 for (i = 0; i < ctr0->count; i++) {
768 union srvsvc_NetShareInfo info;
770 nterr = share_get_config(mem_ctx, sctx, snames[i], &scfg);
771 if (!NT_STATUS_IS_OK(nterr)) {
772 DEBUG(1, ("ERROR: Service [%s] disappeared after enumeration", snames[i]));
773 return WERR_GENERAL_FAILURE;
775 info.info0 = &ctr0->array[i];
776 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
777 if (!W_ERROR_IS_OK(status)) {
784 r->out.ctr.ctr0 = ctr0;
785 r->out.totalentries = r->out.ctr.ctr0->count;
791 struct srvsvc_NetShareCtr1 *ctr1;
793 ctr1 = talloc(mem_ctx, struct srvsvc_NetShareCtr1);
794 W_ERROR_HAVE_NO_MEMORY(ctr1);
796 ctr1->count = numshares;
799 if (ctr1->count == 0) {
800 r->out.ctr.ctr1 = ctr1;
804 ctr1->array = talloc_array(mem_ctx, struct srvsvc_NetShareInfo1, ctr1->count);
805 W_ERROR_HAVE_NO_MEMORY(ctr1->array);
807 for (i=0; i < ctr1->count; i++) {
809 union srvsvc_NetShareInfo info;
811 nterr = share_get_config(mem_ctx, sctx, snames[i], &scfg);
812 if (!NT_STATUS_IS_OK(nterr)) {
813 DEBUG(1, ("ERROR: Service [%s] disappeared after enumeration", snames[i]));
814 return WERR_GENERAL_FAILURE;
816 info.info1 = &ctr1->array[i];
817 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
818 if (!W_ERROR_IS_OK(status)) {
825 r->out.ctr.ctr1 = ctr1;
826 r->out.totalentries = r->out.ctr.ctr1->count;
832 struct srvsvc_NetShareCtr2 *ctr2;
834 SRVSVC_CHECK_ADMIN_ACCESS;
836 ctr2 = talloc(mem_ctx, struct srvsvc_NetShareCtr2);
837 W_ERROR_HAVE_NO_MEMORY(ctr2);
839 ctr2->count = numshares;
842 if (ctr2->count == 0) {
843 r->out.ctr.ctr2 = ctr2;
847 ctr2->array = talloc_array(mem_ctx, struct srvsvc_NetShareInfo2, ctr2->count);
848 W_ERROR_HAVE_NO_MEMORY(ctr2->array);
850 for (i=0; i < ctr2->count; i++) {
852 union srvsvc_NetShareInfo info;
854 nterr = share_get_config(mem_ctx, sctx, snames[i], &scfg);
855 if (!NT_STATUS_IS_OK(nterr)) {
856 DEBUG(1, ("ERROR: Service [%s] disappeared after enumeration", snames[i]));
857 return WERR_GENERAL_FAILURE;
859 info.info2 = &ctr2->array[i];
860 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
861 if (!W_ERROR_IS_OK(status)) {
868 r->out.ctr.ctr2 = ctr2;
869 r->out.totalentries = r->out.ctr.ctr2->count;
875 struct srvsvc_NetShareCtr501 *ctr501;
877 SRVSVC_CHECK_ADMIN_ACCESS;
879 ctr501 = talloc(mem_ctx, struct srvsvc_NetShareCtr501);
880 W_ERROR_HAVE_NO_MEMORY(ctr501);
882 ctr501->count = numshares;
883 ctr501->array = NULL;
885 if (ctr501->count == 0) {
886 r->out.ctr.ctr501 = ctr501;
890 ctr501->array = talloc_array(mem_ctx, struct srvsvc_NetShareInfo501, ctr501->count);
891 W_ERROR_HAVE_NO_MEMORY(ctr501->array);
893 for (i=0; i < ctr501->count; i++) {
895 union srvsvc_NetShareInfo info;
897 nterr = share_get_config(mem_ctx, sctx, snames[i], &scfg);
898 if (!NT_STATUS_IS_OK(nterr)) {
899 DEBUG(1, ("ERROR: Service [%s] disappeared after enumeration", snames[i]));
900 return WERR_GENERAL_FAILURE;
902 info.info501 = &ctr501->array[i];
903 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
904 if (!W_ERROR_IS_OK(status)) {
911 r->out.ctr.ctr501 = ctr501;
912 r->out.totalentries = r->out.ctr.ctr501->count;
918 struct srvsvc_NetShareCtr502 *ctr502;
920 SRVSVC_CHECK_ADMIN_ACCESS;
922 ctr502 = talloc(mem_ctx, struct srvsvc_NetShareCtr502);
923 W_ERROR_HAVE_NO_MEMORY(ctr502);
925 ctr502->count = numshares;
926 ctr502->array = NULL;
928 if (ctr502->count == 0) {
929 r->out.ctr.ctr502 = ctr502;
933 ctr502->array = talloc_array(mem_ctx, struct srvsvc_NetShareInfo502, ctr502->count);
934 W_ERROR_HAVE_NO_MEMORY(ctr502->array);
936 for (i=0; i < ctr502->count; i++) {
938 union srvsvc_NetShareInfo info;
940 nterr = share_get_config(mem_ctx, sctx, snames[i], &scfg);
941 if (!NT_STATUS_IS_OK(nterr)) {
942 DEBUG(1, ("ERROR: Service [%s] disappeared after enumeration", snames[i]));
943 return WERR_GENERAL_FAILURE;
945 info.info502 = &ctr502->array[i];
946 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
947 if (!W_ERROR_IS_OK(status)) {
954 r->out.ctr.ctr502 = ctr502;
955 r->out.totalentries = r->out.ctr.ctr502->count;
959 return WERR_UNKNOWN_LEVEL;
962 return WERR_UNKNOWN_LEVEL;
967 srvsvc_NetShareGetInfo
969 static WERROR dcesrv_srvsvc_NetShareGetInfo(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
970 struct srvsvc_NetShareGetInfo *r)
973 struct share_context *sctx = NULL;
974 struct share_config *scfg = NULL;
978 /* TODO: - access check
981 if (strcmp("", r->in.share_name) == 0) {
982 return WERR_INVALID_PARAM;
985 nterr = share_get_context(mem_ctx, &sctx);
986 if (!NT_STATUS_IS_OK(nterr)) {
987 return ntstatus_to_werror(nterr);
990 nterr = share_get_config(mem_ctx, sctx, r->in.share_name, &scfg);
991 if (!NT_STATUS_IS_OK(nterr)) {
992 return ntstatus_to_werror(nterr);
995 switch (r->in.level) {
999 union srvsvc_NetShareInfo info;
1001 info.info0 = talloc(mem_ctx, struct srvsvc_NetShareInfo0);
1002 W_ERROR_HAVE_NO_MEMORY(info.info0);
1004 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
1005 if (!W_ERROR_IS_OK(status)) {
1009 r->out.info.info0 = info.info0;
1015 union srvsvc_NetShareInfo info;
1017 info.info1 = talloc(mem_ctx, struct srvsvc_NetShareInfo1);
1018 W_ERROR_HAVE_NO_MEMORY(info.info1);
1020 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
1021 if (!W_ERROR_IS_OK(status)) {
1025 r->out.info.info1 = info.info1;
1031 union srvsvc_NetShareInfo info;
1033 SRVSVC_CHECK_ADMIN_ACCESS;
1035 info.info2 = talloc(mem_ctx, struct srvsvc_NetShareInfo2);
1036 W_ERROR_HAVE_NO_MEMORY(info.info2);
1038 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
1039 if (!W_ERROR_IS_OK(status)) {
1043 r->out.info.info2 = info.info2;
1049 union srvsvc_NetShareInfo info;
1051 info.info501 = talloc(mem_ctx, struct srvsvc_NetShareInfo501);
1052 W_ERROR_HAVE_NO_MEMORY(info.info501);
1054 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
1055 if (!W_ERROR_IS_OK(status)) {
1059 r->out.info.info501 = info.info501;
1065 union srvsvc_NetShareInfo info;
1067 SRVSVC_CHECK_ADMIN_ACCESS;
1069 info.info502 = talloc(mem_ctx, struct srvsvc_NetShareInfo502);
1070 W_ERROR_HAVE_NO_MEMORY(info.info502);
1072 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
1073 if (!W_ERROR_IS_OK(status)) {
1077 r->out.info.info502 = info.info502;
1083 union srvsvc_NetShareInfo info;
1085 info.info1005 = talloc(mem_ctx, struct srvsvc_NetShareInfo1005);
1086 W_ERROR_HAVE_NO_MEMORY(info.info1005);
1088 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
1089 if (!W_ERROR_IS_OK(status)) {
1093 r->out.info.info1005 = info.info1005;
1097 return WERR_UNKNOWN_LEVEL;
1100 return WERR_UNKNOWN_LEVEL;
1103 static WERROR dcesrv_srvsvc_fill_share_info(struct share_info *info, int *count,
1104 const char *share_name, int level,
1107 const char *comment,
1108 const char *password,
1109 enum srvsvc_ShareType type,
1111 uint32_t csc_policy,
1112 struct security_descriptor *sd)
1117 info[i].name = SHARE_CSC_POLICY;
1118 info[i].type = SHARE_INFO_INT;
1119 info[i].value = talloc(info, int);
1120 *((int *)info[i].value) = csc_policy;
1127 /* TODO: check if unknown is csc_policy */
1129 /* TODO: security descriptor */
1132 if (path && path[0]) {
1133 info[i].name = SHARE_PATH;
1134 info[i].type = SHARE_INFO_STRING;
1136 /* Windows will send a path in a form of C:\example\path */
1137 if (path[1] == ':') {
1138 info[i].value = talloc_strdup(info, &path[2]);
1140 /* very strange let's try to set as is */
1141 info[i].value = talloc_strdup(info, path);
1143 W_ERROR_HAVE_NO_MEMORY(info[i].value);
1144 all_string_sub((char *)info[i].value, "\\", "/", 0);
1149 if (password && password[0]) {
1150 info[i].name = SHARE_PASSWORD;
1151 info[i].type = SHARE_INFO_STRING;
1152 info[i].value = talloc_strdup(info, password);
1153 W_ERROR_HAVE_NO_MEMORY(info[i].value);
1158 info[i].name = SHARE_MAX_CONNECTIONS;
1159 info[i].type = SHARE_INFO_INT;
1160 info[i].value = talloc(info, int);
1161 *((int *)info[i].value) = max_users;
1166 info[i].name = SHARE_TYPE;
1167 info[i].type = SHARE_INFO_STRING;
1170 info[i].value = talloc_strdup(info, "DISK");
1173 info[i].value = talloc_strdup(info, "PRINTER");
1176 info[i].value = talloc_strdup(info, "IPC");
1179 return WERR_INVALID_PARAM;
1181 W_ERROR_HAVE_NO_MEMORY(info[i].value);
1186 info[i].name = SHARE_COMMENT;
1187 info[i].type = SHARE_INFO_STRING;
1188 info[i].value = talloc_strdup(info, comment);
1189 W_ERROR_HAVE_NO_MEMORY(info[i].value);
1195 strcasecmp(share_name, name) != 0) {
1196 info[i].name = SHARE_NAME;
1197 info[i].type = SHARE_INFO_STRING;
1198 info[i].value = talloc_strdup(info, name);
1199 W_ERROR_HAVE_NO_MEMORY(info[i].value);
1206 return WERR_UNKNOWN_LEVEL;
1215 srvsvc_NetShareSetInfo
1217 static WERROR dcesrv_srvsvc_NetShareSetInfo(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1218 struct srvsvc_NetShareSetInfo *r)
1222 struct share_context *sctx = NULL;
1223 struct share_info *info;
1226 /* TODO: - access check
1229 /* there are no more than 10 options in all struct srvsvc_NetShareInfoXXX */
1230 info = talloc_array(mem_ctx, struct share_info, 10);
1231 W_ERROR_HAVE_NO_MEMORY(info);
1233 ZERO_STRUCT(r->out);
1235 if (strcmp("", r->in.share_name) == 0) {
1236 return WERR_INVALID_PARAM;
1239 nterr = share_get_context(mem_ctx, &sctx);
1240 if (!NT_STATUS_IS_OK(nterr)) {
1241 return ntstatus_to_werror(nterr);
1244 switch (r->in.level) {
1247 status = dcesrv_srvsvc_fill_share_info(info, &count,
1248 r->in.share_name, r->in.level,
1249 r->in.info.info0->name,
1257 if (W_ERROR_EQUAL(status, WERR_OK)) {
1264 status = dcesrv_srvsvc_fill_share_info(info, &count,
1265 r->in.share_name, r->in.level,
1266 r->in.info.info1->name,
1268 r->in.info.info1->comment,
1270 r->in.info.info1->type,
1274 if (W_ERROR_EQUAL(status, WERR_OK)) {
1281 status = dcesrv_srvsvc_fill_share_info(info, &count,
1282 r->in.share_name, r->in.level,
1283 r->in.info.info2->name,
1284 r->in.info.info2->path,
1285 r->in.info.info2->comment,
1286 r->in.info.info2->password,
1287 r->in.info.info2->type,
1288 r->in.info.info2->max_users,
1291 if (W_ERROR_EQUAL(status, WERR_OK)) {
1298 status = dcesrv_srvsvc_fill_share_info(info, &count,
1299 r->in.share_name, r->in.level,
1300 r->in.info.info501->name,
1302 r->in.info.info501->comment,
1304 r->in.info.info501->type,
1306 r->in.info.info501->csc_policy,
1308 if (W_ERROR_EQUAL(status, WERR_OK)) {
1315 status = dcesrv_srvsvc_fill_share_info(info, &count,
1316 r->in.share_name, r->in.level,
1317 r->in.info.info502->name,
1318 r->in.info.info502->path,
1319 r->in.info.info502->comment,
1320 r->in.info.info502->password,
1321 r->in.info.info502->type,
1322 r->in.info.info502->max_users,
1324 r->in.info.info502->sd);
1325 if (W_ERROR_EQUAL(status, WERR_OK)) {
1332 status = dcesrv_srvsvc_fill_share_info(info, &count,
1333 r->in.share_name, r->in.level,
1336 r->in.info.info1004->comment,
1342 if (W_ERROR_EQUAL(status, WERR_OK)) {
1349 /* r->in.info.dfs_flags; */
1351 if (r->in.parm_error) {
1352 r->out.parm_error = r->in.parm_error;
1358 return WERR_UNKNOWN_LEVEL;
1361 nterr = share_set(sctx, r->in.share_name, info, count);
1362 if (!NT_STATUS_IS_OK(nterr)) {
1363 return ntstatus_to_werror(nterr);
1366 if (r->in.parm_error) {
1367 r->out.parm_error = r->in.parm_error;
1375 srvsvc_NetShareDelSticky
1377 static WERROR dcesrv_srvsvc_NetShareDelSticky(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1378 struct srvsvc_NetShareDelSticky *r)
1380 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
1385 srvsvc_NetShareCheck
1387 static WERROR dcesrv_srvsvc_NetShareCheck(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1388 struct srvsvc_NetShareCheck *r)
1391 struct share_context *sctx = NULL;
1392 struct share_config *scfg = NULL;
1397 ZERO_STRUCT(r->out);
1399 /* TODO: - access check
1402 if (strcmp("", r->in.device_name) == 0) {
1403 r->out.type = STYPE_IPC;
1407 /* copy the path skipping C:\ */
1408 if (strncasecmp(r->in.device_name, "C:", 2) == 0) {
1409 device = talloc_strdup(mem_ctx, &r->in.device_name[2]);
1411 /* no chance we have a share that doesn't start with C:\ */
1412 return WERR_DEVICE_NOT_SHARED;
1414 all_string_sub(device, "\\", "/", 0);
1416 nterr = share_get_context(mem_ctx, &sctx);
1417 if (!NT_STATUS_IS_OK(nterr)) {
1418 return ntstatus_to_werror(nterr);
1421 nterr = share_list_all(mem_ctx, sctx, &count, &names);
1422 if (!NT_STATUS_IS_OK(nterr)) {
1423 return ntstatus_to_werror(nterr);
1426 for (i = 0; i < count; i++) {
1430 nterr = share_get_config(mem_ctx, sctx, names[i], &scfg);
1431 if (!NT_STATUS_IS_OK(nterr)) {
1432 return ntstatus_to_werror(nterr);
1434 path = share_string_option(scfg, SHARE_PATH, NULL);
1435 if (!path) continue;
1437 if (strcmp(device, path) == 0) {
1438 type = share_string_option(scfg, SHARE_TYPE, NULL);
1439 if (!type) continue;
1441 if (strcmp(type, "DISK") == 0) {
1442 r->out.type = STYPE_DISKTREE;
1446 if (strcmp(type, "IPC") == 0) {
1447 r->out.type = STYPE_IPC;
1451 if (strcmp(type, "PRINTER") == 0) {
1452 r->out.type = STYPE_PRINTQ;
1458 return WERR_DEVICE_NOT_SHARED;
1463 srvsvc_NetSrvGetInfo
1465 static WERROR dcesrv_srvsvc_NetSrvGetInfo(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1466 struct srvsvc_NetSrvGetInfo *r)
1468 struct dcesrv_context *dce_ctx = dce_call->conn->dce_ctx;
1470 ZERO_STRUCT(r->out);
1472 switch (r->in.level) {
1475 struct srvsvc_NetSrvInfo100 *info100;
1477 info100 = talloc(mem_ctx, struct srvsvc_NetSrvInfo100);
1478 W_ERROR_HAVE_NO_MEMORY(info100);
1480 info100->platform_id = dcesrv_common_get_platform_id(mem_ctx, dce_ctx);
1481 info100->server_name = dcesrv_common_get_server_name(mem_ctx, dce_ctx, r->in.server_unc);
1482 W_ERROR_HAVE_NO_MEMORY(info100->server_name);
1484 r->out.info.info100 = info100;
1489 struct srvsvc_NetSrvInfo101 *info101;
1491 info101 = talloc(mem_ctx, struct srvsvc_NetSrvInfo101);
1492 W_ERROR_HAVE_NO_MEMORY(info101);
1494 info101->platform_id = dcesrv_common_get_platform_id(mem_ctx, dce_ctx);
1495 info101->server_name = dcesrv_common_get_server_name(mem_ctx, dce_ctx, r->in.server_unc);
1496 W_ERROR_HAVE_NO_MEMORY(info101->server_name);
1498 info101->version_major = dcesrv_common_get_version_major(mem_ctx, dce_ctx);
1499 info101->version_minor = dcesrv_common_get_version_minor(mem_ctx, dce_ctx);
1500 info101->server_type = dcesrv_common_get_server_type(mem_ctx, dce_ctx);
1501 info101->comment = talloc_strdup(mem_ctx, lp_serverstring());
1502 W_ERROR_HAVE_NO_MEMORY(info101->comment);
1504 r->out.info.info101 = info101;
1509 struct srvsvc_NetSrvInfo102 *info102;
1511 info102 = talloc(mem_ctx, struct srvsvc_NetSrvInfo102);
1512 W_ERROR_HAVE_NO_MEMORY(info102);
1514 info102->platform_id = dcesrv_common_get_platform_id(mem_ctx, dce_ctx);
1515 info102->server_name = dcesrv_common_get_server_name(mem_ctx, dce_ctx, r->in.server_unc);
1516 W_ERROR_HAVE_NO_MEMORY(info102->server_name);
1518 info102->version_major = dcesrv_common_get_version_major(mem_ctx, dce_ctx);
1519 info102->version_minor = dcesrv_common_get_version_minor(mem_ctx, dce_ctx);
1520 info102->server_type = dcesrv_common_get_server_type(mem_ctx, dce_ctx);
1521 info102->comment = talloc_strdup(mem_ctx, lp_serverstring());
1522 W_ERROR_HAVE_NO_MEMORY(info102->comment);
1524 info102->users = dcesrv_common_get_users(mem_ctx, dce_ctx);
1525 info102->disc = dcesrv_common_get_disc(mem_ctx, dce_ctx);
1526 info102->hidden = dcesrv_common_get_hidden(mem_ctx, dce_ctx);
1527 info102->announce = dcesrv_common_get_announce(mem_ctx, dce_ctx);
1528 info102->anndelta = dcesrv_common_get_anndelta(mem_ctx, dce_ctx);
1529 info102->licenses = dcesrv_common_get_licenses(mem_ctx, dce_ctx);
1530 info102->userpath = dcesrv_common_get_userpath(mem_ctx, dce_ctx);
1531 W_ERROR_HAVE_NO_MEMORY(info102->userpath);
1533 r->out.info.info102 = info102;
1537 return WERR_UNKNOWN_LEVEL;
1540 return WERR_UNKNOWN_LEVEL;
1545 srvsvc_NetSrvSetInfo
1547 static WERROR dcesrv_srvsvc_NetSrvSetInfo(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1548 struct srvsvc_NetSrvSetInfo *r)
1550 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
1557 static WERROR dcesrv_srvsvc_NetDiskEnum(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1558 struct srvsvc_NetDiskEnum *r)
1560 r->out.info.disks = NULL;
1561 r->out.info.count = 0;
1562 r->out.totalentries = 0;
1563 r->out.resume_handle = NULL;
1565 switch (r->in.level) {
1568 /* we can safely hardcode the reply and report we have only one disk (C:) */
1569 /* for some reason Windows wants 2 entries with the second being empty */
1570 r->out.info.disks = talloc_array(mem_ctx, struct srvsvc_NetDiskInfo0, 2);
1571 W_ERROR_HAVE_NO_MEMORY(r->out.info.disks);
1572 r->out.info.count = 2;
1574 r->out.info.disks[0].disk = talloc_strdup(mem_ctx, "C:");
1575 W_ERROR_HAVE_NO_MEMORY(r->out.info.disks[0].disk);
1577 r->out.info.disks[1].disk = talloc_strdup(mem_ctx, "");
1578 W_ERROR_HAVE_NO_MEMORY(r->out.info.disks[1].disk);
1580 r->out.totalentries = 1;
1581 r->out.resume_handle = r->in.resume_handle;
1586 return WERR_UNKNOWN_LEVEL;
1589 return WERR_UNKNOWN_LEVEL;
1594 srvsvc_NetServerStatisticsGet
1596 static WERROR dcesrv_srvsvc_NetServerStatisticsGet(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1597 struct srvsvc_NetServerStatisticsGet *r)
1599 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
1604 srvsvc_NetTransportAdd
1606 static WERROR dcesrv_srvsvc_NetTransportAdd(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1607 struct srvsvc_NetTransportAdd *r)
1609 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
1614 srvsvc_NetTransportEnum
1616 static WERROR dcesrv_srvsvc_NetTransportEnum(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1617 struct srvsvc_NetTransportEnum *r)
1619 r->out.level = r->in.level;
1620 r->out.totalentries = 0;
1621 r->out.resume_handle = NULL;
1623 switch (r->in.level) {
1626 r->out.transports.ctr0 = talloc(mem_ctx, struct srvsvc_NetTransportCtr0);
1627 W_ERROR_HAVE_NO_MEMORY(r->out.transports.ctr0);
1629 r->out.transports.ctr0->count = 0;
1630 r->out.transports.ctr0->array = NULL;
1632 return WERR_NOT_SUPPORTED;
1636 r->out.transports.ctr1 = talloc(mem_ctx, struct srvsvc_NetTransportCtr1);
1637 W_ERROR_HAVE_NO_MEMORY(r->out.transports.ctr1);
1639 r->out.transports.ctr1->count = 0;
1640 r->out.transports.ctr1->array = NULL;
1642 return WERR_NOT_SUPPORTED;
1646 r->out.transports.ctr2 = talloc(mem_ctx, struct srvsvc_NetTransportCtr2);
1647 W_ERROR_HAVE_NO_MEMORY(r->out.transports.ctr2);
1649 r->out.transports.ctr2->count = 0;
1650 r->out.transports.ctr2->array = NULL;
1652 return WERR_NOT_SUPPORTED;
1656 r->out.transports.ctr3 = talloc(mem_ctx, struct srvsvc_NetTransportCtr3);
1657 W_ERROR_HAVE_NO_MEMORY(r->out.transports.ctr3);
1659 r->out.transports.ctr3->count = 0;
1660 r->out.transports.ctr3->array = NULL;
1662 return WERR_NOT_SUPPORTED;
1665 return WERR_UNKNOWN_LEVEL;
1668 return WERR_UNKNOWN_LEVEL;
1672 srvsvc_NetTransportDel
1674 static WERROR dcesrv_srvsvc_NetTransportDel(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1675 struct srvsvc_NetTransportDel *r)
1677 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
1684 static WERROR dcesrv_srvsvc_NetRemoteTOD(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1685 struct srvsvc_NetRemoteTOD *r)
1687 struct timeval tval;
1691 r->out.info = talloc(mem_ctx, struct srvsvc_NetRemoteTODInfo);
1692 W_ERROR_HAVE_NO_MEMORY(r->out.info);
1694 GetTimeOfDay(&tval);
1699 r->out.info->elapsed = t;
1700 /* TODO: fake the uptime: just return the milliseconds till 0:00:00 today */
1701 r->out.info->msecs = (tm.tm_hour*60*60*1000)
1702 + (tm.tm_min*60*1000)
1704 + (tval.tv_usec/1000);
1705 r->out.info->hours = tm.tm_hour;
1706 r->out.info->mins = tm.tm_min;
1707 r->out.info->secs = tm.tm_sec;
1708 r->out.info->hunds = tval.tv_usec/10000;
1709 r->out.info->timezone = get_time_zone(t)/60;
1710 r->out.info->tinterval = 310; /* just return the same as windows */
1711 r->out.info->day = tm.tm_mday;
1712 r->out.info->month = tm.tm_mon + 1;
1713 r->out.info->year = tm.tm_year + 1900;
1714 r->out.info->weekday = tm.tm_wday;
1722 static WERROR dcesrv_srvsvc_NetPathType(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1723 struct srvsvc_NetPathType *r)
1725 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
1730 srvsvc_NetPathCanonicalize
1732 static WERROR dcesrv_srvsvc_NetPathCanonicalize(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1733 struct srvsvc_NetPathCanonicalize *r)
1735 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
1740 srvsvc_NetPathCompare
1742 static WERROR dcesrv_srvsvc_NetPathCompare(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1743 struct srvsvc_NetPathCompare *r)
1745 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
1750 srvsvc_NetNameValidate
1752 static WERROR dcesrv_srvsvc_NetNameValidate(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1753 struct srvsvc_NetNameValidate *r)
1757 if ((r->in.flags != 0x0) && (r->in.flags != 0x80000000)) {
1758 return WERR_INVALID_NAME;
1761 switch (r->in.name_type) {
1770 return WERR_NOT_SUPPORTED;
1772 case 9: /* validate share name */
1774 len = strlen_m(r->in.name);
1775 if ((r->in.flags == 0x0) && (len > 81)) {
1776 return WERR_INVALID_NAME;
1778 if ((r->in.flags == 0x80000000) && (len > 13)) {
1779 return WERR_INVALID_NAME;
1781 if (! dcesrv_common_validate_share_name(mem_ctx, r->in.name)) {
1782 return WERR_INVALID_NAME;
1790 return WERR_NOT_SUPPORTED;
1792 return WERR_INVALID_PARAM;
1795 return WERR_INVALID_PARAM;
1800 srvsvc_NetPRNameCompare
1802 static WERROR dcesrv_srvsvc_NetPRNameCompare(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1803 struct srvsvc_NetPRNameCompare *r)
1805 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
1812 static WERROR dcesrv_srvsvc_NetShareEnum(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
1813 struct srvsvc_NetShareEnum *r)
1817 const char **snames;
1818 struct share_context *sctx;
1819 struct share_config *scfg;
1820 struct dcesrv_context *dce_ctx = dce_call->conn->dce_ctx;
1822 r->out.level = r->in.level;
1823 ZERO_STRUCT(r->out.ctr);
1824 r->out.totalentries = 0;
1825 r->out.resume_handle = NULL;
1827 /* TODO: - paging of results
1830 nterr = share_get_context(mem_ctx, &sctx);
1831 if (!NT_STATUS_IS_OK(nterr)) {
1832 return ntstatus_to_werror(nterr);
1835 nterr = share_list_all(mem_ctx, sctx, &numshares, &snames);
1836 if (!NT_STATUS_IS_OK(nterr)) {
1837 return ntstatus_to_werror(nterr);
1840 switch (r->in.level) {
1845 struct srvsvc_NetShareCtr0 *ctr0;
1847 ctr0 = talloc(mem_ctx, struct srvsvc_NetShareCtr0);
1848 W_ERROR_HAVE_NO_MEMORY(ctr0);
1851 ctr0->count = count;
1854 if (ctr0->count == 0) {
1855 r->out.ctr.ctr0 = ctr0;
1859 ctr0->array = talloc_array(mem_ctx, struct srvsvc_NetShareInfo0, count);
1860 W_ERROR_HAVE_NO_MEMORY(ctr0->array);
1862 for (i=0; i < count; i++) {
1864 union srvsvc_NetShareInfo info;
1865 enum srvsvc_ShareType type;
1867 nterr = share_get_config(mem_ctx, sctx, snames[i], &scfg);
1868 if (!NT_STATUS_IS_OK(nterr)) {
1869 DEBUG(1, ("ERROR: Service [%s] disappeared after enumeration", snames[i]));
1870 return WERR_GENERAL_FAILURE;
1873 type = dcesrv_common_get_share_type(mem_ctx, dce_ctx, scfg);
1874 if (type & STYPE_HIDDEN) {
1880 info.info0 = &ctr0->array[y];
1881 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
1882 W_ERROR_NOT_OK_RETURN(status);
1886 talloc_free(snames);
1888 r->out.ctr.ctr0 = ctr0;
1889 r->out.totalentries = r->out.ctr.ctr0->count;
1896 struct srvsvc_NetShareCtr1 *ctr1;
1898 ctr1 = talloc(mem_ctx, struct srvsvc_NetShareCtr1);
1899 W_ERROR_HAVE_NO_MEMORY(ctr1);
1902 ctr1->count = count;
1905 if (ctr1->count == 0) {
1906 r->out.ctr.ctr1 = ctr1;
1910 ctr1->array = talloc_array(mem_ctx, struct srvsvc_NetShareInfo1, count);
1911 W_ERROR_HAVE_NO_MEMORY(ctr1->array);
1913 for (i=0; i < count; i++) {
1915 union srvsvc_NetShareInfo info;
1916 enum srvsvc_ShareType type;
1918 nterr = share_get_config(mem_ctx, sctx, snames[i], &scfg);
1919 if (!NT_STATUS_IS_OK(nterr)) {
1920 DEBUG(1, ("ERROR: Service [%s] disappeared after enumeration", snames[i]));
1921 return WERR_GENERAL_FAILURE;
1924 type = dcesrv_common_get_share_type(mem_ctx, dce_ctx, scfg);
1925 if (type & STYPE_HIDDEN) {
1931 info.info1 = &ctr1->array[y];
1932 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
1933 W_ERROR_NOT_OK_RETURN(status);
1937 talloc_free(snames);
1939 r->out.ctr.ctr1 = ctr1;
1940 r->out.totalentries = r->out.ctr.ctr1->count;
1947 struct srvsvc_NetShareCtr2 *ctr2;
1949 SRVSVC_CHECK_ADMIN_ACCESS;
1951 ctr2 = talloc(mem_ctx, struct srvsvc_NetShareCtr2);
1952 W_ERROR_HAVE_NO_MEMORY(ctr2);
1955 ctr2->count = count;
1958 if (ctr2->count == 0) {
1959 r->out.ctr.ctr2 = ctr2;
1963 ctr2->array = talloc_array(mem_ctx, struct srvsvc_NetShareInfo2, count);
1964 W_ERROR_HAVE_NO_MEMORY(ctr2->array);
1966 for (i=0; i < count; i++) {
1968 union srvsvc_NetShareInfo info;
1969 enum srvsvc_ShareType type;
1971 nterr = share_get_config(mem_ctx, sctx, snames[i], &scfg);
1972 if (!NT_STATUS_IS_OK(nterr)) {
1973 DEBUG(1, ("ERROR: Service [%s] disappeared after enumeration", snames[i]));
1974 return WERR_GENERAL_FAILURE;
1977 type = dcesrv_common_get_share_type(mem_ctx, dce_ctx, scfg);
1978 if (type & STYPE_HIDDEN) {
1984 info.info2 = &ctr2->array[y];
1985 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
1986 W_ERROR_NOT_OK_RETURN(status);
1990 talloc_free(snames);
1992 r->out.ctr.ctr2 = ctr2;
1993 r->out.totalentries = r->out.ctr.ctr2->count;
2000 struct srvsvc_NetShareCtr502 *ctr502;
2002 SRVSVC_CHECK_ADMIN_ACCESS;
2004 ctr502 = talloc(mem_ctx, struct srvsvc_NetShareCtr502);
2005 W_ERROR_HAVE_NO_MEMORY(ctr502);
2008 ctr502->count = count;
2009 ctr502->array = NULL;
2011 if (ctr502->count == 0) {
2012 r->out.ctr.ctr502 = ctr502;
2016 ctr502->array = talloc_array(mem_ctx, struct srvsvc_NetShareInfo502, count);
2017 W_ERROR_HAVE_NO_MEMORY(ctr502->array);
2019 for (i=0; i < count; i++) {
2021 union srvsvc_NetShareInfo info;
2022 enum srvsvc_ShareType type;
2024 nterr = share_get_config(mem_ctx, sctx, snames[i], &scfg);
2025 if (!NT_STATUS_IS_OK(nterr)) {
2026 DEBUG(1, ("ERROR: Service [%s] disappeared after enumeration", snames[i]));
2027 return WERR_GENERAL_FAILURE;
2030 type = dcesrv_common_get_share_type(mem_ctx, dce_ctx, scfg);
2031 if (type & STYPE_HIDDEN) {
2037 info.info502 = &ctr502->array[y];
2038 status = dcesrv_srvsvc_fiel_ShareInfo(dce_call, mem_ctx, scfg, r->in.level, &info);
2039 W_ERROR_NOT_OK_RETURN(status);
2043 talloc_free(snames);
2045 r->out.ctr.ctr502 = ctr502;
2046 r->out.totalentries = r->out.ctr.ctr502->count;
2050 return WERR_UNKNOWN_LEVEL;
2053 return WERR_UNKNOWN_LEVEL;
2058 srvsvc_NetShareDelStart
2060 static WERROR dcesrv_srvsvc_NetShareDelStart(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2061 struct srvsvc_NetShareDelStart *r)
2063 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2068 srvsvc_NetShareDelCommit
2070 static WERROR dcesrv_srvsvc_NetShareDelCommit(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2071 struct srvsvc_NetShareDelCommit *r)
2073 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2078 srvsvc_NetGetFileSecurity
2080 static WERROR dcesrv_srvsvc_NetGetFileSecurity(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2081 struct srvsvc_NetGetFileSecurity *r)
2083 struct sec_desc_buf *sd_buf;
2084 struct ntvfs_context *ntvfs_ctx = NULL;
2085 struct ntvfs_request *ntvfs_req;
2086 union smb_fileinfo *io;
2089 nt_status = srvsvc_create_ntvfs_context(dce_call, mem_ctx, r->in.share, &ntvfs_ctx);
2090 if (!NT_STATUS_IS_OK(nt_status)) return ntstatus_to_werror(nt_status);
2092 ntvfs_req = ntvfs_request_create(ntvfs_ctx, mem_ctx,
2093 dce_call->conn->auth_state.session_info,
2097 W_ERROR_HAVE_NO_MEMORY(ntvfs_req);
2099 sd_buf = talloc(mem_ctx, struct sec_desc_buf);
2100 W_ERROR_HAVE_NO_MEMORY(sd_buf);
2102 io = talloc(mem_ctx, union smb_fileinfo);
2103 W_ERROR_HAVE_NO_MEMORY(io);
2105 io->query_secdesc.level = RAW_FILEINFO_SEC_DESC;
2106 io->query_secdesc.in.file.path = r->in.file;
2107 io->query_secdesc.in.secinfo_flags = r->in.securityinformation;
2109 nt_status = ntvfs_qpathinfo(ntvfs_req, io);
2110 if (!NT_STATUS_IS_OK(nt_status)) return ntstatus_to_werror(nt_status);
2112 sd_buf->sd = io->query_secdesc.out.sd;
2114 r->out.sd_buf = sd_buf;
2120 srvsvc_NetSetFileSecurity
2122 static WERROR dcesrv_srvsvc_NetSetFileSecurity(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2123 struct srvsvc_NetSetFileSecurity *r)
2125 struct ntvfs_context *ntvfs_ctx;
2126 struct ntvfs_request *ntvfs_req;
2127 union smb_setfileinfo *io;
2130 nt_status = srvsvc_create_ntvfs_context(dce_call, mem_ctx, r->in.share, &ntvfs_ctx);
2131 if (!NT_STATUS_IS_OK(nt_status)) return ntstatus_to_werror(nt_status);
2133 ntvfs_req = ntvfs_request_create(ntvfs_ctx, mem_ctx,
2134 dce_call->conn->auth_state.session_info,
2138 W_ERROR_HAVE_NO_MEMORY(ntvfs_req);
2140 io = talloc(mem_ctx, union smb_setfileinfo);
2141 W_ERROR_HAVE_NO_MEMORY(io);
2143 io->set_secdesc.level = RAW_FILEINFO_SEC_DESC;
2144 io->set_secdesc.in.file.path = r->in.file;
2145 io->set_secdesc.in.secinfo_flags = r->in.securityinformation;
2146 io->set_secdesc.in.sd = r->in.sd_buf.sd;
2148 nt_status = ntvfs_setpathinfo(ntvfs_req, io);
2149 if (!NT_STATUS_IS_OK(nt_status)) return ntstatus_to_werror(nt_status);
2156 srvsvc_NetServerTransportAddEx
2158 static WERROR dcesrv_srvsvc_NetServerTransportAddEx(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2159 struct srvsvc_NetServerTransportAddEx *r)
2161 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2166 srvsvc_NetServerSetServiceBitsEx
2168 static WERROR dcesrv_srvsvc_NetServerSetServiceBitsEx(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2169 struct srvsvc_NetServerSetServiceBitsEx *r)
2171 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2176 srvsvc_NETRDFSGETVERSION
2178 static WERROR dcesrv_srvsvc_NETRDFSGETVERSION(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2179 struct srvsvc_NETRDFSGETVERSION *r)
2181 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2186 srvsvc_NETRDFSCREATELOCALPARTITION
2188 static WERROR dcesrv_srvsvc_NETRDFSCREATELOCALPARTITION(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2189 struct srvsvc_NETRDFSCREATELOCALPARTITION *r)
2191 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2196 srvsvc_NETRDFSDELETELOCALPARTITION
2198 static WERROR dcesrv_srvsvc_NETRDFSDELETELOCALPARTITION(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2199 struct srvsvc_NETRDFSDELETELOCALPARTITION *r)
2201 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2206 srvsvc_NETRDFSSETLOCALVOLUMESTATE
2208 static WERROR dcesrv_srvsvc_NETRDFSSETLOCALVOLUMESTATE(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2209 struct srvsvc_NETRDFSSETLOCALVOLUMESTATE *r)
2211 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2216 srvsvc_NETRDFSSETSERVERINFO
2218 static WERROR dcesrv_srvsvc_NETRDFSSETSERVERINFO(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2219 struct srvsvc_NETRDFSSETSERVERINFO *r)
2221 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2226 srvsvc_NETRDFSCREATEEXITPOINT
2228 static WERROR dcesrv_srvsvc_NETRDFSCREATEEXITPOINT(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2229 struct srvsvc_NETRDFSCREATEEXITPOINT *r)
2231 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2236 srvsvc_NETRDFSDELETEEXITPOINT
2238 static WERROR dcesrv_srvsvc_NETRDFSDELETEEXITPOINT(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2239 struct srvsvc_NETRDFSDELETEEXITPOINT *r)
2241 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2246 srvsvc_NETRDFSMODIFYPREFIX
2248 static WERROR dcesrv_srvsvc_NETRDFSMODIFYPREFIX(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2249 struct srvsvc_NETRDFSMODIFYPREFIX *r)
2251 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2256 srvsvc_NETRDFSFIXLOCALVOLUME
2258 static WERROR dcesrv_srvsvc_NETRDFSFIXLOCALVOLUME(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2259 struct srvsvc_NETRDFSFIXLOCALVOLUME *r)
2261 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2266 srvsvc_NETRDFSMANAGERREPORTSITEINFO
2268 static WERROR dcesrv_srvsvc_NETRDFSMANAGERREPORTSITEINFO(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2269 struct srvsvc_NETRDFSMANAGERREPORTSITEINFO *r)
2271 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2276 srvsvc_NETRSERVERTRANSPORTDELEX
2278 static WERROR dcesrv_srvsvc_NETRSERVERTRANSPORTDELEX(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2279 struct srvsvc_NETRSERVERTRANSPORTDELEX *r)
2281 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2287 static WERROR dcesrv_srvsvc_NetShareDel(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2288 struct srvsvc_NetShareDel *r)
2291 struct share_context *sctx;
2293 nterr = share_get_context(mem_ctx, &sctx);
2294 if (!NT_STATUS_IS_OK(nterr)) {
2295 return ntstatus_to_werror(nterr);
2298 nterr = share_remove(sctx, r->in.share_name);
2299 if (!NT_STATUS_IS_OK(nterr)) {
2300 return ntstatus_to_werror(nterr);
2307 srvsvc_NetSetServiceBits
2309 static WERROR dcesrv_srvsvc_NetSetServiceBits(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2310 struct srvsvc_NetSetServiceBits *r)
2312 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2316 srvsvc_NETRPRNAMECANONICALIZE
2318 static WERROR dcesrv_srvsvc_NETRPRNAMECANONICALIZE(struct dcesrv_call_state *dce_call, TALLOC_CTX *mem_ctx,
2319 struct srvsvc_NETRPRNAMECANONICALIZE *r)
2321 DCESRV_FAULT(DCERPC_FAULT_OP_RNG_ERROR);
2324 /* include the generated boilerplate */
2325 #include "librpc/gen_ndr/ndr_srvsvc_s.c"