2 Unix SMB/Netbios implementation.
3 SMB client library implementation
4 Copyright (C) Andrew Tridgell 1998
5 Copyright (C) Richard Sharpe 2000, 2002
6 Copyright (C) John Terpstra 2000
7 Copyright (C) Tom Jansen (Ninja ISD) 2002
8 Copyright (C) Derrell Lipman 2003-2008
9 Copyright (C) Jeremy Allison 2007, 2008
11 This program is free software; you can redistribute it and/or modify
12 it under the terms of the GNU General Public License as published by
13 the Free Software Foundation; either version 3 of the License, or
14 (at your option) any later version.
16 This program is distributed in the hope that it will be useful,
17 but WITHOUT ANY WARRANTY; without even the implied warranty of
18 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19 GNU General Public License for more details.
21 You should have received a copy of the GNU General Public License
22 along with this program. If not, see <http://www.gnu.org/licenses/>.
26 #include "libsmb/libsmb.h"
27 #include "libsmbclient.h"
28 #include "libsmb_internal.h"
32 * Open a print file to be written to by other calls
36 SMBC_open_print_job_ctx(SMBCCTX
*context
,
42 char *password
= NULL
;
44 TALLOC_CTX
*frame
= talloc_stackframe();
46 if (!context
|| !context
->internal
->initialized
) {
58 DEBUG(4, ("SMBC_open_print_job_ctx(%s)\n", fname
));
60 if (SMBC_parse_path(frame
,
75 /* What if the path is empty, or the file exists? */
78 return smbc_getFunctionOpen(context
)(context
, fname
, O_WRONLY
, 666);
82 * Routine to print a file on a remote server ...
84 * We open the file, which we assume to be on a remote server, and then
85 * copy it to a print file on the share specified by printq.
89 SMBC_print_file_ctx(SMBCCTX
*c_file
,
97 smbc_open_print_job_fn f_open_pj2
;
102 TALLOC_CTX
*frame
= talloc_stackframe();
104 if (!c_file
|| !c_file
->internal
->initialized
||
105 !c_print
|| !c_print
->internal
->initialized
) {
111 if (!fname
&& !printq
) {
117 /* Try to open the file for reading ... */
118 f_open1
= smbc_getFunctionOpen(c_file
);
119 if (f_open1
== NULL
) {
125 fid1
= f_open1(c_file
, fname
, O_RDONLY
, 0666);
127 DEBUG(3, ("Error, fname=%s, errno=%i\n", fname
, errno
));
129 return -1; /* smbc_open sets errno */
132 /* Now, try to open the printer file for writing */
133 f_open_pj2
= smbc_getFunctionOpenPrintJob(c_print
);
134 if (f_open_pj2
== NULL
) {
140 fid2
= f_open_pj2(c_print
, printq
);
142 saverr
= errno
; /* Save errno */
143 smbc_getFunctionClose(c_file
)(c_file
, fid1
);
149 while ((bytes
= smbc_getFunctionRead(c_file
)(c_file
, fid1
,
150 buf
, sizeof(buf
))) > 0) {
153 if ((smbc_getFunctionWrite(c_print
)(c_print
, fid2
,
156 smbc_getFunctionClose(c_file
)(c_file
, fid1
);
157 smbc_getFunctionClose(c_print
)(c_print
, fid2
);
164 smbc_getFunctionClose(c_file
)(c_file
, fid1
);
165 smbc_getFunctionClose(c_print
)(c_print
, fid2
);
178 * Routine to list print jobs on a printer share ...
182 SMBC_list_print_jobs_ctx(SMBCCTX
*context
,
184 smbc_list_print_job_fn fn
)
190 char *password
= NULL
;
191 char *workgroup
= NULL
;
193 TALLOC_CTX
*frame
= talloc_stackframe();
195 if (!context
|| !context
->internal
->initialized
) {
207 DEBUG(4, ("smbc_list_print_jobs(%s)\n", fname
));
209 if (SMBC_parse_path(frame
,
224 if (!user
|| user
[0] == (char)0) {
225 user
= talloc_strdup(frame
, smbc_getUser(context
));
233 srv
= SMBC_server(frame
, context
, True
,
234 server
, share
, &workgroup
, &user
, &password
);
238 return -1; /* errno set by SMBC_server */
241 if (cli_print_queue(srv
->cli
,
242 (void (*)(struct print_job_info
*))fn
) < 0) {
243 errno
= SMBC_errno(context
, srv
->cli
);
253 * Delete a print job from a remote printer share
257 SMBC_unlink_print_job_ctx(SMBCCTX
*context
,
265 char *password
= NULL
;
266 char *workgroup
= NULL
;
269 TALLOC_CTX
*frame
= talloc_stackframe();
271 if (!context
|| !context
->internal
->initialized
) {
283 DEBUG(4, ("smbc_unlink_print_job(%s)\n", fname
));
285 if (SMBC_parse_path(frame
,
300 if (!user
|| user
[0] == (char)0) {
301 user
= talloc_strdup(frame
, smbc_getUser(context
));
309 srv
= SMBC_server(frame
, context
, True
,
310 server
, share
, &workgroup
, &user
, &password
);
314 return -1; /* errno set by SMBC_server */
317 if ((err
= cli_printjob_del(srv
->cli
, id
)) != 0) {
319 errno
= SMBC_errno(context
, srv
->cli
);
320 else if (err
== ERRnosuchprintjob
)