2N/A/*
2N/A * CDDL HEADER START
2N/A *
2N/A * The contents of this file are subject to the terms of the
2N/A * Common Development and Distribution License (the "License").
2N/A * You may not use this file except in compliance with the License.
2N/A *
2N/A * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
2N/A * or http://www.opensolaris.org/os/licensing.
2N/A * See the License for the specific language governing permissions
2N/A * and limitations under the License.
2N/A *
2N/A * When distributing Covered Code, include this CDDL HEADER in each
2N/A * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
2N/A * If applicable, add the following below this CDDL HEADER, with the
2N/A * fields enclosed by brackets "[]" replaced with your own identifying
2N/A * information: Portions Copyright [yyyy] [name of copyright owner]
2N/A *
2N/A * CDDL HEADER END
2N/A */
2N/A
2N/A/*
2N/A * Copyright (c) 2010, 2012, Oracle and/or its affiliates. All rights reserved.
2N/A */
2N/A
2N/A#include <netdb.h>
2N/A#include <sys/types.h>
2N/A#include <string.h>
2N/A#include <strings.h>
2N/A#include <smbsrv/libsmb.h>
2N/A#include <smbsrv/libntsvcs.h>
2N/A#include <smbsrv/smbinfo.h>
2N/A#include <smb/nmpipes.h>
2N/A#include <smbsrv/ndl/srvsvc.ndl>
2N/A
2N/Astatic int wkssvc_s_NetWkstaGetInfo(void *, ndr_xa_t *);
2N/Astatic int wkssvc_s_NetWkstaTransportEnum(void *, ndr_xa_t *);
2N/A
2N/Astatic ndr_stub_table_t wkssvc_stub_table[] = {
2N/A { wkssvc_s_NetWkstaGetInfo, WKSSVC_OPNUM_NetWkstaGetInfo },
2N/A { wkssvc_s_NetWkstaTransportEnum, WKSSVC_OPNUM_NetWkstaTransportEnum },
2N/A {0}
2N/A};
2N/A
2N/Astatic ndr_service_t wkssvc_service = {
2N/A "Workstation", /* name (WKSSVC or WKSTA) */
2N/A "Workstation services", /* desc */
2N/A "\\wkssvc", /* endpoint */
2N/A PIPE_NTSVCS, /* sec_addr_port */
2N/A "6bffd098-a112-3610-9833-46c3f87e345a", 1, /* abstract */
2N/A NDR_TRANSFER_SYNTAX_UUID, 2, /* transfer */
2N/A 0, /* no bind_instance_size */
2N/A 0, /* no bind_req() */
2N/A 0, /* no unbind_and_close() */
2N/A 0, /* use generic_call_stub() */
2N/A &TYPEINFO(wkssvc_interface), /* interface ti */
2N/A wkssvc_stub_table /* stub_table */
2N/A};
2N/A
2N/Avoid
2N/Awkssvc_initialize(void)
2N/A{
2N/A (void) ndr_svc_register(&wkssvc_service);
2N/A}
2N/A
2N/A/*
2N/A * WKSSVC NetWkstaGetInfo
2N/A */
2N/Astatic int
2N/Awkssvc_s_NetWkstaGetInfo(void *arg, ndr_xa_t *mxa)
2N/A{
2N/A struct mslm_NetWkstaGetInfo *param = arg;
2N/A mslm_NetWkstaGetInfo_rb *rb;
2N/A char hostname[MAXHOSTNAMELEN];
2N/A char resource_domain[SMB_PI_MAX_DOMAIN];
2N/A smb_version_t version;
2N/A char *name;
2N/A char *domain;
2N/A DWORD status;
2N/A int rc;
2N/A
2N/A (void) smb_getdomainname_nb(resource_domain, SMB_PI_MAX_DOMAIN);
2N/A
2N/A rb = NDR_NEW(mxa, mslm_NetWkstaGetInfo_rb);
2N/A
2N/A if ((rc = smb_getnetbiosname(hostname, MAXHOSTNAMELEN)) == 0) {
2N/A name = NDR_STRDUP(mxa, hostname);
2N/A domain = NDR_STRDUP(mxa, resource_domain);
2N/A }
2N/A
2N/A if ((rc != 0) || (rb == NULL) || (name == NULL) || (domain == NULL)) {
2N/A bzero(param, sizeof (struct mslm_NetWkstaGetInfo));
2N/A param->status = ERROR_NOT_ENOUGH_MEMORY;
2N/A return (NDR_DRC_OK);
2N/A }
2N/A
2N/A smb_config_get_version(&version);
2N/A
2N/A param->result.level = param->level;
2N/A param->result.bufptr.nullptr = (void *)rb;
2N/A
2N/A switch (param->level) {
2N/A case 100:
2N/A rb->buf100.wki100_platform_id = SV_PLATFORM_ID_NT;
2N/A rb->buf100.wki100_ver_major = version.sv_major;
2N/A rb->buf100.wki100_ver_minor = version.sv_minor;
2N/A rb->buf100.wki100_computername = (unsigned char *)name;
2N/A rb->buf100.wki100_langroup = (unsigned char *)domain;
2N/A status = ERROR_SUCCESS;
2N/A break;
2N/A
2N/A case 101:
2N/A rb->buf101.wki101_platform_id = SV_PLATFORM_ID_NT;
2N/A rb->buf101.wki101_ver_major = version.sv_major;
2N/A rb->buf101.wki101_ver_minor = version.sv_minor;
2N/A rb->buf101.wki101_computername = (unsigned char *)name;
2N/A rb->buf101.wki101_langroup = (unsigned char *)domain;
2N/A rb->buf101.wki101_lanroot = (unsigned char *)"";
2N/A status = ERROR_SUCCESS;
2N/A break;
2N/A
2N/A case 102:
2N/A rb->buf102.wki102_platform_id = SV_PLATFORM_ID_NT;
2N/A rb->buf102.wki102_ver_major = version.sv_major;
2N/A rb->buf102.wki102_ver_minor = version.sv_minor;
2N/A rb->buf102.wki102_computername = (unsigned char *)name;
2N/A rb->buf102.wki102_langroup = (unsigned char *)domain;
2N/A rb->buf102.wki102_lanroot = (unsigned char *)"";
2N/A rb->buf102.wki102_logged_on_users = 1;
2N/A status = ERROR_SUCCESS;
2N/A break;
2N/A
2N/A case 502:
2N/A bzero(&rb->buf502, sizeof (struct mslm_WKSTA_INFO_502));
2N/A rb->buf502.keep_connection = 600;
2N/A rb->buf502.max_commands = 1024;
2N/A rb->buf502.session_timeout = SSN_KEEP_ALIVE_TIMEOUT;
2N/A rb->buf502.size_char_buf = 1024;
2N/A rb->buf502.max_threads = 1024;
2N/A rb->buf502.use_opportunistic_locking = 1;
2N/A rb->buf502.use_unlock_behind = 1;
2N/A rb->buf502.use_close_behind = 1;
2N/A rb->buf502.buf_named_pipes = 1;
2N/A rb->buf502.use_lock_read_unlock = 1;
2N/A rb->buf502.utilize_nt_caching = 1;
2N/A rb->buf502.use_raw_read = 1;
2N/A rb->buf502.use_raw_write = 1;
2N/A status = ERROR_SUCCESS;
2N/A break;
2N/A
2N/A default:
2N/A param->result.bufptr.nullptr = 0;
2N/A status = ERROR_INVALID_LEVEL;
2N/A break;
2N/A }
2N/A
2N/A if (status != ERROR_SUCCESS) {
2N/A bzero(param, sizeof (struct mslm_NetWkstaGetInfo));
2N/A param->status = status;
2N/A }
2N/A
2N/A return (NDR_DRC_OK);
2N/A}
2N/A
2N/A/*
2N/A * WKSSVC NetWkstaTransportEnum
2N/A */
2N/Astatic int
2N/Awkssvc_s_NetWkstaTransportEnum(void *arg, ndr_xa_t *mxa)
2N/A{
2N/A struct mslm_NetWkstaTransportEnum *param = arg;
2N/A struct mslm_NetWkstaTransportCtr0 *info0;
2N/A struct mslm_NetWkstaTransportInfo0 *ti0;
2N/A
2N/A switch (param->info.level) {
2N/A case 0:
2N/A info0 = NDR_NEW(mxa, struct mslm_NetWkstaTransportCtr0);
2N/A ti0 = NDR_NEW(mxa, struct mslm_NetWkstaTransportInfo0);
2N/A
2N/A if (info0 == NULL || ti0 == NULL) {
2N/A bzero(param, sizeof (struct mslm_NetWkstaGetInfo));
2N/A param->status = ERROR_NOT_ENOUGH_MEMORY;
2N/A break;
2N/A }
2N/A
2N/A ti0->quality_of_service = 65535;
2N/A ti0->num_vcs = 0;
2N/A ti0->transport_name = (unsigned char *)"\\Device\\NetbiosSmb";
2N/A ti0->transport_address = (unsigned char *)"000000000000";
2N/A ti0->wan_ish = 1024;
2N/A
2N/A info0->count = 1;
2N/A info0->ti0 = ti0;
2N/A param->info.ru.info0 = info0;
2N/A param->total_entries = 1;
2N/A
2N/A if (param->resume_handle)
2N/A *param->resume_handle = 0;
2N/A
2N/A param->status = ERROR_SUCCESS;
2N/A break;
2N/A
2N/A default:
2N/A bzero(param, sizeof (struct mslm_NetWkstaGetInfo));
2N/A param->status = ERROR_INVALID_LEVEL;
2N/A }
2N/A
2N/A return (NDR_DRC_OK);
2N/A}