static int ejs_cli_connect(MprVarHandle eid, int argc, char **argv) { struct smbcli_socket *sock; struct smbcli_transport *transport; struct nbt_name calling, called; NTSTATUS result; if (argc != 1) { ejsSetErrorMsg(eid, "connect invalid arguments"); return -1; } /* Socket connect */ sock = smbcli_sock_init(NULL, NULL); if (!sock) { ejsSetErrorMsg(eid, "socket initialisation failed"); return -1; } if (!smbcli_sock_connect_byname(sock, argv[0], 0)) { ejsSetErrorMsg(eid, "socket connect failed"); return -1; } transport = smbcli_transport_init(sock, sock, False); if (!transport) { ejsSetErrorMsg(eid, "transport init failed"); return -1; } /* Send a netbios session request */ make_nbt_name_client(&calling, lp_netbios_name()); nbt_choose_called_name(NULL, &called, argv[0], NBT_NAME_SERVER); if (!smbcli_transport_connect(transport, &calling, &called)) { ejsSetErrorMsg(eid, "transport establishment failed"); return -1; } result = smb_raw_negotiate(transport, lp_maxprotocol()); if (!NT_STATUS_IS_OK(result)) { mpr_Return(eid, mprNTSTATUS(result)); return 0; } /* Return a socket object */ mpr_Return(eid, mprCreatePtrVar(transport)); return 0; }
/* wrapper around smb_raw_negotiate() */ NTSTATUS smbcli_negprot(struct smbcli_state *cli, bool unicode, int maxprotocol) { if (unicode) { cli->options.unicode = 1; } else { cli->options.unicode = 0; } cli->transport = smbcli_transport_init(cli->sock, cli, true, &cli->options); cli->sock = NULL; if (!cli->transport) { return NT_STATUS_NO_MEMORY; } return smb_raw_negotiate(cli->transport, unicode, maxprotocol); }