Optimization. Don't do the retry logic if sitename_fetch() returned NULL, we already...
[Samba.git] / source3 / include / printing.h
blobc511fa2058df69487667353e6456132e69f18efd
1 #ifndef PRINTING_H_
2 #define PRINTING_H_
4 /*
5 Unix SMB/CIFS implementation.
6 printing definitions
7 Copyright (C) Andrew Tridgell 1992-2000
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 3 of the License, or
12 (at your option) any later version.
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License
20 along with this program. If not, see <http://www.gnu.org/licenses/>.
24 This file defines the low-level printing system interfaces used by the
25 SAMBA printing subsystem.
28 /* Extra fields above "LPQ_PRINTING" are used to map extra NT status codes. */
30 enum {
31 LPQ_QUEUED = 0,
32 LPQ_PAUSED,
33 LPQ_SPOOLING,
34 LPQ_PRINTING,
35 LPQ_ERROR,
36 LPQ_DELETING,
37 LPQ_OFFLINE,
38 LPQ_PAPEROUT,
39 LPQ_PRINTED,
40 LPQ_DELETED,
41 LPQ_BLOCKED,
42 LPQ_USER_INTERVENTION,
44 /* smbd is dooing the file spooling before passing control to spoolss */
45 PJOB_SMBD_SPOOLING
48 typedef struct _print_queue_struct {
49 int sysjob; /* normally the UNIX jobid -- see note in
50 printing.c:traverse_fn_delete() */
51 int size;
52 int page_count;
53 int status;
54 int priority;
55 time_t time;
56 fstring fs_user;
57 fstring fs_file;
58 } print_queue_struct;
60 enum {LPSTAT_OK, LPSTAT_STOPPED, LPSTAT_ERROR};
62 typedef struct {
63 fstring message;
64 int qcount;
65 int status;
66 } print_status_struct;
68 /* Information for print jobs */
69 struct printjob {
70 pid_t pid; /* which process launched the job */
71 uint32_t jobid; /* the spoolss print job identifier */
72 int sysjob; /* the system (lp) job number */
73 int fd; /* file descriptor of open file if open */
74 time_t starttime; /* when the job started spooling */
75 int status; /* the status of this job */
76 size_t size; /* the size of the job so far */
77 int page_count; /* then number of pages so far */
78 bool spooled; /* has it been sent to the spooler yet? */
79 bool smbjob; /* set if the job is a SMB job */
80 fstring filename; /* the filename used to spool the file */
81 fstring jobname; /* the job name given to us by the client */
82 fstring user; /* the user who started the job */
83 fstring clientmachine; /* The client machine which started this job */
84 fstring queuename; /* service number of printer for this job */
85 struct spoolss_DeviceMode *devmode;
88 /* Information for print interfaces */
89 struct printif
91 /* value of the 'printing' option for this service */
92 enum printing_types type;
94 int (*queue_get)(const char *printer_name,
95 enum printing_types printing_type,
96 char *lpq_command,
97 print_queue_struct **q,
98 print_status_struct *status);
99 int (*queue_pause)(int snum);
100 int (*queue_resume)(int snum);
101 int (*job_delete)(const char *sharename, const char *lprm_command, struct printjob *pjob);
102 int (*job_pause)(int snum, struct printjob *pjob);
103 int (*job_resume)(int snum, struct printjob *pjob);
104 int (*job_submit)(int snum, struct printjob *pjob,
105 enum printing_types printing_type,
106 char *lpq_command);
109 extern struct printif generic_printif;
111 #ifdef HAVE_CUPS
112 extern struct printif cups_printif;
113 #endif /* HAVE_CUPS */
115 #ifdef HAVE_IPRINT
116 extern struct printif iprint_printif;
117 #endif /* HAVE_IPRINT */
119 /* PRINT_MAX_JOBID is now defined in local.h */
120 #define UNIX_JOB_START PRINT_MAX_JOBID
121 #define NEXT_JOBID(j) ((j+1) % PRINT_MAX_JOBID > 0 ? (j+1) % PRINT_MAX_JOBID : 1)
123 #define MAX_CACHE_VALID_TIME 3600
124 #define CUPS_DEFAULT_CONNECTION_TIMEOUT 30
126 #ifndef PRINT_SPOOL_PREFIX
127 #define PRINT_SPOOL_PREFIX "smbprn."
128 #endif
129 #define PRINT_DATABASE_VERSION 8
131 #ifdef AIX
132 #define DEFAULT_PRINTING PRINT_AIX
133 #define PRINTCAP_NAME "/etc/qconfig"
134 #endif
136 #ifdef HPUX
137 #define DEFAULT_PRINTING PRINT_HPUX
138 #endif
140 #ifdef QNX
141 #define DEFAULT_PRINTING PRINT_QNX
142 #endif
144 #ifndef DEFAULT_PRINTING
145 #ifdef HAVE_CUPS
146 #define DEFAULT_PRINTING PRINT_CUPS
147 #define PRINTCAP_NAME "cups"
148 #elif defined(SYSV)
149 #define DEFAULT_PRINTING PRINT_SYSV
150 #define PRINTCAP_NAME "lpstat"
151 #else
152 #define DEFAULT_PRINTING PRINT_BSD
153 #define PRINTCAP_NAME "/etc/printcap"
154 #endif
155 #endif
157 #ifndef PRINTCAP_NAME
158 #define PRINTCAP_NAME "/etc/printcap"
159 #endif
161 /* There can be this many printing tdb's open, plus any locked ones. */
162 #define MAX_PRINT_DBS_OPEN 1
164 struct TDB_DATA;
165 struct tdb_context;
167 struct tdb_print_db {
168 struct tdb_print_db *next, *prev;
169 struct tdb_context *tdb;
170 int ref_count;
171 fstring printer_name;
175 * Used for print notify
178 #define NOTIFY_PID_LIST_KEY "NOTIFY_PID_LIST"
180 /* The following definitions come from printing/printspoolss.c */
182 NTSTATUS print_spool_open(files_struct *fsp,
183 const char *fname,
184 uint16_t current_vuid);
186 int print_spool_write(files_struct *fsp, const char *data, uint32_t size,
187 SMB_OFF_T offset, uint32_t *written);
189 void print_spool_end(files_struct *fsp, enum file_close_type close_type);
191 void print_spool_terminate(struct connection_struct *conn,
192 struct print_file_data *print_file);
194 /* The following definitions come from printing/printing.c */
196 uint32 sysjob_to_jobid(int unix_jobid);
197 bool print_notify_register_pid(int snum);
198 bool print_notify_deregister_pid(int snum);
199 bool print_job_exists(const char* sharename, uint32 jobid);
200 struct spoolss_DeviceMode *print_job_devmode(TALLOC_CTX *mem_ctx,
201 const char *sharename,
202 uint32 jobid);
203 bool print_job_set_name(struct tevent_context *ev,
204 struct messaging_context *msg_ctx,
205 const char *sharename, uint32 jobid, const char *name);
206 bool print_job_get_name(TALLOC_CTX *mem_ctx, const char *sharename, uint32_t jobid, char **name);
207 WERROR print_job_delete(const struct auth_serversupplied_info *server_info,
208 struct messaging_context *msg_ctx,
209 int snum, uint32_t jobid);
210 WERROR print_job_pause(const struct auth_serversupplied_info *server_info,
211 struct messaging_context *msg_ctx,
212 int snum, uint32 jobid);
213 WERROR print_job_resume(const struct auth_serversupplied_info *server_info,
214 struct messaging_context *msg_ctx,
215 int snum, uint32 jobid);
216 ssize_t print_job_write(struct tevent_context *ev,
217 struct messaging_context *msg_ctx,
218 int snum, uint32 jobid, const char *buf, size_t size);
219 int print_queue_length(struct messaging_context *msg_ctx, int snum,
220 print_status_struct *pstatus);
221 WERROR print_job_start(const struct auth_serversupplied_info *server_info,
222 struct messaging_context *msg_ctx,
223 const char *clientmachine,
224 int snum, const char *docname, const char *filename,
225 struct spoolss_DeviceMode *devmode, uint32_t *_jobid);
226 void print_job_endpage(struct messaging_context *msg_ctx,
227 int snum, uint32 jobid);
228 NTSTATUS print_job_end(struct messaging_context *msg_ctx, int snum,
229 uint32 jobid, enum file_close_type close_type);
230 int print_queue_status(struct messaging_context *msg_ctx, int snum,
231 print_queue_struct **ppqueue,
232 print_status_struct *status);
233 WERROR print_queue_pause(const struct auth_serversupplied_info *server_info,
234 struct messaging_context *msg_ctx, int snum);
235 WERROR print_queue_resume(const struct auth_serversupplied_info *server_info,
236 struct messaging_context *msg_ctx, int snum);
237 WERROR print_queue_purge(const struct auth_serversupplied_info *server_info,
238 struct messaging_context *msg_ctx, int snum);
239 uint16 pjobid_to_rap(const char* sharename, uint32 jobid);
240 bool rap_to_pjobid(uint16 rap_jobid, fstring sharename, uint32 *pjobid);
241 void rap_jobid_delete(const char* sharename, uint32 jobid);
242 bool print_backend_init(struct messaging_context *msg_ctx);
243 void start_background_queue(struct tevent_context *ev,
244 struct messaging_context *msg);
245 void printing_end(void);
247 /* The following definitions come from printing/lpq_parse.c */
249 bool parse_lpq_entry(enum printing_types printing_type,char *line,
250 print_queue_struct *buf,
251 print_status_struct *status,bool first);
253 /* The following definitions come from printing/printing_db.c */
255 struct tdb_print_db *get_print_db_byname(const char *printername);
256 void release_print_db( struct tdb_print_db *pdb);
257 void close_all_print_db(void);
258 struct TDB_DATA get_printer_notify_pid_list(struct tdb_context *tdb, const char *printer_name, bool cleanlist);
260 void print_queue_receive(struct messaging_context *msg,
261 void *private_data,
262 uint32_t msg_type,
263 struct server_id server_id,
264 DATA_BLOB *data);
265 #endif /* PRINTING_H_ */