On Thu, 09-Dec-1999 at 15:02:41 -0800, Alfred Perlstein wrote:
> On Thu, 9 Dec 1999, Andre Albsmeier wrote:
> 
> ...
>
> > For better reference, here is the current patch:
> > 
> > *** lpr.c.ORI       Thu Dec  9 15:30:18 1999
> > --- lpr.c   Thu Dec  9 15:30:35 1999
> > ***************
> > *** 370,375 ****
> > --- 370,405 ----
> >             }
> >             if (sflag)
> >                     printf("%s: %s: not linked, copying instead\n", name, arg);
> > +           /*
> > +            * If lpr was invoked with -r we try to move the file to
> > +            * be printed instead of copying and deleting it later.
> > +            * This works if the file and lpd's spool directory are
> > +            * on the same filesystem as it is often the case for files
> > +            * printed by samba or pcnfsd. In this case, a lot of I/O
> > +            * and temporary disk space can be avoided. Otherwise, we
> > +            * will continue normally.
> > +            */
> > +           if (f) {                        /* file should be deleted */
> > +                   seteuid(euid);          /* needed for rename() */
> > +                   if (!rename(arg, dfname)) {
> > +                           int i;
> > + #if 0
> > +                           chown(dfname, userid, getegid());
> > +                           chmod(dfname, S_IRUSR | S_IWUSR |
> > +                               S_IRGRP | S_IWGRP);
> > + #endif
> > +                           seteuid(uid);   /* restore old uid */
> > +                           if (format == 'p')
> > +                                   card('T', title ? title : arg);
> > +                           for (i = 0; i < ncopies; i++)
> > +                                   card(format, &dfname[inchar-2]);
> > +                           card('U', &dfname[inchar-2]);
> > +                           card('N', arg);
> > +                           nact++;
> > +                           continue;
> > +                   }
> > +                   seteuid(uid);           /* restore old uid */
> > +           }
> >             if ((i = open(arg, O_RDONLY)) < 0) {
> >                     printf("%s: cannot open %s\n", name, arg);
> >             } else {
> > 
> > 
> 
> I don't have too much time to think about this, argue me this:

Sure, please tell me if you don't want to get CC'ed on this anymore.

> 
> why should I allow a user to print any file on the system?
> 
> the race condition is still there.

Right :-(. The file won't be given to the user anymore but he can
print everything. However, there must be a solution for this...

> 
> -Alfred
> 

        -Andre


To Unsubscribe: send mail to [EMAIL PROTECTED]
with "unsubscribe freebsd-current" in the body of the message

Reply via email to