Fix debugs for rap mapping. Delete job on map fail.
[tprouty/samba.git] / source / printing / printfsp.c
1 /* 
2    Unix SMB/CIFS implementation.
3    printing backend routines for smbd - using files_struct rather
4    than only snum
5    Copyright (C) Andrew Tridgell 1992-2000
6    
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 2 of the License, or
10    (at your option) any later version.
11    
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16    
17    You should have received a copy of the GNU General Public License
18    along with this program; if not, write to the Free Software
19    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
20 */
21
22 #include "includes.h"
23
24 /***************************************************************************
25 open a print file and setup a fsp for it. This is a wrapper around
26 print_job_start().
27 ***************************************************************************/
28
29 files_struct *print_fsp_open(connection_struct *conn, char *fname)
30 {
31         int jobid;
32         SMB_STRUCT_STAT sbuf;
33         extern struct current_user current_user;
34         files_struct *fsp = file_new(conn);
35         fstring name;
36
37         if(!fsp)
38                 return NULL;
39
40         fstrcpy( name, "Remote Downlevel Document");
41         if (fname) {
42                 char *p = strrchr(fname, '/');
43                 fstrcat(name, " ");
44                 if (!p)
45                         p = fname;
46                 fstrcat(name, p);
47         }
48
49         jobid = print_job_start(&current_user, SNUM(conn), name, NULL);
50         if (jobid == -1) {
51                 file_free(fsp);
52                 return NULL;
53         }
54
55         /* Convert to RAP id. */
56         fsp->rap_print_jobid = pjobid_to_rap(SNUM(conn), jobid);
57         if (fsp->rap_print_jobid == 0) {
58                 /* We need to delete the entry in the tdb. */
59                 pjob_delete(SNUM(conn), jobid);
60                 file_free(fsp);
61                 return NULL;
62         }
63
64         /* setup a full fsp */
65         fsp->fd = print_job_fd(SNUM(conn),jobid);
66         GetTimeOfDay(&fsp->open_time);
67         fsp->vuid = current_user.vuid;
68         fsp->size = 0;
69         fsp->pos = -1;
70         fsp->can_lock = True;
71         fsp->can_read = False;
72         fsp->can_write = True;
73         fsp->share_mode = 0;
74         fsp->print_file = True;
75         fsp->modified = False;
76         fsp->oplock_type = NO_OPLOCK;
77         fsp->sent_oplock_break = NO_BREAK_SENT;
78         fsp->is_directory = False;
79         fsp->directory_delete_on_close = False;
80         fsp->conn = conn;
81         string_set(&fsp->fsp_name,print_job_fname(SNUM(conn),jobid));
82         fsp->wbmpx_ptr = NULL;      
83         fsp->wcp = NULL; 
84         conn->vfs_ops.fstat(fsp,fsp->fd, &sbuf);
85         fsp->mode = sbuf.st_mode;
86         fsp->inode = sbuf.st_ino;
87         fsp->dev = sbuf.st_dev;
88
89         conn->num_files_open++;
90
91         return fsp;
92 }
93
94 /****************************************************************************
95 print a file - called on closing the file
96 ****************************************************************************/
97 void print_fsp_end(files_struct *fsp, BOOL normal_close)
98 {
99         uint32 jobid;
100         int snum;
101
102         if (fsp->share_mode == FILE_DELETE_ON_CLOSE) {
103                 /*
104                  * Truncate the job. print_job_end will take
105                  * care of deleting it for us. JRA.
106                  */
107                 sys_ftruncate(fsp->fd, 0);
108         }
109
110         if (fsp->fsp_name) {
111                 string_free(&fsp->fsp_name);
112         }
113
114         if (!rap_to_pjobid(fsp->rap_print_jobid, &snum, &jobid)) {
115                 DEBUG(3,("print_fsp_end: Unable to convert RAP jobid %u to print jobid.\n",
116                         (unsigned int)fsp->rap_print_jobid ));
117                 return;
118         }
119
120         print_job_end(SNUM(fsp->conn),jobid, normal_close);
121 }