2 Python wrappers for DCERPC/SMB client routines.
4 Copyright (C) Tim Potter, 2002
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
21 #include "python/py_spoolss.h"
25 PyObject
*spoolss_enumports(PyObject
*self
, PyObject
*args
, PyObject
*kw
)
28 PyObject
*result
= NULL
, *creds
= NULL
;
30 uint32 i
, needed
, num_ports
;
31 static char *kwlist
[] = {"server", "level", "creds", NULL
};
32 TALLOC_CTX
*mem_ctx
= NULL
;
33 struct cli_state
*cli
= NULL
;
34 char *server
, *errstr
;
37 /* Parse parameters */
39 if (!PyArg_ParseTupleAndKeywords(
40 args
, kw
, "s|iO", kwlist
, &server
, &level
, &creds
))
43 if (server
[0] != '\\' || server
[1] != '\\') {
44 PyErr_SetString(PyExc_ValueError
, "UNC name required");
50 if (creds
&& creds
!= Py_None
&& !PyDict_Check(creds
)) {
51 PyErr_SetString(PyExc_TypeError
,
52 "credentials must be dictionary or None");
56 if (!(cli
= open_pipe_creds(server
, creds
, PIPE_SPOOLSS
, &errstr
))) {
57 PyErr_SetString(spoolss_error
, errstr
);
62 if (!(mem_ctx
= talloc_init())) {
64 spoolss_error
, "unable to init talloc context\n");
68 /* Call rpc function */
70 werror
= cli_spoolss_enum_ports(
71 cli
, mem_ctx
, 0, &needed
, level
, &num_ports
, &ctr
);
73 if (W_ERROR_V(werror
) == ERRinsufficientbuffer
)
74 werror
= cli_spoolss_enum_ports(
75 cli
, mem_ctx
, needed
, NULL
, level
,
78 if (!W_ERROR_IS_OK(werror
)) {
79 PyErr_SetObject(spoolss_werror
, py_werror_tuple(werror
));
87 result
= PyDict_New();
89 for (i
= 0; i
< num_ports
; i
++) {
93 rpcstr_pull(name
, ctr
.port
.info_1
[i
].port_name
.buffer
,
94 sizeof(fstring
), -1, STR_TERMINATE
);
96 py_from_PORT_INFO_1(&value
, &ctr
.port
.info_1
[i
]);
99 value
, "level", PyInt_FromLong(1));
101 PyDict_SetItemString(result
, name
, value
);
106 result
= PyDict_New();
108 for(i
= 0; i
< num_ports
; i
++) {
112 rpcstr_pull(name
, ctr
.port
.info_2
[i
].port_name
.buffer
,
113 sizeof(fstring
), -1, STR_TERMINATE
);
115 py_from_PORT_INFO_2(&value
, &ctr
.port
.info_2
[i
]);
117 PyDict_SetItemString(
118 value
, "level", PyInt_FromLong(2));
120 PyDict_SetItemString(result
, name
, value
);
125 PyErr_SetString(spoolss_error
, "unknown info level");
134 talloc_destroy(mem_ctx
);