- 1.4b1.
- No longer need ext, includeifexists, foomatic-recommended, getnameddest, str2101, str2536 patches. - Require poppler-utils at runtime and for build. No longer need pdftops.conf. - Obsolete cupsddk.
This commit is contained in:
parent
92b094fbad
commit
cb06f24a89
@ -1,7 +1,7 @@
|
|||||||
diff -up cups-1.3.7/backend/ipp.c.eggcups cups-1.3.7/backend/ipp.c
|
diff -up cups-1.4b1/backend/ipp.c.eggcups cups-1.4b1/backend/ipp.c
|
||||||
--- cups-1.3.7/backend/ipp.c.eggcups 2008-07-15 13:34:01.000000000 +0100
|
--- cups-1.4b1/backend/ipp.c.eggcups 2008-10-15 19:27:45.000000000 +0100
|
||||||
+++ cups-1.3.7/backend/ipp.c 2008-07-15 13:34:01.000000000 +0100
|
+++ cups-1.4b1/backend/ipp.c 2008-11-11 15:43:30.000000000 +0000
|
||||||
@@ -58,6 +58,70 @@ static char pstmpname[1024] = ""; /* Tem
|
@@ -51,6 +51,70 @@ static char pstmpname[1024] = ""; /* Tem
|
||||||
static char tmpfilename[1024] = ""; /* Temporary spool file name */
|
static char tmpfilename[1024] = ""; /* Temporary spool file name */
|
||||||
static int job_cancelled = 0; /* Job cancelled? */
|
static int job_cancelled = 0; /* Job cancelled? */
|
||||||
|
|
||||||
@ -72,7 +72,7 @@ diff -up cups-1.3.7/backend/ipp.c.eggcups cups-1.3.7/backend/ipp.c
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Local functions...
|
* Local functions...
|
||||||
@@ -1004,6 +1068,15 @@ main(int argc, /* I - Number of comm
|
@@ -1058,6 +1122,15 @@ main(int argc, /* I - Number of comm
|
||||||
job_id);
|
job_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -88,22 +88,22 @@ diff -up cups-1.3.7/backend/ipp.c.eggcups cups-1.3.7/backend/ipp.c
|
|||||||
ippDelete(response);
|
ippDelete(response);
|
||||||
|
|
||||||
if (job_cancelled)
|
if (job_cancelled)
|
||||||
diff -up cups-1.3.7/backend/Makefile.eggcups cups-1.3.7/backend/Makefile
|
diff -up cups-1.4b1/backend/Makefile.eggcups cups-1.4b1/backend/Makefile
|
||||||
--- cups-1.3.7/backend/Makefile.eggcups 2007-08-08 20:27:51.000000000 +0100
|
--- cups-1.4b1/backend/Makefile.eggcups 2008-10-06 22:08:27.000000000 +0100
|
||||||
+++ cups-1.3.7/backend/Makefile 2008-07-15 13:34:01.000000000 +0100
|
+++ cups-1.4b1/backend/Makefile 2008-11-11 15:45:31.000000000 +0000
|
||||||
@@ -131,7 +131,7 @@ ieee1394-linux.o: ieee1394.h
|
@@ -188,7 +188,7 @@ dnssd: dnssd.o ../cups/$(LIBCUPS) libbac
|
||||||
|
|
||||||
ipp: ipp.o ../cups/$(LIBCUPS)
|
ipp: ipp.o ../cups/$(LIBCUPS) libbackend.a
|
||||||
echo Linking $@...
|
echo Linking $@...
|
||||||
- $(CC) $(LDFLAGS) -o ipp ipp.o $(LIBS)
|
- $(CC) $(LDFLAGS) -o ipp ipp.o libbackend.a $(LIBS)
|
||||||
+ $(CC) $(LDFLAGS) -o ipp ipp.o $(LIBS) $(CUPSDLIBS)
|
+ $(CC) $(LDFLAGS) -o ipp ipp.o libbackend.a $(LIBS) $(CUPSDLIBS)
|
||||||
$(RM) http
|
$(RM) http
|
||||||
$(LN) ipp http
|
$(LN) ipp http
|
||||||
|
|
||||||
diff -up cups-1.3.7/scheduler/subscriptions.c.eggcups cups-1.3.7/scheduler/subscriptions.c
|
diff -up cups-1.4b1/scheduler/subscriptions.c.eggcups cups-1.4b1/scheduler/subscriptions.c
|
||||||
--- cups-1.3.7/scheduler/subscriptions.c.eggcups 2008-01-23 22:23:42.000000000 +0000
|
--- cups-1.4b1/scheduler/subscriptions.c.eggcups 2008-08-01 22:11:55.000000000 +0100
|
||||||
+++ cups-1.3.7/scheduler/subscriptions.c 2008-07-15 13:34:01.000000000 +0100
|
+++ cups-1.4b1/scheduler/subscriptions.c 2008-11-11 15:43:30.000000000 +0000
|
||||||
@@ -1295,13 +1295,13 @@ cupsd_send_dbus(cupsd_eventmask_t event,
|
@@ -1302,13 +1302,13 @@ cupsd_send_dbus(cupsd_eventmask_t event,
|
||||||
what = "PrinterAdded";
|
what = "PrinterAdded";
|
||||||
else if (event & CUPSD_EVENT_PRINTER_DELETED)
|
else if (event & CUPSD_EVENT_PRINTER_DELETED)
|
||||||
what = "PrinterRemoved";
|
what = "PrinterRemoved";
|
||||||
@ -119,7 +119,7 @@ diff -up cups-1.3.7/scheduler/subscriptions.c.eggcups cups-1.3.7/scheduler/subsc
|
|||||||
else
|
else
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@@ -1337,7 +1337,7 @@ cupsd_send_dbus(cupsd_eventmask_t event,
|
@@ -1344,7 +1344,7 @@ cupsd_send_dbus(cupsd_eventmask_t event,
|
||||||
dbus_message_append_iter_init(message, &iter);
|
dbus_message_append_iter_init(message, &iter);
|
||||||
if (dest)
|
if (dest)
|
||||||
dbus_message_iter_append_string(&iter, dest->name);
|
dbus_message_iter_append_string(&iter, dest->name);
|
||||||
|
@ -1,50 +0,0 @@
|
|||||||
--- cups-1.1.22/pdftops/gfile.cxx.ext 2003-11-19 18:17:03.000000000 +0000
|
|
||||||
+++ cups-1.1.22/pdftops/gfile.cxx 2004-11-29 17:58:13.250694162 +0000
|
|
||||||
@@ -487,32 +487,14 @@
|
|
||||||
char *s;
|
|
||||||
int fd;
|
|
||||||
|
|
||||||
- if (ext) {
|
|
||||||
-#if HAVE_MKSTEMPS
|
|
||||||
- if ((s = getenv("TMPDIR"))) {
|
|
||||||
- *name = new GString(s);
|
|
||||||
- } else {
|
|
||||||
- *name = new GString("/tmp");
|
|
||||||
- }
|
|
||||||
- (*name)->append("/XXXXXX")->append(ext);
|
|
||||||
- fd = mkstemps((*name)->getCString(), strlen(ext));
|
|
||||||
-#else
|
|
||||||
- if (!(s = tmpnam(NULL))) {
|
|
||||||
- return gFalse;
|
|
||||||
- }
|
|
||||||
+#if HAVE_MKSTEMP
|
|
||||||
+ if ((s = getenv("TMPDIR"))) {
|
|
||||||
*name = new GString(s);
|
|
||||||
- (*name)->append(ext);
|
|
||||||
- fd = open((*name)->getCString(), O_WRONLY | O_CREAT | O_EXCL, 0600);
|
|
||||||
-#endif
|
|
||||||
} else {
|
|
||||||
-#if HAVE_MKSTEMP
|
|
||||||
- if ((s = getenv("TMPDIR"))) {
|
|
||||||
- *name = new GString(s);
|
|
||||||
- } else {
|
|
||||||
- *name = new GString("/tmp");
|
|
||||||
- }
|
|
||||||
- (*name)->append("/XXXXXX");
|
|
||||||
- fd = mkstemp((*name)->getCString());
|
|
||||||
+ *name = new GString("/tmp");
|
|
||||||
+ }
|
|
||||||
+ (*name)->append("/XXXXXX");
|
|
||||||
+ fd = mkstemp((*name)->getCString());
|
|
||||||
#else // HAVE_MKSTEMP
|
|
||||||
if (!(s = tmpnam(NULL))) {
|
|
||||||
return gFalse;
|
|
||||||
@@ -520,7 +502,7 @@
|
|
||||||
*name = new GString(s);
|
|
||||||
fd = open((*name)->getCString(), O_WRONLY | O_CREAT | O_EXCL, 0600);
|
|
||||||
#endif // HAVE_MKSTEMP
|
|
||||||
- }
|
|
||||||
+
|
|
||||||
if (fd < 0 || !(*f = fdopen(fd, mode))) {
|
|
||||||
delete *name;
|
|
||||||
return gFalse;
|
|
@ -1,27 +0,0 @@
|
|||||||
diff -up cups-1.3.2/scheduler/cups-driverd.c.foomatic-recommended cups-1.3.2/scheduler/cups-driverd.c
|
|
||||||
--- cups-1.3.2/scheduler/cups-driverd.c.foomatic-recommended 2007-09-25 10:33:29.000000000 +0100
|
|
||||||
+++ cups-1.3.2/scheduler/cups-driverd.c 2007-09-25 10:34:03.000000000 +0100
|
|
||||||
@@ -180,7 +180,6 @@ add_ppd(const char *name, /* I - PPD na
|
|
||||||
int type) /* I - Driver type */
|
|
||||||
{
|
|
||||||
ppd_info_t *ppd; /* PPD */
|
|
||||||
- char *recommended; /* Foomatic driver string */
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
@@ -238,15 +237,6 @@ add_ppd(const char *name, /* I - PPD na
|
|
||||||
strlcpy(ppd->record.device_id, device_id, sizeof(ppd->record.device_id));
|
|
||||||
|
|
||||||
/*
|
|
||||||
- * Strip confusing (and often wrong) "recommended" suffix added by
|
|
||||||
- * Foomatic drivers...
|
|
||||||
- */
|
|
||||||
-
|
|
||||||
- if ((recommended = strstr(ppd->record.make_and_model,
|
|
||||||
- " (recommended)")) != NULL)
|
|
||||||
- *recommended = '\0';
|
|
||||||
-
|
|
||||||
- /*
|
|
||||||
* Return the new PPD pointer...
|
|
||||||
*/
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
@ -1,20 +0,0 @@
|
|||||||
--- cups-1.2rc3/pdftops/GlobalParams.cxx.includeifexists 2006-04-25 13:19:09.000000000 +0100
|
|
||||||
+++ cups-1.2rc3/pdftops/GlobalParams.cxx 2006-04-25 13:19:12.000000000 +0100
|
|
||||||
@@ -536,6 +536,17 @@
|
|
||||||
error(-1, "Bad 'include' config file command (%s:%d)",
|
|
||||||
fileName->getCString(), line);
|
|
||||||
}
|
|
||||||
+ } else if (!cmd->cmp("includeifexists")) {
|
|
||||||
+ if (tokens->getLength() == 2) {
|
|
||||||
+ incFile = (GString *)tokens->get(1);
|
|
||||||
+ if ((f2 = fopen(incFile->getCString(), "r"))) {
|
|
||||||
+ parseFile(incFile, f2);
|
|
||||||
+ fclose(f2);
|
|
||||||
+ }
|
|
||||||
+ } else {
|
|
||||||
+ error(-1, "Bad 'includeifexists' config file command (%s:%d)",
|
|
||||||
+ fileName->getCString(), line);
|
|
||||||
+ }
|
|
||||||
} else if (!cmd->cmp("nameToUnicode")) {
|
|
||||||
parseNameToUnicode(tokens, fileName, line);
|
|
||||||
} else if (!cmd->cmp("cidToUnicode")) {
|
|
@ -1,8 +1,9 @@
|
|||||||
--- cups-1.2.4/berkeley/lpr.c.lpr-help 2006-09-27 14:44:34.000000000 +0100
|
diff -up cups-1.4b1/berkeley/lpr.c.lpr-help cups-1.4b1/berkeley/lpr.c
|
||||||
+++ cups-1.2.4/berkeley/lpr.c 2006-09-27 14:59:16.000000000 +0100
|
--- cups-1.4b1/berkeley/lpr.c.lpr-help 2008-07-11 23:46:21.000000000 +0100
|
||||||
@@ -58,6 +58,30 @@
|
+++ cups-1.4b1/berkeley/lpr.c 2008-11-11 16:20:32.000000000 +0000
|
||||||
|
@@ -30,6 +30,31 @@
|
||||||
|
#include <cups/i18n.h>
|
||||||
|
|
||||||
char tempfile[1024]; /* Temporary file for printing from stdin */
|
|
||||||
|
|
||||||
+static void
|
+static void
|
||||||
+usage (const char *name)
|
+usage (const char *name)
|
||||||
@ -28,10 +29,19 @@
|
|||||||
+, name);
|
+, name);
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
|
+
|
||||||
/*
|
/*
|
||||||
* 'main()' - Parse options and send files for printing.
|
* 'main()' - Parse options and send files for printing.
|
||||||
@@ -324,6 +348,12 @@
|
*/
|
||||||
|
@@ -54,7 +79,6 @@ main(int argc, /* I - Number of comm
|
||||||
|
int deletefile; /* Delete file after print? */
|
||||||
|
char buffer[8192]; /* Copy buffer */
|
||||||
|
|
||||||
|
-
|
||||||
|
_cupsSetLocale(argv);
|
||||||
|
|
||||||
|
deletefile = 0;
|
||||||
|
@@ -282,6 +306,12 @@ main(int argc, /* I - Number of comm
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default :
|
default :
|
||||||
|
382
cups-lspp.patch
382
cups-lspp.patch
@ -1,8 +1,8 @@
|
|||||||
diff -up cups-1.3.8/config.h.in.lspp cups-1.3.8/config.h.in
|
diff -up cups-1.4b1/config.h.in.lspp cups-1.4b1/config.h.in
|
||||||
--- cups-1.3.8/config.h.in.lspp 2008-09-10 16:18:26.000000000 +0100
|
--- cups-1.4b1/config.h.in.lspp 2008-09-08 23:03:01.000000000 +0100
|
||||||
+++ cups-1.3.8/config.h.in 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/config.h.in 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -544,6 +544,13 @@
|
@@ -619,6 +619,13 @@
|
||||||
#undef HAVE_REMOVEFILE
|
#undef HAVE_TCPD_H
|
||||||
|
|
||||||
|
|
||||||
+/*
|
+/*
|
||||||
@ -15,9 +15,9 @@ diff -up cups-1.3.8/config.h.in.lspp cups-1.3.8/config.h.in
|
|||||||
#endif /* !_CUPS_CONFIG_H_ */
|
#endif /* !_CUPS_CONFIG_H_ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
diff -up /dev/null cups-1.3.8/config-scripts/cups-lspp.m4
|
diff -up /dev/null cups-1.4b1/config-scripts/cups-lspp.m4
|
||||||
--- /dev/null 2008-09-10 08:56:32.430063181 +0100
|
--- /dev/null 2008-11-11 08:58:48.466006417 +0000
|
||||||
+++ cups-1.3.8/config-scripts/cups-lspp.m4 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/config-scripts/cups-lspp.m4 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -0,0 +1,36 @@
|
@@ -0,0 +1,36 @@
|
||||||
+dnl
|
+dnl
|
||||||
+dnl LSPP code for the Common UNIX Printing System (CUPS).
|
+dnl LSPP code for the Common UNIX Printing System (CUPS).
|
||||||
@ -55,9 +55,9 @@ diff -up /dev/null cups-1.3.8/config-scripts/cups-lspp.m4
|
|||||||
+ ;;
|
+ ;;
|
||||||
+ esac
|
+ esac
|
||||||
+fi
|
+fi
|
||||||
diff -up cups-1.3.8/configure.in.lspp cups-1.3.8/configure.in
|
diff -up cups-1.4b1/configure.in.lspp cups-1.4b1/configure.in
|
||||||
--- cups-1.3.8/configure.in.lspp 2007-07-25 00:47:12.000000000 +0100
|
--- cups-1.4b1/configure.in.lspp 2008-08-04 21:55:13.000000000 +0100
|
||||||
+++ cups-1.3.8/configure.in 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/configure.in 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -42,6 +42,8 @@ sinclude(config-scripts/cups-pap.m4)
|
@@ -42,6 +42,8 @@ sinclude(config-scripts/cups-pap.m4)
|
||||||
sinclude(config-scripts/cups-pdf.m4)
|
sinclude(config-scripts/cups-pdf.m4)
|
||||||
sinclude(config-scripts/cups-scripting.m4)
|
sinclude(config-scripts/cups-scripting.m4)
|
||||||
@ -67,10 +67,10 @@ diff -up cups-1.3.8/configure.in.lspp cups-1.3.8/configure.in
|
|||||||
INSTALL_LANGUAGES=""
|
INSTALL_LANGUAGES=""
|
||||||
UNINSTALL_LANGUAGES=""
|
UNINSTALL_LANGUAGES=""
|
||||||
LANGFILES=""
|
LANGFILES=""
|
||||||
diff -up cups-1.3.8/configure.lspp cups-1.3.8/configure
|
diff -up cups-1.4b1/configure.lspp cups-1.4b1/configure
|
||||||
--- cups-1.3.8/configure.lspp 2008-09-10 16:18:26.000000000 +0100
|
--- cups-1.4b1/configure.lspp 2008-11-11 16:53:28.000000000 +0000
|
||||||
+++ cups-1.3.8/configure 2008-09-10 16:18:43.000000000 +0100
|
+++ cups-1.4b1/configure 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -807,6 +807,8 @@ PHP
|
@@ -827,6 +827,8 @@ PHP
|
||||||
PHPCONFIG
|
PHPCONFIG
|
||||||
PHPDIR
|
PHPDIR
|
||||||
PYTHON
|
PYTHON
|
||||||
@ -79,15 +79,66 @@ diff -up cups-1.3.8/configure.lspp cups-1.3.8/configure
|
|||||||
INSTALL_LANGUAGES
|
INSTALL_LANGUAGES
|
||||||
UNINSTALL_LANGUAGES
|
UNINSTALL_LANGUAGES
|
||||||
LIBOBJS
|
LIBOBJS
|
||||||
@@ -1430,6 +1432,7 @@ Optional Features:
|
@@ -1455,6 +1457,7 @@ Optional Features:
|
||||||
enable UseNetworkDefault by default, default=auto
|
|
||||||
--enable-raw-printing enable raw printing by default, default=auto
|
--enable-raw-printing enable raw printing by default, default=auto
|
||||||
|
--enable-pap build with AppleTalk support, default=auto
|
||||||
--enable-pdftops build pdftops filter, default=auto
|
--enable-pdftops build pdftops filter, default=auto
|
||||||
+ --enable-lspp turn on auditing and label support, default=no
|
+ --enable-lspp turn on auditing and label support, default=no
|
||||||
|
|
||||||
Optional Packages:
|
Optional Packages:
|
||||||
--with-PACKAGE[=ARG] use PACKAGE [ARG=yes]
|
--with-PACKAGE[=ARG] use PACKAGE [ARG=yes]
|
||||||
@@ -18555,6 +18558,412 @@ fi
|
@@ -4647,7 +4650,7 @@ if (eval "$ac_cpp conftest.$ac_ext") 2>&
|
||||||
|
else
|
||||||
|
ac_cv_header_stdc=no
|
||||||
|
fi
|
||||||
|
-rm -f -r conftest*
|
||||||
|
+rm -f conftest*
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
@@ -4668,7 +4671,7 @@ if (eval "$ac_cpp conftest.$ac_ext") 2>&
|
||||||
|
else
|
||||||
|
ac_cv_header_stdc=no
|
||||||
|
fi
|
||||||
|
-rm -f -r conftest*
|
||||||
|
+rm -f conftest*
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
@@ -10323,10 +10326,10 @@ case "$uname" in
|
||||||
|
;;
|
||||||
|
Linux* | GNU*)
|
||||||
|
# Linux and GNU Hurd
|
||||||
|
- MAN1EXT=1.gz
|
||||||
|
- MAN5EXT=5.gz
|
||||||
|
- MAN7EXT=7.gz
|
||||||
|
- MAN8EXT=8.gz
|
||||||
|
+ MAN1EXT=1
|
||||||
|
+ MAN5EXT=5
|
||||||
|
+ MAN7EXT=7
|
||||||
|
+ MAN8EXT=8
|
||||||
|
MAN8DIR=8
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
@@ -18305,7 +18308,7 @@ cat >>confdefs.h <<_ACEOF
|
||||||
|
_ACEOF
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
-rm -f -r conftest*
|
||||||
|
+rm -f conftest*
|
||||||
|
if test $ac_cv_sys_file_offset_bits = unknown; then
|
||||||
|
{ echo "$as_me:$LINENO: checking for _LARGE_FILES value needed for large files" >&5
|
||||||
|
echo $ECHO_N "checking for _LARGE_FILES value needed for large files... $ECHO_C" >&6; }
|
||||||
|
@@ -18426,7 +18429,7 @@ cat >>confdefs.h <<_ACEOF
|
||||||
|
_ACEOF
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
-rm -f -r conftest*
|
||||||
|
+rm -f conftest*
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
@@ -20327,6 +20330,412 @@ fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -500,34 +551,26 @@ diff -up cups-1.3.8/configure.lspp cups-1.3.8/configure
|
|||||||
INSTALL_LANGUAGES=""
|
INSTALL_LANGUAGES=""
|
||||||
UNINSTALL_LANGUAGES=""
|
UNINSTALL_LANGUAGES=""
|
||||||
LANGFILES=""
|
LANGFILES=""
|
||||||
@@ -19449,7 +19858,7 @@ PHP!$PHP$ac_delim
|
@@ -21284,13 +21693,15 @@ PHP!$PHP$ac_delim
|
||||||
PHPCONFIG!$PHPCONFIG$ac_delim
|
PHPCONFIG!$PHPCONFIG$ac_delim
|
||||||
PHPDIR!$PHPDIR$ac_delim
|
PHPDIR!$PHPDIR$ac_delim
|
||||||
PYTHON!$PYTHON$ac_delim
|
PYTHON!$PYTHON$ac_delim
|
||||||
-INSTALL_LANGUAGES!$INSTALL_LANGUAGES$ac_delim
|
|
||||||
+LIBAUDIT!$LIBAUDIT$ac_delim
|
+LIBAUDIT!$LIBAUDIT$ac_delim
|
||||||
_ACEOF
|
|
||||||
|
|
||||||
if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 97; then
|
|
||||||
@@ -19491,12 +19900,14 @@ _ACEOF
|
|
||||||
ac_delim='%!_!# '
|
|
||||||
for ac_last_try in false false false false false :; do
|
|
||||||
cat >conf$$subs.sed <<_ACEOF
|
|
||||||
+LIBSELINUX!$LIBSELINUX$ac_delim
|
+LIBSELINUX!$LIBSELINUX$ac_delim
|
||||||
+INSTALL_LANGUAGES!$INSTALL_LANGUAGES$ac_delim
|
INSTALL_LANGUAGES!$INSTALL_LANGUAGES$ac_delim
|
||||||
UNINSTALL_LANGUAGES!$UNINSTALL_LANGUAGES$ac_delim
|
UNINSTALL_LANGUAGES!$UNINSTALL_LANGUAGES$ac_delim
|
||||||
LIBOBJS!$LIBOBJS$ac_delim
|
LIBOBJS!$LIBOBJS$ac_delim
|
||||||
LTLIBOBJS!$LTLIBOBJS$ac_delim
|
LTLIBOBJS!$LTLIBOBJS$ac_delim
|
||||||
_ACEOF
|
_ACEOF
|
||||||
|
|
||||||
- if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 3; then
|
- if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 23; then
|
||||||
+ if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 5; then
|
+ if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 25; then
|
||||||
break
|
break
|
||||||
elif $ac_last_try; then
|
elif $ac_last_try; then
|
||||||
{ { echo "$as_me:$LINENO: error: could not make $CONFIG_STATUS" >&5
|
{ { echo "$as_me:$LINENO: error: could not make $CONFIG_STATUS" >&5
|
||||||
diff -up cups-1.3.8/cups/cups.h.lspp cups-1.3.8/cups/cups.h
|
diff -up cups-1.4b1/cups/cups.h.lspp cups-1.4b1/cups/cups.h
|
||||||
--- cups-1.3.8/cups/cups.h.lspp 2008-09-10 16:18:26.000000000 +0100
|
--- cups-1.4b1/cups/cups.h.lspp 2008-09-25 00:08:34.000000000 +0100
|
||||||
+++ cups-1.3.8/cups/cups.h 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/cups/cups.h 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -15,6 +15,9 @@
|
@@ -15,6 +15,9 @@
|
||||||
* This file is subject to the Apple OS-Developed Software exception.
|
* This file is subject to the Apple OS-Developed Software exception.
|
||||||
*/
|
*/
|
||||||
@ -538,8 +581,8 @@ diff -up cups-1.3.8/cups/cups.h.lspp cups-1.3.8/cups/cups.h
|
|||||||
#ifndef _CUPS_CUPS_H_
|
#ifndef _CUPS_CUPS_H_
|
||||||
# define _CUPS_CUPS_H_
|
# define _CUPS_CUPS_H_
|
||||||
|
|
||||||
@@ -66,6 +69,12 @@ extern "C" {
|
@@ -83,6 +86,12 @@ extern "C" {
|
||||||
# define CUPS_DATE_ANY -1
|
# define CUPS_WHICHJOBS_COMPLETED 1
|
||||||
|
|
||||||
|
|
||||||
+# ifdef WITH_LSPP
|
+# ifdef WITH_LSPP
|
||||||
@ -551,9 +594,9 @@ diff -up cups-1.3.8/cups/cups.h.lspp cups-1.3.8/cups/cups.h
|
|||||||
/*
|
/*
|
||||||
* Types and structures...
|
* Types and structures...
|
||||||
*/
|
*/
|
||||||
diff -up cups-1.3.8/data/Makefile.lspp cups-1.3.8/data/Makefile
|
diff -up cups-1.4b1/data/Makefile.lspp cups-1.4b1/data/Makefile
|
||||||
--- cups-1.3.8/data/Makefile.lspp 2007-10-10 23:00:43.000000000 +0100
|
--- cups-1.4b1/data/Makefile.lspp 2008-10-15 19:21:56.000000000 +0100
|
||||||
+++ cups-1.3.8/data/Makefile 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/data/Makefile 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -25,7 +25,10 @@ BANNERS = \
|
@@ -25,7 +25,10 @@ BANNERS = \
|
||||||
secret \
|
secret \
|
||||||
standard \
|
standard \
|
||||||
@ -566,9 +609,9 @@ diff -up cups-1.3.8/data/Makefile.lspp cups-1.3.8/data/Makefile
|
|||||||
|
|
||||||
CHARMAPS = \
|
CHARMAPS = \
|
||||||
euc-cn.txt \
|
euc-cn.txt \
|
||||||
diff -up /dev/null cups-1.3.8/data/mls
|
diff -up /dev/null cups-1.4b1/data/mls
|
||||||
--- /dev/null 2008-09-10 08:56:32.430063181 +0100
|
--- /dev/null 2008-11-11 08:58:48.466006417 +0000
|
||||||
+++ cups-1.3.8/data/mls 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/data/mls 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -0,0 +1,261 @@
|
@@ -0,0 +1,261 @@
|
||||||
+%!PS-Adobe-3.0
|
+%!PS-Adobe-3.0
|
||||||
+%%BoundingBox: 0 0 612 792
|
+%%BoundingBox: 0 0 612 792
|
||||||
@ -831,9 +874,9 @@ diff -up /dev/null cups-1.3.8/data/mls
|
|||||||
+% End of "$Id: mls_template,v 1.1 2005/06/27 18:44:46 colmo Exp $".
|
+% End of "$Id: mls_template,v 1.1 2005/06/27 18:44:46 colmo Exp $".
|
||||||
+%
|
+%
|
||||||
+%%EOF
|
+%%EOF
|
||||||
diff -up /dev/null cups-1.3.8/data/selinux
|
diff -up /dev/null cups-1.4b1/data/selinux
|
||||||
--- /dev/null 2008-09-10 08:56:32.430063181 +0100
|
--- /dev/null 2008-11-11 08:58:48.466006417 +0000
|
||||||
+++ cups-1.3.8/data/selinux 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/data/selinux 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -0,0 +1,261 @@
|
@@ -0,0 +1,261 @@
|
||||||
+%!PS-Adobe-3.0
|
+%!PS-Adobe-3.0
|
||||||
+%%BoundingBox: 0 0 612 792
|
+%%BoundingBox: 0 0 612 792
|
||||||
@ -1096,9 +1139,9 @@ diff -up /dev/null cups-1.3.8/data/selinux
|
|||||||
+% End of "$Id: mls_template,v 1.1 2005/06/27 18:44:46 colmo Exp $".
|
+% End of "$Id: mls_template,v 1.1 2005/06/27 18:44:46 colmo Exp $".
|
||||||
+%
|
+%
|
||||||
+%%EOF
|
+%%EOF
|
||||||
diff -up /dev/null cups-1.3.8/data/te
|
diff -up /dev/null cups-1.4b1/data/te
|
||||||
--- /dev/null 2008-09-10 08:56:32.430063181 +0100
|
--- /dev/null 2008-11-11 08:58:48.466006417 +0000
|
||||||
+++ cups-1.3.8/data/te 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/data/te 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -0,0 +1,261 @@
|
@@ -0,0 +1,261 @@
|
||||||
+%!PS-Adobe-3.0
|
+%!PS-Adobe-3.0
|
||||||
+%%BoundingBox: 0 0 612 792
|
+%%BoundingBox: 0 0 612 792
|
||||||
@ -1361,9 +1404,9 @@ diff -up /dev/null cups-1.3.8/data/te
|
|||||||
+% End of "$Id: mls_template,v 1.1 2005/06/27 18:44:46 colmo Exp $".
|
+% End of "$Id: mls_template,v 1.1 2005/06/27 18:44:46 colmo Exp $".
|
||||||
+%
|
+%
|
||||||
+%%EOF
|
+%%EOF
|
||||||
diff -up cups-1.3.8/filter/common.c.lspp cups-1.3.8/filter/common.c
|
diff -up cups-1.4b1/filter/common.c.lspp cups-1.4b1/filter/common.c
|
||||||
--- cups-1.3.8/filter/common.c.lspp 2008-07-11 23:48:49.000000000 +0100
|
--- cups-1.4b1/filter/common.c.lspp 2007-07-11 22:46:42.000000000 +0100
|
||||||
+++ cups-1.3.8/filter/common.c 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/filter/common.c 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -30,6 +30,12 @@
|
@@ -30,6 +30,12 @@
|
||||||
* Include necessary headers...
|
* Include necessary headers...
|
||||||
*/
|
*/
|
||||||
@ -1532,8 +1575,9 @@ diff -up cups-1.3.8/filter/common.c.lspp cups-1.3.8/filter/common.c
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
--- cups-1.3.9/filter/pstops.c.lspp 2008-10-30 13:29:33.000000000 +0000
|
diff -up cups-1.4b1/filter/pstops.c.lspp cups-1.4b1/filter/pstops.c
|
||||||
+++ cups-1.3.9/filter/pstops.c 2008-10-30 13:31:06.000000000 +0000
|
--- cups-1.4b1/filter/pstops.c.lspp 2008-09-24 00:44:33.000000000 +0100
|
||||||
|
+++ cups-1.4b1/filter/pstops.c 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -3233,6 +3233,18 @@ write_label_prolog(pstops_doc_t *doc, /*
|
@@ -3233,6 +3233,18 @@ write_label_prolog(pstops_doc_t *doc, /*
|
||||||
{
|
{
|
||||||
const char *classification; /* CLASSIFICATION environment variable */
|
const char *classification; /* CLASSIFICATION environment variable */
|
||||||
@ -1689,10 +1733,10 @@ diff -up cups-1.3.8/filter/common.c.lspp cups-1.3.8/filter/common.c
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
diff -up cups-1.3.8/Makedefs.in.lspp cups-1.3.8/Makedefs.in
|
diff -up cups-1.4b1/Makedefs.in.lspp cups-1.4b1/Makedefs.in
|
||||||
--- cups-1.3.8/Makedefs.in.lspp 2008-01-22 22:37:21.000000000 +0000
|
--- cups-1.4b1/Makedefs.in.lspp 2008-11-11 16:53:28.000000000 +0000
|
||||||
+++ cups-1.3.8/Makedefs.in 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/Makedefs.in 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -134,7 +134,7 @@ LIBCUPSORDER = @LIBCUPSORDER@
|
@@ -145,7 +145,7 @@ LIBCUPSORDER = @LIBCUPSORDER@
|
||||||
LIBCUPSIMAGEORDER = @LIBCUPSIMAGEORDER@
|
LIBCUPSIMAGEORDER = @LIBCUPSIMAGEORDER@
|
||||||
LINKCUPS = @LINKCUPS@ $(SSLLIBS)
|
LINKCUPS = @LINKCUPS@ $(SSLLIBS)
|
||||||
LINKCUPSIMAGE = @LINKCUPSIMAGE@
|
LINKCUPSIMAGE = @LINKCUPSIMAGE@
|
||||||
@ -1701,10 +1745,19 @@ diff -up cups-1.3.8/Makedefs.in.lspp cups-1.3.8/Makedefs.in
|
|||||||
OPTIM = @OPTIM@
|
OPTIM = @OPTIM@
|
||||||
OPTIONS =
|
OPTIONS =
|
||||||
PAMLIBS = @PAMLIBS@
|
PAMLIBS = @PAMLIBS@
|
||||||
diff -up cups-1.3.8/scheduler/client.c.lspp cups-1.3.8/scheduler/client.c
|
@@ -256,7 +256,7 @@ DBUSDIR = @DBUSDIR@
|
||||||
--- cups-1.3.8/scheduler/client.c.lspp 2008-09-10 16:18:26.000000000 +0100
|
# Rules...
|
||||||
+++ cups-1.3.8/scheduler/client.c 2008-09-10 16:18:26.000000000 +0100
|
#
|
||||||
@@ -40,12 +40,14 @@
|
|
||||||
|
-.SILENT:
|
||||||
|
+
|
||||||
|
.SUFFIXES: .1 .1.gz .1m .1m.gz .3 .3.gz .5 .5.gz .7 .7.gz .8 .8.gz .a .c .cxx .h .man .o .32.o .64.o .gz
|
||||||
|
|
||||||
|
.c.o:
|
||||||
|
diff -up cups-1.4b1/scheduler/client.c.lspp cups-1.4b1/scheduler/client.c
|
||||||
|
--- cups-1.4b1/scheduler/client.c.lspp 2008-10-27 22:47:12.000000000 +0000
|
||||||
|
+++ cups-1.4b1/scheduler/client.c 2008-11-11 16:53:28.000000000 +0000
|
||||||
|
@@ -41,6 +41,7 @@
|
||||||
* pipe_command() - Pipe the output of a command to the remote client.
|
* pipe_command() - Pipe the output of a command to the remote client.
|
||||||
* write_file() - Send a file via HTTP.
|
* write_file() - Send a file via HTTP.
|
||||||
* write_pipe() - Flag that data is available on the CGI pipe.
|
* write_pipe() - Flag that data is available on the CGI pipe.
|
||||||
@ -1712,16 +1765,17 @@ diff -up cups-1.3.8/scheduler/client.c.lspp cups-1.3.8/scheduler/client.c
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Include necessary headers...
|
@@ -49,6 +50,7 @@
|
||||||
*/
|
|
||||||
|
|
||||||
+#define _GNU_SOURCE
|
|
||||||
#include <cups/http-private.h>
|
|
||||||
#include "cupsd.h"
|
#include "cupsd.h"
|
||||||
|
|
||||||
@@ -77,6 +79,12 @@ extern const char *cssmErrorString(int e
|
+#define _GNU_SOURCE
|
||||||
# include <gnutls/x509.h>
|
#ifdef HAVE_CDSASSL
|
||||||
#endif /* HAVE_GNUTLS */
|
# include <Security/Security.h>
|
||||||
|
# ifdef HAVE_SECIDENTITYSEARCHPRIV_H
|
||||||
|
@@ -81,6 +83,12 @@ extern const char *cssmErrorString(int e
|
||||||
|
# include <tcpd.h>
|
||||||
|
#endif /* HAVE_TCPD_H */
|
||||||
|
|
||||||
+#ifdef WITH_LSPP
|
+#ifdef WITH_LSPP
|
||||||
+#include <selinux/selinux.h>
|
+#include <selinux/selinux.h>
|
||||||
@ -1732,9 +1786,9 @@ diff -up cups-1.3.8/scheduler/client.c.lspp cups-1.3.8/scheduler/client.c
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Local functions...
|
* Local functions...
|
||||||
@@ -351,6 +359,57 @@ cupsdAcceptClient(cupsd_listener_t *lis)
|
@@ -402,6 +410,57 @@ cupsdAcceptClient(cupsd_listener_t *lis)
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
#endif /* HAVE_TCPD_H */
|
||||||
|
|
||||||
+#ifdef WITH_LSPP
|
+#ifdef WITH_LSPP
|
||||||
+ if (is_lspp_config())
|
+ if (is_lspp_config())
|
||||||
@ -1790,7 +1844,7 @@ diff -up cups-1.3.8/scheduler/client.c.lspp cups-1.3.8/scheduler/client.c
|
|||||||
#ifdef AF_INET6
|
#ifdef AF_INET6
|
||||||
if (con->http.hostaddr->addr.sa_family == AF_INET6)
|
if (con->http.hostaddr->addr.sa_family == AF_INET6)
|
||||||
cupsdLogMessage(CUPSD_LOG_DEBUG, "cupsdAcceptClient: %d from %s:%d (IPv6)",
|
cupsdLogMessage(CUPSD_LOG_DEBUG, "cupsdAcceptClient: %d from %s:%d (IPv6)",
|
||||||
@@ -733,6 +792,13 @@ cupsdReadClient(cupsd_client_t *con) /*
|
@@ -801,6 +860,13 @@ cupsdReadClient(cupsd_client_t *con) /*
|
||||||
mime_type_t *type; /* MIME type of file */
|
mime_type_t *type; /* MIME type of file */
|
||||||
cupsd_printer_t *p; /* Printer */
|
cupsd_printer_t *p; /* Printer */
|
||||||
static unsigned request_id = 0; /* Request ID for temp files */
|
static unsigned request_id = 0; /* Request ID for temp files */
|
||||||
@ -1804,7 +1858,7 @@ diff -up cups-1.3.8/scheduler/client.c.lspp cups-1.3.8/scheduler/client.c
|
|||||||
|
|
||||||
|
|
||||||
status = HTTP_CONTINUE;
|
status = HTTP_CONTINUE;
|
||||||
@@ -2017,6 +2083,67 @@ cupsdReadClient(cupsd_client_t *con) /*
|
@@ -2091,6 +2157,67 @@ cupsdReadClient(cupsd_client_t *con) /*
|
||||||
fchmod(con->file, 0640);
|
fchmod(con->file, 0640);
|
||||||
fchown(con->file, RunUser, Group);
|
fchown(con->file, RunUser, Group);
|
||||||
fcntl(con->file, F_SETFD, fcntl(con->file, F_GETFD) | FD_CLOEXEC);
|
fcntl(con->file, F_SETFD, fcntl(con->file, F_GETFD) | FD_CLOEXEC);
|
||||||
@ -1872,7 +1926,7 @@ diff -up cups-1.3.8/scheduler/client.c.lspp cups-1.3.8/scheduler/client.c
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (con->http.state != HTTP_POST_SEND)
|
if (con->http.state != HTTP_POST_SEND)
|
||||||
@@ -4288,6 +4415,50 @@ make_certificate(cupsd_client_t *con) /*
|
@@ -4402,6 +4529,50 @@ make_certificate(cupsd_client_t *con) /*
|
||||||
#endif /* HAVE_SSL */
|
#endif /* HAVE_SSL */
|
||||||
|
|
||||||
|
|
||||||
@ -1923,13 +1977,13 @@ diff -up cups-1.3.8/scheduler/client.c.lspp cups-1.3.8/scheduler/client.c
|
|||||||
/*
|
/*
|
||||||
* 'pipe_command()' - Pipe the output of a command to the remote client.
|
* 'pipe_command()' - Pipe the output of a command to the remote client.
|
||||||
*/
|
*/
|
||||||
diff -up cups-1.3.8/scheduler/client.h.lspp cups-1.3.8/scheduler/client.h
|
diff -up cups-1.4b1/scheduler/client.h.lspp cups-1.4b1/scheduler/client.h
|
||||||
--- cups-1.3.8/scheduler/client.h.lspp 2007-10-22 19:52:13.000000000 +0100
|
--- cups-1.4b1/scheduler/client.h.lspp 2008-09-11 02:54:11.000000000 +0100
|
||||||
+++ cups-1.3.8/scheduler/client.h 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/scheduler/client.h 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -17,6 +17,13 @@
|
@@ -18,6 +18,13 @@
|
||||||
# include <Security/Authorization.h>
|
|
||||||
#endif /* HAVE_AUTHORIZATION_H */
|
#endif /* HAVE_AUTHORIZATION_H */
|
||||||
|
|
||||||
|
|
||||||
+/* Copyright (C) 2005 Trusted Computer Solutions, Inc. */
|
+/* Copyright (C) 2005 Trusted Computer Solutions, Inc. */
|
||||||
+/* (c) Copyright 2005-2006 Hewlett-Packard Development Company, L.P. */
|
+/* (c) Copyright 2005-2006 Hewlett-Packard Development Company, L.P. */
|
||||||
+
|
+
|
||||||
@ -1940,7 +1994,7 @@ diff -up cups-1.3.8/scheduler/client.h.lspp cups-1.3.8/scheduler/client.h
|
|||||||
/*
|
/*
|
||||||
* HTTP client structure...
|
* HTTP client structure...
|
||||||
*/
|
*/
|
||||||
@@ -62,6 +69,10 @@ struct cupsd_client_s
|
@@ -63,6 +70,10 @@ struct cupsd_client_s
|
||||||
#ifdef HAVE_AUTHORIZATION_H
|
#ifdef HAVE_AUTHORIZATION_H
|
||||||
AuthorizationRef authref; /* Authorization ref */
|
AuthorizationRef authref; /* Authorization ref */
|
||||||
#endif /* HAVE_AUTHORIZATION_H */
|
#endif /* HAVE_AUTHORIZATION_H */
|
||||||
@ -1951,7 +2005,7 @@ diff -up cups-1.3.8/scheduler/client.h.lspp cups-1.3.8/scheduler/client.h
|
|||||||
};
|
};
|
||||||
|
|
||||||
#define HTTP(con) &((con)->http)
|
#define HTTP(con) &((con)->http)
|
||||||
@@ -129,6 +140,9 @@ extern void cupsdStartListening(void);
|
@@ -132,6 +143,9 @@ extern void cupsdStartListening(void);
|
||||||
extern void cupsdStopListening(void);
|
extern void cupsdStopListening(void);
|
||||||
extern void cupsdUpdateCGI(void);
|
extern void cupsdUpdateCGI(void);
|
||||||
extern void cupsdWriteClient(cupsd_client_t *con);
|
extern void cupsdWriteClient(cupsd_client_t *con);
|
||||||
@ -1961,9 +2015,9 @@ diff -up cups-1.3.8/scheduler/client.h.lspp cups-1.3.8/scheduler/client.h
|
|||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
diff -up cups-1.3.8/scheduler/conf.c.lspp cups-1.3.8/scheduler/conf.c
|
diff -up cups-1.4b1/scheduler/conf.c.lspp cups-1.4b1/scheduler/conf.c
|
||||||
--- cups-1.3.8/scheduler/conf.c.lspp 2008-09-10 16:18:26.000000000 +0100
|
--- cups-1.4b1/scheduler/conf.c.lspp 2008-11-11 16:53:28.000000000 +0000
|
||||||
+++ cups-1.3.8/scheduler/conf.c 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/scheduler/conf.c 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -27,6 +27,7 @@
|
@@ -27,6 +27,7 @@
|
||||||
* read_configuration() - Read a configuration file.
|
* read_configuration() - Read a configuration file.
|
||||||
* read_location() - Read a <Location path> definition.
|
* read_location() - Read a <Location path> definition.
|
||||||
@ -1982,7 +2036,7 @@ diff -up cups-1.3.8/scheduler/conf.c.lspp cups-1.3.8/scheduler/conf.c
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Configuration variable structure...
|
* Configuration variable structure...
|
||||||
@@ -161,6 +165,10 @@ static const cupsd_var_t variables[] =
|
@@ -168,6 +172,10 @@ static const cupsd_var_t variables[] =
|
||||||
# if defined(HAVE_LIBSSL) || defined(HAVE_GNUTLS)
|
# if defined(HAVE_LIBSSL) || defined(HAVE_GNUTLS)
|
||||||
{ "ServerKey", &ServerKey, CUPSD_VARTYPE_PATHNAME },
|
{ "ServerKey", &ServerKey, CUPSD_VARTYPE_PATHNAME },
|
||||||
# endif /* HAVE_LIBSSL || HAVE_GNUTLS */
|
# endif /* HAVE_LIBSSL || HAVE_GNUTLS */
|
||||||
@ -1993,17 +2047,17 @@ diff -up cups-1.3.8/scheduler/conf.c.lspp cups-1.3.8/scheduler/conf.c
|
|||||||
#endif /* HAVE_SSL */
|
#endif /* HAVE_SSL */
|
||||||
{ "ServerName", &ServerName, CUPSD_VARTYPE_STRING },
|
{ "ServerName", &ServerName, CUPSD_VARTYPE_STRING },
|
||||||
{ "ServerRoot", &ServerRoot, CUPSD_VARTYPE_PATHNAME },
|
{ "ServerRoot", &ServerRoot, CUPSD_VARTYPE_PATHNAME },
|
||||||
@@ -352,6 +360,9 @@ cupsdReadConfiguration(void)
|
@@ -380,6 +388,9 @@ cupsdReadConfiguration(void)
|
||||||
*old_requestroot; /* Old RequestRoot */
|
|
||||||
const char *tmpdir; /* TMPDIR environment variable */
|
const char *tmpdir; /* TMPDIR environment variable */
|
||||||
struct stat tmpinfo; /* Temporary directory info */
|
struct stat tmpinfo; /* Temporary directory info */
|
||||||
|
cupsd_policy_t *p; /* Policy */
|
||||||
+#ifdef WITH_LSPP
|
+#ifdef WITH_LSPP
|
||||||
+ char *audit_message; /* Audit message string */
|
+ char *audit_message; /* Audit message string */
|
||||||
+#endif /* WITH_LSPP */
|
+#endif /* WITH_LSPP */
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@@ -614,6 +625,25 @@ cupsdReadConfiguration(void)
|
@@ -659,6 +670,25 @@ cupsdReadConfiguration(void)
|
||||||
|
|
||||||
RunUser = getuid();
|
RunUser = getuid();
|
||||||
|
|
||||||
@ -2029,9 +2083,9 @@ diff -up cups-1.3.8/scheduler/conf.c.lspp cups-1.3.8/scheduler/conf.c
|
|||||||
/*
|
/*
|
||||||
* See if the ServerName is an IP address...
|
* See if the ServerName is an IP address...
|
||||||
*/
|
*/
|
||||||
@@ -896,11 +926,23 @@ cupsdReadConfiguration(void)
|
@@ -951,11 +981,23 @@ cupsdReadConfiguration(void)
|
||||||
if (MaxActiveJobs > (MaxFDs / 3))
|
* Update classification setting as needed...
|
||||||
MaxActiveJobs = MaxFDs / 3;
|
*/
|
||||||
|
|
||||||
- if (Classification && !strcasecmp(Classification, "none"))
|
- if (Classification && !strcasecmp(Classification, "none"))
|
||||||
+ if (Classification && strcasecmp(Classification, "none") == 0)
|
+ if (Classification && strcasecmp(Classification, "none") == 0)
|
||||||
@ -2053,8 +2107,8 @@ diff -up cups-1.3.8/scheduler/conf.c.lspp cups-1.3.8/scheduler/conf.c
|
|||||||
+ }
|
+ }
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Update the MaxClientsPerHost value, as needed...
|
* Check the MaxClients setting, and then allocate memory for it...
|
||||||
@@ -3299,6 +3341,18 @@ read_location(cups_file_t *fp, /* I - C
|
@@ -3489,6 +3531,18 @@ read_location(cups_file_t *fp, /* I - C
|
||||||
return ((FatalErrors & CUPSD_FATAL_CONFIG) ? 0 : linenum);
|
return ((FatalErrors & CUPSD_FATAL_CONFIG) ? 0 : linenum);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2073,12 +2127,12 @@ diff -up cups-1.3.8/scheduler/conf.c.lspp cups-1.3.8/scheduler/conf.c
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* 'read_policy()' - Read a <Policy name> definition.
|
* 'read_policy()' - Read a <Policy name> definition.
|
||||||
diff -up cups-1.3.8/scheduler/conf.h.lspp cups-1.3.8/scheduler/conf.h
|
diff -up cups-1.4b1/scheduler/conf.h.lspp cups-1.4b1/scheduler/conf.h
|
||||||
--- cups-1.3.8/scheduler/conf.h.lspp 2008-09-10 16:18:26.000000000 +0100
|
--- cups-1.4b1/scheduler/conf.h.lspp 2008-11-11 16:53:28.000000000 +0000
|
||||||
+++ cups-1.3.8/scheduler/conf.h 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/scheduler/conf.h 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -208,6 +208,12 @@ VAR char *ServerKey VALUE(NULL);
|
@@ -233,6 +233,12 @@ VAR char *ServerKey VALUE(NULL);
|
||||||
/* Server key file */
|
VAR int SSLOptions VALUE(CUPSD_SSL_NONE);
|
||||||
# endif /* HAVE_LIBSSL || HAVE_GNUTLS */
|
/* SSL/TLS options */
|
||||||
#endif /* HAVE_SSL */
|
#endif /* HAVE_SSL */
|
||||||
+#ifdef WITH_LSPP
|
+#ifdef WITH_LSPP
|
||||||
+VAR int AuditLog VALUE(-1),
|
+VAR int AuditLog VALUE(-1),
|
||||||
@ -2088,8 +2142,8 @@ diff -up cups-1.3.8/scheduler/conf.h.lspp cups-1.3.8/scheduler/conf.h
|
|||||||
+#endif /* WITH_LSPP */
|
+#endif /* WITH_LSPP */
|
||||||
|
|
||||||
#ifdef HAVE_LAUNCHD
|
#ifdef HAVE_LAUNCHD
|
||||||
VAR int LaunchdTimeout VALUE(DEFAULT_TIMEOUT);
|
VAR int LaunchdTimeout VALUE(DEFAULT_KEEPALIVE);
|
||||||
@@ -226,6 +232,9 @@ VAR char *SystemGroupAuthKey VALUE(NULL
|
@@ -251,6 +257,9 @@ VAR char *SystemGroupAuthKey VALUE(NULL
|
||||||
/* System group auth key */
|
/* System group auth key */
|
||||||
#endif /* HAVE_AUTHORIZATION_H */
|
#endif /* HAVE_AUTHORIZATION_H */
|
||||||
|
|
||||||
@ -2099,10 +2153,10 @@ diff -up cups-1.3.8/scheduler/conf.h.lspp cups-1.3.8/scheduler/conf.h
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Prototypes...
|
* Prototypes...
|
||||||
diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
diff -up cups-1.4b1/scheduler/ipp.c.lspp cups-1.4b1/scheduler/ipp.c
|
||||||
--- cups-1.3.8/scheduler/ipp.c.lspp 2008-09-10 16:18:26.000000000 +0100
|
--- cups-1.4b1/scheduler/ipp.c.lspp 2008-11-11 16:53:28.000000000 +0000
|
||||||
+++ cups-1.3.8/scheduler/ipp.c 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/scheduler/ipp.c 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -36,6 +36,7 @@
|
@@ -41,6 +41,7 @@
|
||||||
* cancel_all_jobs() - Cancel all print jobs.
|
* cancel_all_jobs() - Cancel all print jobs.
|
||||||
* cancel_job() - Cancel a print job.
|
* cancel_job() - Cancel a print job.
|
||||||
* cancel_subscription() - Cancel a subscription.
|
* cancel_subscription() - Cancel a subscription.
|
||||||
@ -2110,7 +2164,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
* check_quotas() - Check quotas for a printer and user.
|
* check_quotas() - Check quotas for a printer and user.
|
||||||
* check_rss_recipient() - Check that we do not have a duplicate RSS
|
* check_rss_recipient() - Check that we do not have a duplicate RSS
|
||||||
* feed URI.
|
* feed URI.
|
||||||
@@ -95,6 +96,9 @@
|
@@ -101,6 +102,9 @@
|
||||||
* validate_user() - Validate the user for the request.
|
* validate_user() - Validate the user for the request.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -2120,7 +2174,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
/*
|
/*
|
||||||
* Include necessary headers...
|
* Include necessary headers...
|
||||||
*/
|
*/
|
||||||
@@ -118,6 +122,14 @@ extern int mbr_check_membership_by_id(uu
|
@@ -127,6 +131,14 @@ extern int mbr_check_membership_by_id(uu
|
||||||
# endif /* HAVE_MEMBERSHIPPRIV_H */
|
# endif /* HAVE_MEMBERSHIPPRIV_H */
|
||||||
#endif /* __APPLE__ */
|
#endif /* __APPLE__ */
|
||||||
|
|
||||||
@ -2135,7 +2189,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Local functions...
|
* Local functions...
|
||||||
@@ -143,6 +155,9 @@ static void cancel_all_jobs(cupsd_client
|
@@ -160,6 +172,9 @@ static void cancel_all_jobs(cupsd_client
|
||||||
static void cancel_job(cupsd_client_t *con, ipp_attribute_t *uri);
|
static void cancel_job(cupsd_client_t *con, ipp_attribute_t *uri);
|
||||||
static void cancel_subscription(cupsd_client_t *con, int id);
|
static void cancel_subscription(cupsd_client_t *con, int id);
|
||||||
static int check_rss_recipient(const char *recipient);
|
static int check_rss_recipient(const char *recipient);
|
||||||
@ -2145,7 +2199,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
static int check_quotas(cupsd_client_t *con, cupsd_printer_t *p);
|
static int check_quotas(cupsd_client_t *con, cupsd_printer_t *p);
|
||||||
static ipp_attribute_t *copy_attribute(ipp_t *to, ipp_attribute_t *attr,
|
static ipp_attribute_t *copy_attribute(ipp_t *to, ipp_attribute_t *attr,
|
||||||
int quickcopy);
|
int quickcopy);
|
||||||
@@ -1270,6 +1285,21 @@ add_job(cupsd_client_t *con, /* I - Cl
|
@@ -1311,6 +1326,21 @@ add_job(cupsd_client_t *con, /* I - Cl
|
||||||
int kbytes; /* Size of print file */
|
int kbytes; /* Size of print file */
|
||||||
int i; /* Looping var */
|
int i; /* Looping var */
|
||||||
int lowerpagerange; /* Page range bound */
|
int lowerpagerange; /* Page range bound */
|
||||||
@ -2167,7 +2221,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
|
|
||||||
|
|
||||||
cupsdLogMessage(CUPSD_LOG_DEBUG2, "add_job(%p[%d], %p(%s), %p(%s/%s))",
|
cupsdLogMessage(CUPSD_LOG_DEBUG2, "add_job(%p[%d], %p(%s), %p(%s/%s))",
|
||||||
@@ -1486,6 +1516,104 @@ add_job(cupsd_client_t *con, /* I - Cl
|
@@ -1527,6 +1557,104 @@ add_job(cupsd_client_t *con, /* I - Cl
|
||||||
ippAddString(con->request, IPP_TAG_JOB, IPP_TAG_NAME, "job-name", NULL,
|
ippAddString(con->request, IPP_TAG_JOB, IPP_TAG_NAME, "job-name", NULL,
|
||||||
title = "Untitled");
|
title = "Untitled");
|
||||||
|
|
||||||
@ -2272,7 +2326,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
if ((job = cupsdAddJob(priority, printer->name)) == NULL)
|
if ((job = cupsdAddJob(priority, printer->name)) == NULL)
|
||||||
{
|
{
|
||||||
send_ipp_status(con, IPP_INTERNAL_ERROR,
|
send_ipp_status(con, IPP_INTERNAL_ERROR,
|
||||||
@@ -1494,6 +1622,32 @@ add_job(cupsd_client_t *con, /* I - Cl
|
@@ -1535,6 +1663,32 @@ add_job(cupsd_client_t *con, /* I - Cl
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2305,7 +2359,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
job->dtype = printer->type & (CUPS_PRINTER_CLASS | CUPS_PRINTER_IMPLICIT |
|
job->dtype = printer->type & (CUPS_PRINTER_CLASS | CUPS_PRINTER_IMPLICIT |
|
||||||
CUPS_PRINTER_REMOTE);
|
CUPS_PRINTER_REMOTE);
|
||||||
job->attrs = con->request;
|
job->attrs = con->request;
|
||||||
@@ -1699,6 +1853,29 @@ add_job(cupsd_client_t *con, /* I - Cl
|
@@ -1743,6 +1897,29 @@ add_job(cupsd_client_t *con, /* I - Cl
|
||||||
attr->values[0].string.text = _cupsStrAlloc(printer->job_sheets[0]);
|
attr->values[0].string.text = _cupsStrAlloc(printer->job_sheets[0]);
|
||||||
attr->values[1].string.text = _cupsStrAlloc(printer->job_sheets[1]);
|
attr->values[1].string.text = _cupsStrAlloc(printer->job_sheets[1]);
|
||||||
}
|
}
|
||||||
@ -2335,19 +2389,19 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
|
|
||||||
job->job_sheets = attr;
|
job->job_sheets = attr;
|
||||||
|
|
||||||
@@ -1729,6 +1906,9 @@ add_job(cupsd_client_t *con, /* I - Cl
|
@@ -1773,6 +1950,9 @@ add_job(cupsd_client_t *con, /* I - Cl
|
||||||
"job-sheets=\"%s,none\", "
|
"job-sheets=\"%s,none\", "
|
||||||
"job-originating-user-name=\"%s\"",
|
"job-originating-user-name=\"%s\"",
|
||||||
job->id, Classification, job->username);
|
Classification, job->username);
|
||||||
+#ifdef WITH_LSPP
|
+#ifdef WITH_LSPP
|
||||||
+ override = 1;
|
+ override = 1;
|
||||||
+#endif /* WITH_LSPP */
|
+#endif /* WITH_LSPP */
|
||||||
}
|
}
|
||||||
else if (attr->num_values == 2 &&
|
else if (attr->num_values == 2 &&
|
||||||
strcmp(attr->values[0].string.text,
|
strcmp(attr->values[0].string.text,
|
||||||
@@ -1747,6 +1927,9 @@ add_job(cupsd_client_t *con, /* I - Cl
|
@@ -1791,6 +1971,9 @@ add_job(cupsd_client_t *con, /* I - Cl
|
||||||
"job-originating-user-name=\"%s\"",
|
"job-originating-user-name=\"%s\"",
|
||||||
job->id, attr->values[0].string.text,
|
attr->values[0].string.text,
|
||||||
attr->values[1].string.text, job->username);
|
attr->values[1].string.text, job->username);
|
||||||
+#ifdef WITH_LSPP
|
+#ifdef WITH_LSPP
|
||||||
+ override = 1;
|
+ override = 1;
|
||||||
@ -2355,9 +2409,9 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
}
|
}
|
||||||
else if (strcmp(attr->values[0].string.text, Classification) &&
|
else if (strcmp(attr->values[0].string.text, Classification) &&
|
||||||
strcmp(attr->values[0].string.text, "none") &&
|
strcmp(attr->values[0].string.text, "none") &&
|
||||||
@@ -1767,6 +1950,9 @@ add_job(cupsd_client_t *con, /* I - Cl
|
@@ -1811,6 +1994,9 @@ add_job(cupsd_client_t *con, /* I - Cl
|
||||||
"job-originating-user-name=\"%s\"",
|
"job-originating-user-name=\"%s\"",
|
||||||
job->id, attr->values[0].string.text,
|
attr->values[0].string.text,
|
||||||
attr->values[1].string.text, job->username);
|
attr->values[1].string.text, job->username);
|
||||||
+#ifdef WITH_LSPP
|
+#ifdef WITH_LSPP
|
||||||
+ override = 1;
|
+ override = 1;
|
||||||
@ -2365,10 +2419,10 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (strcmp(attr->values[0].string.text, Classification) &&
|
else if (strcmp(attr->values[0].string.text, Classification) &&
|
||||||
@@ -1807,9 +1993,52 @@ add_job(cupsd_client_t *con, /* I - Cl
|
@@ -1851,8 +2037,52 @@ add_job(cupsd_client_t *con, /* I - Cl
|
||||||
"job-sheets=\"%s\", "
|
"job-sheets=\"%s\", "
|
||||||
"job-originating-user-name=\"%s\"",
|
"job-originating-user-name=\"%s\"",
|
||||||
job->id, Classification, job->username);
|
Classification, job->username);
|
||||||
+#ifdef WITH_LSPP
|
+#ifdef WITH_LSPP
|
||||||
+ override = 1;
|
+ override = 1;
|
||||||
+#endif /* WITH_LSPP */
|
+#endif /* WITH_LSPP */
|
||||||
@ -2405,20 +2459,20 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
+ ServerName, NULL, NULL, 0);
|
+ ServerName, NULL, NULL, 0);
|
||||||
+ }
|
+ }
|
||||||
+ cupsdClearString(&audit_message);
|
+ cupsdClearString(&audit_message);
|
||||||
|
+ }
|
||||||
}
|
}
|
||||||
}
|
+
|
||||||
|
|
||||||
+ if (userheader)
|
+ if (userheader)
|
||||||
+ free(userheader);
|
+ free(userheader);
|
||||||
+ if (userfooter)
|
+ if (userfooter)
|
||||||
+ free(userfooter);
|
+ free(userfooter);
|
||||||
+#endif /* WITH_LSPP */
|
+#endif /* WITH_LSPP */
|
||||||
+ }
|
}
|
||||||
+
|
+
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* See if we need to add the starting sheet...
|
* See if we need to add the starting sheet...
|
||||||
*/
|
@@ -4186,6 +4416,103 @@ check_rss_recipient(
|
||||||
@@ -3521,6 +3750,103 @@ check_rss_recipient(
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -2522,7 +2576,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
/*
|
/*
|
||||||
* 'check_quotas()' - Check quotas for a printer and user.
|
* 'check_quotas()' - Check quotas for a printer and user.
|
||||||
*/
|
*/
|
||||||
@@ -4042,6 +4368,15 @@ copy_banner(cupsd_client_t *con, /* I -
|
@@ -4714,6 +5041,15 @@ copy_banner(cupsd_client_t *con, /* I -
|
||||||
char attrname[255], /* Name of attribute */
|
char attrname[255], /* Name of attribute */
|
||||||
*s; /* Pointer into name */
|
*s; /* Pointer into name */
|
||||||
ipp_attribute_t *attr; /* Attribute */
|
ipp_attribute_t *attr; /* Attribute */
|
||||||
@ -2538,7 +2592,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
|
|
||||||
|
|
||||||
cupsdLogMessage(CUPSD_LOG_DEBUG2,
|
cupsdLogMessage(CUPSD_LOG_DEBUG2,
|
||||||
@@ -4077,6 +4412,82 @@ copy_banner(cupsd_client_t *con, /* I -
|
@@ -4749,6 +5085,82 @@ copy_banner(cupsd_client_t *con, /* I -
|
||||||
|
|
||||||
fchmod(cupsFileNumber(out), 0640);
|
fchmod(cupsFileNumber(out), 0640);
|
||||||
fchown(cupsFileNumber(out), RunUser, Group);
|
fchown(cupsFileNumber(out), RunUser, Group);
|
||||||
@ -2621,7 +2675,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Try the localized banner file under the subdirectory...
|
* Try the localized banner file under the subdirectory...
|
||||||
@@ -4171,6 +4582,24 @@ copy_banner(cupsd_client_t *con, /* I -
|
@@ -4843,6 +5255,24 @@ copy_banner(cupsd_client_t *con, /* I -
|
||||||
else
|
else
|
||||||
s = attrname;
|
s = attrname;
|
||||||
|
|
||||||
@ -2646,7 +2700,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
if (!strcmp(s, "printer-name"))
|
if (!strcmp(s, "printer-name"))
|
||||||
{
|
{
|
||||||
cupsFilePuts(out, job->dest);
|
cupsFilePuts(out, job->dest);
|
||||||
@@ -5938,6 +6367,22 @@ get_job_attrs(cupsd_client_t *con, /* I
|
@@ -6745,6 +7175,22 @@ get_job_attrs(cupsd_client_t *con, /* I
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2669,7 +2723,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
/*
|
/*
|
||||||
* Copy attributes...
|
* Copy attributes...
|
||||||
*/
|
*/
|
||||||
@@ -6143,6 +6588,11 @@ get_jobs(cupsd_client_t *con, /* I - C
|
@@ -6955,6 +7401,11 @@ get_jobs(cupsd_client_t *con, /* I - C
|
||||||
if (count > 0)
|
if (count > 0)
|
||||||
ippAddSeparator(con->response);
|
ippAddSeparator(con->response);
|
||||||
|
|
||||||
@ -2681,7 +2735,7 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
count ++;
|
count ++;
|
||||||
|
|
||||||
cupsdLogMessage(CUPSD_LOG_DEBUG2, "get_jobs: count = %d", count);
|
cupsdLogMessage(CUPSD_LOG_DEBUG2, "get_jobs: count = %d", count);
|
||||||
@@ -10255,6 +10705,11 @@ validate_user(cupsd_job_t *job, /* I
|
@@ -11250,6 +11701,11 @@ validate_user(cupsd_job_t *job, /* I
|
||||||
|
|
||||||
strlcpy(username, get_username(con), userlen);
|
strlcpy(username, get_username(con), userlen);
|
||||||
|
|
||||||
@ -2693,9 +2747,9 @@ diff -up cups-1.3.8/scheduler/ipp.c.lspp cups-1.3.8/scheduler/ipp.c
|
|||||||
/*
|
/*
|
||||||
* Check the username against the owner...
|
* Check the username against the owner...
|
||||||
*/
|
*/
|
||||||
diff -up cups-1.3.8/scheduler/job.c.lspp cups-1.3.8/scheduler/job.c
|
diff -up cups-1.4b1/scheduler/job.c.lspp cups-1.4b1/scheduler/job.c
|
||||||
--- cups-1.3.8/scheduler/job.c.lspp 2008-09-10 16:18:26.000000000 +0100
|
--- cups-1.4b1/scheduler/job.c.lspp 2008-11-11 16:53:28.000000000 +0000
|
||||||
+++ cups-1.3.8/scheduler/job.c 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/scheduler/job.c 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -60,6 +60,9 @@
|
@@ -60,6 +60,9 @@
|
||||||
* update_job_attrs() - Update the job-printer-* attributes.
|
* update_job_attrs() - Update the job-printer-* attributes.
|
||||||
*/
|
*/
|
||||||
@ -2721,7 +2775,7 @@ diff -up cups-1.3.8/scheduler/job.c.lspp cups-1.3.8/scheduler/job.c
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Local globals...
|
* Local globals...
|
||||||
@@ -1136,6 +1147,23 @@ cupsdLoadJob(cupsd_job_t *job) /* I - J
|
@@ -1151,6 +1162,23 @@ cupsdLoadJob(cupsd_job_t *job) /* I - J
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2745,7 +2799,7 @@ diff -up cups-1.3.8/scheduler/job.c.lspp cups-1.3.8/scheduler/job.c
|
|||||||
job->sheets = ippFindAttribute(job->attrs, "job-media-sheets-completed",
|
job->sheets = ippFindAttribute(job->attrs, "job-media-sheets-completed",
|
||||||
IPP_TAG_INTEGER);
|
IPP_TAG_INTEGER);
|
||||||
job->job_sheets = ippFindAttribute(job->attrs, "job-sheets", IPP_TAG_NAME);
|
job->job_sheets = ippFindAttribute(job->attrs, "job-sheets", IPP_TAG_NAME);
|
||||||
@@ -1493,6 +1521,13 @@ cupsdSaveJob(cupsd_job_t *job) /* I - J
|
@@ -1508,6 +1536,13 @@ cupsdSaveJob(cupsd_job_t *job) /* I - J
|
||||||
{
|
{
|
||||||
char filename[1024]; /* Job control filename */
|
char filename[1024]; /* Job control filename */
|
||||||
cups_file_t *fp; /* Job file */
|
cups_file_t *fp; /* Job file */
|
||||||
@ -2759,7 +2813,7 @@ diff -up cups-1.3.8/scheduler/job.c.lspp cups-1.3.8/scheduler/job.c
|
|||||||
|
|
||||||
|
|
||||||
cupsdLogMessage(CUPSD_LOG_DEBUG2, "cupsdSaveJob(job=%p(%d)): job->attrs=%p",
|
cupsdLogMessage(CUPSD_LOG_DEBUG2, "cupsdSaveJob(job=%p(%d)): job->attrs=%p",
|
||||||
@@ -1511,6 +1546,76 @@ cupsdSaveJob(cupsd_job_t *job) /* I - J
|
@@ -1526,6 +1561,76 @@ cupsdSaveJob(cupsd_job_t *job) /* I - J
|
||||||
fchmod(cupsFileNumber(fp), 0600);
|
fchmod(cupsFileNumber(fp), 0600);
|
||||||
fchown(cupsFileNumber(fp), RunUser, Group);
|
fchown(cupsFileNumber(fp), RunUser, Group);
|
||||||
|
|
||||||
@ -2836,7 +2890,7 @@ diff -up cups-1.3.8/scheduler/job.c.lspp cups-1.3.8/scheduler/job.c
|
|||||||
job->attrs->state = IPP_IDLE;
|
job->attrs->state = IPP_IDLE;
|
||||||
|
|
||||||
if (ippWriteIO(fp, (ipp_iocb_t)cupsFileWrite, 1, NULL,
|
if (ippWriteIO(fp, (ipp_iocb_t)cupsFileWrite, 1, NULL,
|
||||||
@@ -2485,6 +2590,21 @@ start_job(cupsd_job_t *job, /* I -
|
@@ -2511,6 +2616,21 @@ start_job(cupsd_job_t *job, /* I -
|
||||||
/* RIP_MAX_CACHE env variable */
|
/* RIP_MAX_CACHE env variable */
|
||||||
static char *options = NULL;/* Full list of options */
|
static char *options = NULL;/* Full list of options */
|
||||||
static int optlength = 0; /* Length of option buffer */
|
static int optlength = 0; /* Length of option buffer */
|
||||||
@ -2857,8 +2911,8 @@ diff -up cups-1.3.8/scheduler/job.c.lspp cups-1.3.8/scheduler/job.c
|
|||||||
+#endif /* WITH_LSPP */
|
+#endif /* WITH_LSPP */
|
||||||
|
|
||||||
|
|
||||||
cupsdLogMessage(CUPSD_LOG_DEBUG2, "[Job %d] start_job: file = %d/%d",
|
cupsdLogJob(job, CUPSD_LOG_DEBUG2, "start_job: file = %d/%d",
|
||||||
@@ -2756,6 +2876,106 @@ start_job(cupsd_job_t *job, /* I -
|
@@ -2783,6 +2903,106 @@ start_job(cupsd_job_t *job, /* I -
|
||||||
fcntl(job->side_pipes[1], F_GETFL) | O_NONBLOCK);
|
fcntl(job->side_pipes[1], F_GETFL) | O_NONBLOCK);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2965,7 +3019,7 @@ diff -up cups-1.3.8/scheduler/job.c.lspp cups-1.3.8/scheduler/job.c
|
|||||||
/*
|
/*
|
||||||
* Determine if we are printing a banner page or not...
|
* Determine if we are printing a banner page or not...
|
||||||
*/
|
*/
|
||||||
@@ -2904,6 +3124,18 @@ start_job(cupsd_job_t *job, /* I -
|
@@ -2920,6 +3140,18 @@ start_job(cupsd_job_t *job, /* I -
|
||||||
banner_page)
|
banner_page)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
@ -2984,7 +3038,7 @@ diff -up cups-1.3.8/scheduler/job.c.lspp cups-1.3.8/scheduler/job.c
|
|||||||
/*
|
/*
|
||||||
* Otherwise add them to the list...
|
* Otherwise add them to the list...
|
||||||
*/
|
*/
|
||||||
@@ -3146,6 +3378,67 @@ start_job(cupsd_job_t *job, /* I -
|
@@ -3169,6 +3401,67 @@ start_job(cupsd_job_t *job, /* I -
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3052,9 +3106,9 @@ diff -up cups-1.3.8/scheduler/job.c.lspp cups-1.3.8/scheduler/job.c
|
|||||||
if (Classification && !banner_page)
|
if (Classification && !banner_page)
|
||||||
{
|
{
|
||||||
if ((attr = ippFindAttribute(job->attrs, "job-sheets",
|
if ((attr = ippFindAttribute(job->attrs, "job-sheets",
|
||||||
diff -up cups-1.3.8/scheduler/job.h.lspp cups-1.3.8/scheduler/job.h
|
diff -up cups-1.4b1/scheduler/job.h.lspp cups-1.4b1/scheduler/job.h
|
||||||
--- cups-1.3.8/scheduler/job.h.lspp 2008-01-16 22:20:33.000000000 +0000
|
--- cups-1.4b1/scheduler/job.h.lspp 2008-08-28 21:38:13.000000000 +0100
|
||||||
+++ cups-1.3.8/scheduler/job.h 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/scheduler/job.h 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -13,6 +13,13 @@
|
@@ -13,6 +13,13 @@
|
||||||
* file is missing or damaged, see the license at "http://www.cups.org/".
|
* file is missing or damaged, see the license at "http://www.cups.org/".
|
||||||
*/
|
*/
|
||||||
@ -3069,7 +3123,7 @@ diff -up cups-1.3.8/scheduler/job.h.lspp cups-1.3.8/scheduler/job.h
|
|||||||
/*
|
/*
|
||||||
* Job request structure...
|
* Job request structure...
|
||||||
*/
|
*/
|
||||||
@@ -60,6 +67,10 @@ typedef struct cupsd_job_s
|
@@ -63,6 +70,10 @@ typedef struct cupsd_job_s
|
||||||
krb5_ccache ccache; /* Kerberos credential cache */
|
krb5_ccache ccache; /* Kerberos credential cache */
|
||||||
char *ccname; /* KRB5CCNAME environment variable */
|
char *ccname; /* KRB5CCNAME environment variable */
|
||||||
#endif /* HAVE_GSSAPI */
|
#endif /* HAVE_GSSAPI */
|
||||||
@ -3080,9 +3134,9 @@ diff -up cups-1.3.8/scheduler/job.h.lspp cups-1.3.8/scheduler/job.h
|
|||||||
} cupsd_job_t;
|
} cupsd_job_t;
|
||||||
|
|
||||||
|
|
||||||
diff -up cups-1.3.8/scheduler/main.c.lspp cups-1.3.8/scheduler/main.c
|
diff -up cups-1.4b1/scheduler/main.c.lspp cups-1.4b1/scheduler/main.c
|
||||||
--- cups-1.3.8/scheduler/main.c.lspp 2008-09-10 16:18:26.000000000 +0100
|
--- cups-1.4b1/scheduler/main.c.lspp 2008-11-11 16:53:28.000000000 +0000
|
||||||
+++ cups-1.3.8/scheduler/main.c 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/scheduler/main.c 2008-11-11 16:53:28.000000000 +0000
|
||||||
@@ -35,6 +35,8 @@
|
@@ -35,6 +35,8 @@
|
||||||
* usage() - Show scheduler usage.
|
* usage() - Show scheduler usage.
|
||||||
*/
|
*/
|
||||||
@ -3112,7 +3166,7 @@ diff -up cups-1.3.8/scheduler/main.c.lspp cups-1.3.8/scheduler/main.c
|
|||||||
|
|
||||||
|
|
||||||
#ifdef HAVE_GETEUID
|
#ifdef HAVE_GETEUID
|
||||||
@@ -413,6 +421,25 @@ main(int argc, /* I - Number of comm
|
@@ -426,6 +434,25 @@ main(int argc, /* I - Number of comm
|
||||||
#endif /* DEBUG */
|
#endif /* DEBUG */
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3138,7 +3192,7 @@ diff -up cups-1.3.8/scheduler/main.c.lspp cups-1.3.8/scheduler/main.c
|
|||||||
/*
|
/*
|
||||||
* Set the timezone info...
|
* Set the timezone info...
|
||||||
*/
|
*/
|
||||||
@@ -1160,6 +1187,11 @@ main(int argc, /* I - Number of comm
|
@@ -1200,6 +1227,11 @@ main(int argc, /* I - Number of comm
|
||||||
|
|
||||||
cupsdStopSelect();
|
cupsdStopSelect();
|
||||||
|
|
||||||
@ -3150,11 +3204,11 @@ diff -up cups-1.3.8/scheduler/main.c.lspp cups-1.3.8/scheduler/main.c
|
|||||||
return (!stop_scheduler);
|
return (!stop_scheduler);
|
||||||
}
|
}
|
||||||
|
|
||||||
diff -up cups-1.3.8/scheduler/printers.c.lspp cups-1.3.8/scheduler/printers.c
|
diff -up cups-1.4b1/scheduler/printers.c.lspp cups-1.4b1/scheduler/printers.c
|
||||||
--- cups-1.3.8/scheduler/printers.c.lspp 2008-09-10 16:18:26.000000000 +0100
|
--- cups-1.4b1/scheduler/printers.c.lspp 2008-11-11 16:53:28.000000000 +0000
|
||||||
+++ cups-1.3.8/scheduler/printers.c 2008-09-10 16:18:26.000000000 +0100
|
+++ cups-1.4b1/scheduler/printers.c 2008-11-11 17:00:31.000000000 +0000
|
||||||
@@ -51,6 +51,8 @@
|
@@ -52,6 +52,8 @@
|
||||||
* printing desktop tools.
|
* write_xml_string() - Write a string with XML escaping.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
+/* (c) Copyright 2005-2006 Hewlett-Packard Development Company, L.P. */
|
+/* (c) Copyright 2005-2006 Hewlett-Packard Development Company, L.P. */
|
||||||
@ -3162,9 +3216,9 @@ diff -up cups-1.3.8/scheduler/printers.c.lspp cups-1.3.8/scheduler/printers.c
|
|||||||
/*
|
/*
|
||||||
* Include necessary headers...
|
* Include necessary headers...
|
||||||
*/
|
*/
|
||||||
@@ -74,6 +76,10 @@ static void write_irix_config(cupsd_prin
|
@@ -79,6 +81,10 @@ static void write_irix_state(cupsd_print
|
||||||
static void write_irix_state(cupsd_printer_t *p);
|
|
||||||
#endif /* __sgi */
|
#endif /* __sgi */
|
||||||
|
static void write_xml_string(cups_file_t *fp, const char *s);
|
||||||
|
|
||||||
+#ifdef WITH_LSPP
|
+#ifdef WITH_LSPP
|
||||||
+# include <libaudit.h>
|
+# include <libaudit.h>
|
||||||
@ -3173,7 +3227,7 @@ diff -up cups-1.3.8/scheduler/printers.c.lspp cups-1.3.8/scheduler/printers.c
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* 'cupsdAddPrinter()' - Add a printer to the system.
|
* 'cupsdAddPrinter()' - Add a printer to the system.
|
||||||
@@ -1846,6 +1852,13 @@ cupsdSetPrinterAttrs(cupsd_printer_t *p)
|
@@ -2081,6 +2087,13 @@ cupsdSetPrinterAttrs(cupsd_printer_t *p)
|
||||||
{ /* No authentication */
|
{ /* No authentication */
|
||||||
"none"
|
"none"
|
||||||
};
|
};
|
||||||
@ -3187,14 +3241,13 @@ diff -up cups-1.3.8/scheduler/printers.c.lspp cups-1.3.8/scheduler/printers.c
|
|||||||
|
|
||||||
|
|
||||||
DEBUG_printf(("cupsdSetPrinterAttrs: entering name = %s, type = %x\n", p->name,
|
DEBUG_printf(("cupsdSetPrinterAttrs: entering name = %s, type = %x\n", p->name,
|
||||||
@@ -1989,6 +2002,44 @@ cupsdSetPrinterAttrs(cupsd_printer_t *p)
|
@@ -2226,6 +2239,42 @@ cupsdSetPrinterAttrs(cupsd_printer_t *p)
|
||||||
attr->values[1].string.text = _cupsStrAlloc(Classification ?
|
attr->values[1].string.text = _cupsStrAlloc(Classification ?
|
||||||
Classification : p->job_sheets[1]);
|
Classification : p->job_sheets[1]);
|
||||||
}
|
}
|
||||||
+#ifdef WITH_LSPP
|
+#ifdef WITH_LSPP
|
||||||
+ if (AuditLog != -1)
|
+ if (AuditLog != -1)
|
||||||
+ {
|
+ {
|
||||||
+ char uri[HTTP_MAX_URI];
|
|
||||||
+ audit_message = NULL;
|
+ audit_message = NULL;
|
||||||
+ rangestr = NULL;
|
+ rangestr = NULL;
|
||||||
+ printercon = 0;
|
+ printercon = 0;
|
||||||
@ -3218,9 +3271,8 @@ diff -up cups-1.3.8/scheduler/printers.c.lspp cups-1.3.8/scheduler/printers.c
|
|||||||
+ else
|
+ else
|
||||||
+ rangestr = strdup("unknown");
|
+ rangestr = strdup("unknown");
|
||||||
+
|
+
|
||||||
+ cupsdSanitizeURI(p->device_uri, uri, sizeof(uri));
|
|
||||||
+ cupsdSetStringf(&audit_message, "printer=%s uri=%s banners=%s,%s range=%s",
|
+ cupsdSetStringf(&audit_message, "printer=%s uri=%s banners=%s,%s range=%s",
|
||||||
+ p->name, uri, p->job_sheets[0], p->job_sheets[1], rangestr);
|
+ p->name, p->sanitized_device_uri, p->job_sheets[0], p->job_sheets[1], rangestr);
|
||||||
+ audit_log_user_message(AuditLog, AUDIT_LABEL_LEVEL_CHANGE, audit_message,
|
+ audit_log_user_message(AuditLog, AUDIT_LABEL_LEVEL_CHANGE, audit_message,
|
||||||
+ ServerName, NULL, NULL, 1);
|
+ ServerName, NULL, NULL, 1);
|
||||||
+ if (printercon)
|
+ if (printercon)
|
||||||
@ -3232,3 +3284,11 @@ diff -up cups-1.3.8/scheduler/printers.c.lspp cups-1.3.8/scheduler/printers.c
|
|||||||
}
|
}
|
||||||
|
|
||||||
p->raw = 0;
|
p->raw = 0;
|
||||||
|
@@ -4606,7 +4655,6 @@ write_irix_state(cupsd_printer_t *p) /*
|
||||||
|
}
|
||||||
|
#endif /* __sgi */
|
||||||
|
|
||||||
|
-
|
||||||
|
/*
|
||||||
|
* 'write_xml_string()' - Write a string with XML escaping.
|
||||||
|
*/
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
--- cups-1.3b1/conf/mime.convs.in.paps 2007-07-18 11:31:28.000000000 +0100
|
diff -up cups-1.4b1/conf/mime.convs.in.paps cups-1.4b1/conf/mime.convs.in
|
||||||
+++ cups-1.3b1/conf/mime.convs.in 2007-07-18 11:31:47.000000000 +0100
|
--- cups-1.4b1/conf/mime.convs.in.paps 2008-10-08 22:07:45.000000000 +0100
|
||||||
@@ -45,7 +45,7 @@
|
+++ cups-1.4b1/conf/mime.convs.in 2008-11-11 15:42:18.000000000 +0000
|
||||||
|
@@ -45,7 +45,7 @@ application/x-cshell application/postsc
|
||||||
application/x-csource application/postscript 33 texttops
|
application/x-csource application/postscript 33 texttops
|
||||||
application/x-perl application/postscript 33 texttops
|
application/x-perl application/postscript 33 texttops
|
||||||
application/x-shell application/postscript 33 texttops
|
application/x-shell application/postscript 33 texttops
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
diff -up cups-1.3.7/scheduler/conf.c.serverbin-compat cups-1.3.7/scheduler/conf.c
|
diff -up cups-1.4b1/scheduler/conf.c.serverbin-compat cups-1.4b1/scheduler/conf.c
|
||||||
--- cups-1.3.7/scheduler/conf.c.serverbin-compat 2008-03-20 04:06:01.000000000 +0000
|
--- cups-1.4b1/scheduler/conf.c.serverbin-compat 2008-10-08 17:34:03.000000000 +0100
|
||||||
+++ cups-1.3.7/scheduler/conf.c 2008-07-15 11:04:19.000000000 +0100
|
+++ cups-1.4b1/scheduler/conf.c 2008-11-11 15:39:11.000000000 +0000
|
||||||
@@ -402,6 +402,9 @@ cupsdReadConfiguration(void)
|
@@ -432,6 +432,9 @@ cupsdReadConfiguration(void)
|
||||||
cupsdSetString(&ServerName, httpGetHostname(NULL, temp, sizeof(temp)));
|
cupsdSetString(&ServerName, httpGetHostname(NULL, temp, sizeof(temp)));
|
||||||
cupsdSetStringf(&ServerAdmin, "root@%s", temp);
|
cupsdSetStringf(&ServerAdmin, "root@%s", temp);
|
||||||
cupsdSetString(&ServerBin, CUPS_SERVERBIN);
|
cupsdSetString(&ServerBin, CUPS_SERVERBIN);
|
||||||
@ -11,23 +11,23 @@ diff -up cups-1.3.7/scheduler/conf.c.serverbin-compat cups-1.3.7/scheduler/conf.
|
|||||||
cupsdSetString(&RequestRoot, CUPS_REQUESTS);
|
cupsdSetString(&RequestRoot, CUPS_REQUESTS);
|
||||||
cupsdSetString(&CacheDir, CUPS_CACHEDIR);
|
cupsdSetString(&CacheDir, CUPS_CACHEDIR);
|
||||||
cupsdSetString(&DataDir, CUPS_DATADIR);
|
cupsdSetString(&DataDir, CUPS_DATADIR);
|
||||||
@@ -1095,7 +1098,12 @@ cupsdReadConfiguration(void)
|
@@ -1187,7 +1190,12 @@ cupsdReadConfiguration(void)
|
||||||
* Read the MIME type and conversion database...
|
* Read the MIME type and conversion database...
|
||||||
*/
|
*/
|
||||||
|
|
||||||
+#ifdef __x86_64__
|
+#ifdef __x86_64__
|
||||||
+ snprintf(temp, sizeof(temp), "%s/filter:%s/filter", ServerBin,
|
+ snprintf(temp, sizeof(temp), "%s/filter:%s/filter", ServerBin,
|
||||||
+ ServerBin_compat);
|
+ ServerBin_compat);
|
||||||
+#else /* ! defined(__x86_64__) */
|
+#else
|
||||||
snprintf(temp, sizeof(temp), "%s/filter", ServerBin);
|
snprintf(temp, sizeof(temp), "%s/filter", ServerBin);
|
||||||
+#endif
|
+#endif
|
||||||
|
snprintf(mimedir, sizeof(mimedir), "%s/mime", DataDir);
|
||||||
|
|
||||||
MimeDatabase = mimeLoad(ServerRoot, temp);
|
MimeDatabase = mimeLoadTypes(NULL, mimedir);
|
||||||
|
diff -up cups-1.4b1/scheduler/conf.h.serverbin-compat cups-1.4b1/scheduler/conf.h
|
||||||
diff -up cups-1.3.7/scheduler/conf.h.serverbin-compat cups-1.3.7/scheduler/conf.h
|
--- cups-1.4b1/scheduler/conf.h.serverbin-compat 2008-09-19 21:03:36.000000000 +0100
|
||||||
--- cups-1.3.7/scheduler/conf.h.serverbin-compat 2008-02-15 23:26:51.000000000 +0000
|
+++ cups-1.4b1/scheduler/conf.h 2008-11-11 15:35:13.000000000 +0000
|
||||||
+++ cups-1.3.7/scheduler/conf.h 2008-07-15 11:04:19.000000000 +0100
|
@@ -89,6 +89,10 @@ VAR char *ConfigurationFile VALUE(NULL)
|
||||||
@@ -59,6 +59,10 @@ VAR char *ConfigurationFile VALUE(NULL)
|
|
||||||
/* Root directory for scheduler */
|
/* Root directory for scheduler */
|
||||||
*ServerBin VALUE(NULL),
|
*ServerBin VALUE(NULL),
|
||||||
/* Root directory for binaries */
|
/* Root directory for binaries */
|
||||||
@ -38,9 +38,9 @@ diff -up cups-1.3.7/scheduler/conf.h.serverbin-compat cups-1.3.7/scheduler/conf.
|
|||||||
*StateDir VALUE(NULL),
|
*StateDir VALUE(NULL),
|
||||||
/* Root directory for state data */
|
/* Root directory for state data */
|
||||||
*RequestRoot VALUE(NULL),
|
*RequestRoot VALUE(NULL),
|
||||||
diff -up cups-1.3.7/scheduler/env.c.serverbin-compat cups-1.3.7/scheduler/env.c
|
diff -up cups-1.4b1/scheduler/env.c.serverbin-compat cups-1.4b1/scheduler/env.c
|
||||||
--- cups-1.3.7/scheduler/env.c.serverbin-compat 2007-07-11 22:46:42.000000000 +0100
|
--- cups-1.4b1/scheduler/env.c.serverbin-compat 2008-06-18 23:31:26.000000000 +0100
|
||||||
+++ cups-1.3.7/scheduler/env.c 2008-07-15 11:04:19.000000000 +0100
|
+++ cups-1.4b1/scheduler/env.c 2008-11-11 15:35:13.000000000 +0000
|
||||||
@@ -86,8 +86,13 @@ cupsdInitEnv(void)
|
@@ -86,8 +86,13 @@ cupsdInitEnv(void)
|
||||||
cupsdSetEnv("LD_LIBRARY_PATH", NULL);
|
cupsdSetEnv("LD_LIBRARY_PATH", NULL);
|
||||||
cupsdSetEnv("LD_PRELOAD", NULL);
|
cupsdSetEnv("LD_PRELOAD", NULL);
|
||||||
@ -55,10 +55,10 @@ diff -up cups-1.3.7/scheduler/env.c.serverbin-compat cups-1.3.7/scheduler/env.c
|
|||||||
cupsdSetEnv("SERVER_ADMIN", ServerAdmin);
|
cupsdSetEnv("SERVER_ADMIN", ServerAdmin);
|
||||||
cupsdSetEnv("SHLIB_PATH", NULL);
|
cupsdSetEnv("SHLIB_PATH", NULL);
|
||||||
cupsdSetEnv("SOFTWARE", CUPS_MINIMAL);
|
cupsdSetEnv("SOFTWARE", CUPS_MINIMAL);
|
||||||
diff -up cups-1.3.7/scheduler/ipp.c.serverbin-compat cups-1.3.7/scheduler/ipp.c
|
diff -up cups-1.4b1/scheduler/ipp.c.serverbin-compat cups-1.4b1/scheduler/ipp.c
|
||||||
--- cups-1.3.7/scheduler/ipp.c.serverbin-compat 2008-03-24 22:34:44.000000000 +0000
|
--- cups-1.4b1/scheduler/ipp.c.serverbin-compat 2008-10-27 21:54:12.000000000 +0000
|
||||||
+++ cups-1.3.7/scheduler/ipp.c 2008-07-15 11:04:19.000000000 +0100
|
+++ cups-1.4b1/scheduler/ipp.c 2008-11-11 15:41:25.000000000 +0000
|
||||||
@@ -2377,9 +2377,18 @@ add_printer(cupsd_client_t *con, /* I -
|
@@ -2515,9 +2515,18 @@ add_printer(cupsd_client_t *con, /* I -
|
||||||
* Could not find device in list!
|
* Could not find device in list!
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -68,8 +68,8 @@ diff -up cups-1.3.7/scheduler/ipp.c.serverbin-compat cups-1.3.7/scheduler/ipp.c
|
|||||||
+ if (access(srcfile, X_OK))
|
+ if (access(srcfile, X_OK))
|
||||||
+ {
|
+ {
|
||||||
+#endif /* __x86_64__ */
|
+#endif /* __x86_64__ */
|
||||||
send_ipp_status(con, IPP_NOT_POSSIBLE, _("Bad device-uri \"%s\"!"),
|
send_ipp_status(con, IPP_NOT_POSSIBLE, _("Bad device-uri scheme \"%s\"!"),
|
||||||
attr->values[0].string.text);
|
scheme);
|
||||||
return;
|
return;
|
||||||
+#ifdef __x86_64__
|
+#ifdef __x86_64__
|
||||||
+ }
|
+ }
|
||||||
@ -77,10 +77,10 @@ diff -up cups-1.3.7/scheduler/ipp.c.serverbin-compat cups-1.3.7/scheduler/ipp.c
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
diff -up cups-1.3.7/scheduler/job.c.serverbin-compat cups-1.3.7/scheduler/job.c
|
diff -up cups-1.4b1/scheduler/job.c.serverbin-compat cups-1.4b1/scheduler/job.c
|
||||||
--- cups-1.3.7/scheduler/job.c.serverbin-compat 2008-03-25 22:57:40.000000000 +0000
|
--- cups-1.4b1/scheduler/job.c.serverbin-compat 2008-10-21 01:02:45.000000000 +0100
|
||||||
+++ cups-1.3.7/scheduler/job.c 2008-07-15 11:04:19.000000000 +0100
|
+++ cups-1.4b1/scheduler/job.c 2008-11-11 15:35:13.000000000 +0000
|
||||||
@@ -3223,8 +3223,32 @@ start_job(cupsd_job_t *job, /* I -
|
@@ -3267,8 +3267,32 @@ start_job(cupsd_job_t *job, /* I -
|
||||||
i ++, filter = (mime_filter_t *)cupsArrayNext(filters))
|
i ++, filter = (mime_filter_t *)cupsArrayNext(filters))
|
||||||
{
|
{
|
||||||
if (filter->filter[0] != '/')
|
if (filter->filter[0] != '/')
|
||||||
@ -115,7 +115,7 @@ diff -up cups-1.3.7/scheduler/job.c.serverbin-compat cups-1.3.7/scheduler/job.c
|
|||||||
else
|
else
|
||||||
strlcpy(command, filter->filter, sizeof(command));
|
strlcpy(command, filter->filter, sizeof(command));
|
||||||
|
|
||||||
@@ -3374,6 +3398,28 @@ start_job(cupsd_job_t *job, /* I -
|
@@ -3414,6 +3438,28 @@ start_job(cupsd_job_t *job, /* I -
|
||||||
{
|
{
|
||||||
sscanf(printer->device_uri, "%254[^:]", method);
|
sscanf(printer->device_uri, "%254[^:]", method);
|
||||||
snprintf(command, sizeof(command), "%s/backend/%s", ServerBin, method);
|
snprintf(command, sizeof(command), "%s/backend/%s", ServerBin, method);
|
||||||
@ -144,10 +144,10 @@ diff -up cups-1.3.7/scheduler/job.c.serverbin-compat cups-1.3.7/scheduler/job.c
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* See if the backend needs to run as root...
|
* See if the backend needs to run as root...
|
||||||
diff -up cups-1.3.7/scheduler/printers.c.serverbin-compat cups-1.3.7/scheduler/printers.c
|
diff -up cups-1.4b1/scheduler/printers.c.serverbin-compat cups-1.4b1/scheduler/printers.c
|
||||||
--- cups-1.3.7/scheduler/printers.c.serverbin-compat 2008-01-30 06:09:39.000000000 +0000
|
--- cups-1.4b1/scheduler/printers.c.serverbin-compat 2008-10-10 06:28:15.000000000 +0100
|
||||||
+++ cups-1.3.7/scheduler/printers.c 2008-07-15 11:04:19.000000000 +0100
|
+++ cups-1.4b1/scheduler/printers.c 2008-11-11 15:35:13.000000000 +0000
|
||||||
@@ -934,9 +934,19 @@ cupsdLoadAllPrinters(void)
|
@@ -985,9 +985,19 @@ cupsdLoadAllPrinters(void)
|
||||||
* Backend does not exist, stop printer...
|
* Backend does not exist, stop printer...
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -167,7 +167,7 @@ diff -up cups-1.3.7/scheduler/printers.c.serverbin-compat cups-1.3.7/scheduler/p
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -3395,6 +3405,12 @@ add_printer_filter(
|
@@ -3448,6 +3458,12 @@ add_printer_filter(
|
||||||
|
|
||||||
if (access(filename, X_OK))
|
if (access(filename, X_OK))
|
||||||
{
|
{
|
||||||
@ -180,7 +180,7 @@ diff -up cups-1.3.7/scheduler/printers.c.serverbin-compat cups-1.3.7/scheduler/p
|
|||||||
snprintf(p->state_message, sizeof(p->state_message),
|
snprintf(p->state_message, sizeof(p->state_message),
|
||||||
"Filter \"%s\" for printer \"%s\" not available: %s",
|
"Filter \"%s\" for printer \"%s\" not available: %s",
|
||||||
program, p->name, strerror(errno));
|
program, p->name, strerror(errno));
|
||||||
@@ -3402,6 +3418,9 @@ add_printer_filter(
|
@@ -3455,6 +3471,9 @@ add_printer_filter(
|
||||||
cupsdSetPrinterState(p, IPP_PRINTER_STOPPED, 0);
|
cupsdSetPrinterState(p, IPP_PRINTER_STOPPED, 0);
|
||||||
|
|
||||||
cupsdLogMessage(CUPSD_LOG_ERROR, "%s", p->state_message);
|
cupsdLogMessage(CUPSD_LOG_ERROR, "%s", p->state_message);
|
||||||
|
@ -1,30 +0,0 @@
|
|||||||
diff -up cups-1.3.8/scheduler/auth.c.str2101 cups-1.3.8/scheduler/auth.c
|
|
||||||
--- cups-1.3.8/scheduler/auth.c.str2101 2008-08-11 15:12:12.000000000 +0100
|
|
||||||
+++ cups-1.3.8/scheduler/auth.c 2008-08-11 15:12:37.000000000 +0100
|
|
||||||
@@ -2098,7 +2098,7 @@ cupsdIsAuthorized(cupsd_client_t *con, /
|
|
||||||
return (HTTP_OK);
|
|
||||||
}
|
|
||||||
|
|
||||||
- return (HTTP_UNAUTHORIZED);
|
|
||||||
+ return (HTTP_FORBIDDEN);
|
|
||||||
}
|
|
||||||
#endif /* HAVE_AUTHORIZATION_H */
|
|
||||||
|
|
||||||
@@ -2122,7 +2122,7 @@ cupsdIsAuthorized(cupsd_client_t *con, /
|
|
||||||
return (HTTP_OK);
|
|
||||||
}
|
|
||||||
|
|
||||||
- return (HTTP_UNAUTHORIZED);
|
|
||||||
+ return (HTTP_FORBIDDEN);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
@@ -2159,7 +2159,7 @@ cupsdIsAuthorized(cupsd_client_t *con, /
|
|
||||||
cupsdLogMessage(CUPSD_LOG_DEBUG,
|
|
||||||
"cupsdIsAuthorized: User not in group(s)!");
|
|
||||||
|
|
||||||
- return (HTTP_UNAUTHORIZED);
|
|
||||||
+ return (HTTP_FORBIDDEN);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
@ -1,810 +0,0 @@
|
|||||||
diff -up cups-1.3.8/config.h.in.str2536 cups-1.3.8/config.h.in
|
|
||||||
--- cups-1.3.8/config.h.in.str2536 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
+++ cups-1.3.8/config.h.in 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
@@ -43,6 +43,13 @@
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * Default fatal error settings...
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+#define CUPS_DEFAULT_FATAL_ERRORS "config"
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* Default browsing settings...
|
|
||||||
*/
|
|
||||||
|
|
||||||
diff -up cups-1.3.8/config-scripts/cups-defaults.m4.str2536 cups-1.3.8/config-scripts/cups-defaults.m4
|
|
||||||
--- cups-1.3.8/config-scripts/cups-defaults.m4.str2536 2008-04-14 19:10:27.000000000 +0100
|
|
||||||
+++ cups-1.3.8/config-scripts/cups-defaults.m4 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
@@ -43,6 +43,14 @@ AC_ARG_WITH(log_file_perm, [ --with-log
|
|
||||||
AC_SUBST(CUPS_LOG_FILE_PERM)
|
|
||||||
AC_DEFINE_UNQUOTED(CUPS_DEFAULT_LOG_FILE_PERM, 0$CUPS_LOG_FILE_PERM)
|
|
||||||
|
|
||||||
+dnl Default FatalErrors
|
|
||||||
+AC_ARG_WITH(fatal_errors, [ --with-fatal-errors set default FatalErrors value, default=config],
|
|
||||||
+ CUPS_FATAL_ERRORS="$withval",
|
|
||||||
+ CUPS_FATAL_ERRORS="config")
|
|
||||||
+AC_SUBST(CUPS_FATAL_ERRORS)
|
|
||||||
+AC_DEFINE_UNQUOTED(CUPS_DEFAULT_FATAL_ERRORS, "$CUPS_FATAL_ERRORS")
|
|
||||||
+
|
|
||||||
+
|
|
||||||
dnl Default Browsing
|
|
||||||
AC_ARG_ENABLE(browsing, [ --enable-browsing enable Browsing by default, default=yes])
|
|
||||||
if test "x$enable_browsing" = xno; then
|
|
||||||
diff -up cups-1.3.8/configure.str2536 cups-1.3.8/configure
|
|
||||||
--- cups-1.3.8/configure.str2536 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
+++ cups-1.3.8/configure 2008-09-10 16:18:16.000000000 +0100
|
|
||||||
@@ -782,6 +782,7 @@ LAUNCHDLIBS
|
|
||||||
LANGUAGES
|
|
||||||
CUPS_CONFIG_FILE_PERM
|
|
||||||
CUPS_LOG_FILE_PERM
|
|
||||||
+CUPS_FATAL_ERRORS
|
|
||||||
CUPS_BROWSING
|
|
||||||
CUPS_BROWSE_LOCAL_PROTOCOLS
|
|
||||||
CUPS_BROWSE_REMOTE_PROTOCOLS
|
|
||||||
@@ -1471,6 +1472,7 @@ Optional Packages:
|
|
||||||
--with-languages set installed languages, default=all
|
|
||||||
--with-config-file-perm set default ConfigFilePerm value, default=0640
|
|
||||||
--with-log-file-perm set default LogFilePerm value, default=0644
|
|
||||||
+ --with-fatal-errors set default FatalErrors value, default=config
|
|
||||||
--with-local-protocols set default BrowseLocalProtocols, default="CUPS"
|
|
||||||
--with-remote-protocols set default BrowseRemoteProtocols, default="CUPS"
|
|
||||||
--with-cups-user set default user for CUPS
|
|
||||||
@@ -9680,10 +9682,10 @@ case "$uname" in
|
|
||||||
;;
|
|
||||||
Linux* | GNU*)
|
|
||||||
# Linux and GNU Hurd
|
|
||||||
- MAN1EXT=1.gz
|
|
||||||
- MAN5EXT=5.gz
|
|
||||||
- MAN7EXT=7.gz
|
|
||||||
- MAN8EXT=8.gz
|
|
||||||
+ MAN1EXT=1
|
|
||||||
+ MAN5EXT=5
|
|
||||||
+ MAN7EXT=7
|
|
||||||
+ MAN8EXT=8
|
|
||||||
MAN8DIR=8
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
@@ -17624,6 +17626,21 @@ cat >>confdefs.h <<_ACEOF
|
|
||||||
_ACEOF
|
|
||||||
|
|
||||||
|
|
||||||
+
|
|
||||||
+# Check whether --with-fatal_errors was given.
|
|
||||||
+if test "${with_fatal_errors+set}" = set; then
|
|
||||||
+ withval=$with_fatal_errors; CUPS_FATAL_ERRORS="$withval"
|
|
||||||
+else
|
|
||||||
+ CUPS_FATAL_ERRORS="config"
|
|
||||||
+fi
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+cat >>confdefs.h <<_ACEOF
|
|
||||||
+#define CUPS_DEFAULT_FATAL_ERRORS "$CUPS_FATAL_ERRORS"
|
|
||||||
+_ACEOF
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+
|
|
||||||
# Check whether --enable-browsing was given.
|
|
||||||
if test "${enable_browsing+set}" = set; then
|
|
||||||
enableval=$enable_browsing;
|
|
||||||
@@ -19407,6 +19424,7 @@ LAUNCHDLIBS!$LAUNCHDLIBS$ac_delim
|
|
||||||
LANGUAGES!$LANGUAGES$ac_delim
|
|
||||||
CUPS_CONFIG_FILE_PERM!$CUPS_CONFIG_FILE_PERM$ac_delim
|
|
||||||
CUPS_LOG_FILE_PERM!$CUPS_LOG_FILE_PERM$ac_delim
|
|
||||||
+CUPS_FATAL_ERRORS!$CUPS_FATAL_ERRORS$ac_delim
|
|
||||||
CUPS_BROWSING!$CUPS_BROWSING$ac_delim
|
|
||||||
CUPS_BROWSE_LOCAL_PROTOCOLS!$CUPS_BROWSE_LOCAL_PROTOCOLS$ac_delim
|
|
||||||
CUPS_BROWSE_REMOTE_PROTOCOLS!$CUPS_BROWSE_REMOTE_PROTOCOLS$ac_delim
|
|
||||||
@@ -19432,7 +19450,6 @@ PHPCONFIG!$PHPCONFIG$ac_delim
|
|
||||||
PHPDIR!$PHPDIR$ac_delim
|
|
||||||
PYTHON!$PYTHON$ac_delim
|
|
||||||
INSTALL_LANGUAGES!$INSTALL_LANGUAGES$ac_delim
|
|
||||||
-UNINSTALL_LANGUAGES!$UNINSTALL_LANGUAGES$ac_delim
|
|
||||||
_ACEOF
|
|
||||||
|
|
||||||
if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 97; then
|
|
||||||
@@ -19474,11 +19491,12 @@ _ACEOF
|
|
||||||
ac_delim='%!_!# '
|
|
||||||
for ac_last_try in false false false false false :; do
|
|
||||||
cat >conf$$subs.sed <<_ACEOF
|
|
||||||
+UNINSTALL_LANGUAGES!$UNINSTALL_LANGUAGES$ac_delim
|
|
||||||
LIBOBJS!$LIBOBJS$ac_delim
|
|
||||||
LTLIBOBJS!$LTLIBOBJS$ac_delim
|
|
||||||
_ACEOF
|
|
||||||
|
|
||||||
- if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 2; then
|
|
||||||
+ if test `sed -n "s/.*$ac_delim\$/X/p" conf$$subs.sed | grep -c X` = 3; then
|
|
||||||
break
|
|
||||||
elif $ac_last_try; then
|
|
||||||
{ { echo "$as_me:$LINENO: error: could not make $CONFIG_STATUS" >&5
|
|
||||||
diff -up cups-1.3.8/doc/help/ref-cupsd-conf.html.in.str2536 cups-1.3.8/doc/help/ref-cupsd-conf.html.in
|
|
||||||
--- cups-1.3.8/doc/help/ref-cupsd-conf.html.in.str2536 2008-06-17 19:27:16.000000000 +0100
|
|
||||||
+++ cups-1.3.8/doc/help/ref-cupsd-conf.html.in 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
@@ -1115,6 +1115,57 @@ printer.</P>
|
|
||||||
</UL>
|
|
||||||
|
|
||||||
|
|
||||||
+
|
|
||||||
+<H2 CLASS="title"><SPAN CLASS="info">CUPS 1.4</SPAN><A NAME="FatalErrors">FatalErrors</A></H2>
|
|
||||||
+
|
|
||||||
+<H3>Examples</H3>
|
|
||||||
+
|
|
||||||
+<PRE CLASS="command">
|
|
||||||
+FatalErrors none
|
|
||||||
+FatalErrors all
|
|
||||||
+FatalErrors browse
|
|
||||||
+FatalErrors config
|
|
||||||
+FatalErrors listen
|
|
||||||
+FatalErrors log
|
|
||||||
+FatalErrors permissions
|
|
||||||
+FatalErrors all -permissions
|
|
||||||
+FatalErrors config permissions log
|
|
||||||
+</PRE>
|
|
||||||
+
|
|
||||||
+<H3>Description</H3>
|
|
||||||
+
|
|
||||||
+<P>The <CODE>FatalErrors</CODE> directive determines whether certain kinds of
|
|
||||||
+errors are fatal. The following kinds of errors are currently recognized:</P>
|
|
||||||
+
|
|
||||||
+<UL>
|
|
||||||
+
|
|
||||||
+ <LI><CODE>none</CODE> - No errors are fatal</LI>
|
|
||||||
+
|
|
||||||
+ <LI><CODE>all</CODE> - All of the errors below are fatal</LI>
|
|
||||||
+
|
|
||||||
+ <LI><CODE>browse</CODE> - Browsing initialization errors are fatal,
|
|
||||||
+ for example failed binding to the CUPS browse port or failed connections
|
|
||||||
+ to LDAP servers</LI>
|
|
||||||
+
|
|
||||||
+ <LI><CODE>config</CODE> - Configuration file syntax errors are
|
|
||||||
+ fatal</LI>
|
|
||||||
+
|
|
||||||
+ <LI><CODE>listen</CODE> - Listen or Port errors are fatal, except for
|
|
||||||
+ IPv6 failures on the loopback or "any" addresses</LI>
|
|
||||||
+
|
|
||||||
+ <LI><CODE>log</CODE> - Log file creation or write errors are fatal</LI>
|
|
||||||
+
|
|
||||||
+ <LI><CODE>permissions</CODE> - Bad startup file permissions are
|
|
||||||
+ fatal, for example shared SSL certificate and key files with world-
|
|
||||||
+ read permissions</LI>
|
|
||||||
+
|
|
||||||
+</UL>
|
|
||||||
+
|
|
||||||
+<P>Multiple errors can be listed, and the form "-kind" can be used with
|
|
||||||
+<CODE>all</CODE> to remove specific kinds of errors. The default setting is
|
|
||||||
+<CODE>@CUPS_FATAL_ERRORS@</CODE>.</P>
|
|
||||||
+
|
|
||||||
+
|
|
||||||
<H2 CLASS="title"><SPAN CLASS="info">CUPS 1.1.18</SPAN><A NAME="FileDevice">FileDevice</A></H2>
|
|
||||||
|
|
||||||
<H3>Examples</H3>
|
|
||||||
diff -up cups-1.3.8/man/cupsd.conf.man.in.str2536 cups-1.3.8/man/cupsd.conf.man.in
|
|
||||||
--- cups-1.3.8/man/cupsd.conf.man.in.str2536 2008-06-16 18:41:11.000000000 +0100
|
|
||||||
+++ cups-1.3.8/man/cupsd.conf.man.in 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
@@ -275,6 +275,15 @@ ErrorLog syslog
|
|
||||||
.br
|
|
||||||
Specifies the error log filename.
|
|
||||||
.TP 5
|
|
||||||
+FatalErrors none
|
|
||||||
+.TP 5
|
|
||||||
+FatalErrors all -kind [... -kind]
|
|
||||||
+.TP 5
|
|
||||||
+FatalErrors kind [... kind]
|
|
||||||
+.br
|
|
||||||
+Specifies which errors are fatal, causing the scheduler to exit. "Kind" is
|
|
||||||
+"browse", "config", "listen", "log", or "permissions".
|
|
||||||
+.TP 5
|
|
||||||
FileDevice Yes
|
|
||||||
.TP 5
|
|
||||||
FileDevice No
|
|
||||||
diff -up cups-1.3.8/scheduler/conf.c.str2536 cups-1.3.8/scheduler/conf.c
|
|
||||||
--- cups-1.3.8/scheduler/conf.c.str2536 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
+++ cups-1.3.8/scheduler/conf.c 2008-09-10 16:17:52.000000000 +0100
|
|
||||||
@@ -21,6 +21,7 @@
|
|
||||||
* get_addr_and_mask() - Get an IP address and netmask.
|
|
||||||
* parse_aaa() - Parse authentication, authorization, and
|
|
||||||
* access control lines.
|
|
||||||
+ * parse_fatal_errors() - Parse FatalErrors values in a string.
|
|
||||||
* parse_groups() - Parse system group names in a string.
|
|
||||||
* parse_protocols() - Parse browse protocols in a string.
|
|
||||||
* read_configuration() - Read a configuration file.
|
|
||||||
@@ -192,6 +193,7 @@ static int get_addr_and_mask(const char
|
|
||||||
unsigned *mask);
|
|
||||||
static int parse_aaa(cupsd_location_t *loc, char *line,
|
|
||||||
char *value, int linenum);
|
|
||||||
+static int parse_fatal_errors(const char *s);
|
|
||||||
static int parse_groups(const char *s);
|
|
||||||
static int parse_protocols(const char *s);
|
|
||||||
static int read_configuration(cups_file_t *fp);
|
|
||||||
@@ -512,6 +514,7 @@ cupsdReadConfiguration(void)
|
|
||||||
*/
|
|
||||||
|
|
||||||
ConfigFilePerm = CUPS_DEFAULT_CONFIG_FILE_PERM;
|
|
||||||
+ FatalErrors = parse_fatal_errors(CUPS_DEFAULT_FATAL_ERRORS);
|
|
||||||
DefaultAuthType = CUPSD_AUTH_BASIC;
|
|
||||||
#ifdef HAVE_SSL
|
|
||||||
DefaultEncryption = HTTP_ENCRYPT_REQUIRED;
|
|
||||||
@@ -782,30 +785,31 @@ cupsdReadConfiguration(void)
|
|
||||||
|
|
||||||
snprintf(temp, sizeof(temp), "%s/rss", CacheDir);
|
|
||||||
|
|
||||||
- if (cupsdCheckPermissions(RequestRoot, NULL, 0710, RunUser,
|
|
||||||
- Group, 1, 1) < 0 ||
|
|
||||||
- cupsdCheckPermissions(CacheDir, NULL, 0775, RunUser,
|
|
||||||
- Group, 1, 1) < 0 ||
|
|
||||||
- cupsdCheckPermissions(temp, NULL, 0775, RunUser,
|
|
||||||
- Group, 1, 1) < 0 ||
|
|
||||||
- cupsdCheckPermissions(StateDir, NULL, 0755, RunUser,
|
|
||||||
- Group, 1, 1) < 0 ||
|
|
||||||
- cupsdCheckPermissions(StateDir, "certs", RunUser ? 0711 : 0511, User,
|
|
||||||
- SystemGroupIDs[0], 1, 1) < 0 ||
|
|
||||||
- cupsdCheckPermissions(ServerRoot, NULL, 0755, RunUser,
|
|
||||||
- Group, 1, 0) < 0 ||
|
|
||||||
- cupsdCheckPermissions(ServerRoot, "ppd", 0755, RunUser,
|
|
||||||
- Group, 1, 1) < 0 ||
|
|
||||||
- cupsdCheckPermissions(ServerRoot, "ssl", 0700, RunUser,
|
|
||||||
- Group, 1, 0) < 0 ||
|
|
||||||
- cupsdCheckPermissions(ServerRoot, "cupsd.conf", ConfigFilePerm, RunUser,
|
|
||||||
- Group, 0, 0) < 0 ||
|
|
||||||
- cupsdCheckPermissions(ServerRoot, "classes.conf", 0600, RunUser,
|
|
||||||
- Group, 0, 0) < 0 ||
|
|
||||||
- cupsdCheckPermissions(ServerRoot, "printers.conf", 0600, RunUser,
|
|
||||||
- Group, 0, 0) < 0 ||
|
|
||||||
- cupsdCheckPermissions(ServerRoot, "passwd.md5", 0600, User,
|
|
||||||
- Group, 0, 0) < 0)
|
|
||||||
+ if ((cupsdCheckPermissions(RequestRoot, NULL, 0710, RunUser,
|
|
||||||
+ Group, 1, 1) < 0 ||
|
|
||||||
+ cupsdCheckPermissions(CacheDir, NULL, 0775, RunUser,
|
|
||||||
+ Group, 1, 1) < 0 ||
|
|
||||||
+ cupsdCheckPermissions(temp, NULL, 0775, RunUser,
|
|
||||||
+ Group, 1, 1) < 0 ||
|
|
||||||
+ cupsdCheckPermissions(StateDir, NULL, 0755, RunUser,
|
|
||||||
+ Group, 1, 1) < 0 ||
|
|
||||||
+ cupsdCheckPermissions(StateDir, "certs", RunUser ? 0711 : 0511, User,
|
|
||||||
+ SystemGroupIDs[0], 1, 1) < 0 ||
|
|
||||||
+ cupsdCheckPermissions(ServerRoot, NULL, 0755, RunUser,
|
|
||||||
+ Group, 1, 0) < 0 ||
|
|
||||||
+ cupsdCheckPermissions(ServerRoot, "ppd", 0755, RunUser,
|
|
||||||
+ Group, 1, 1) < 0 ||
|
|
||||||
+ cupsdCheckPermissions(ServerRoot, "ssl", 0700, RunUser,
|
|
||||||
+ Group, 1, 0) < 0 ||
|
|
||||||
+ cupsdCheckPermissions(ServerRoot, "cupsd.conf", ConfigFilePerm, RunUser,
|
|
||||||
+ Group, 0, 0) < 0 ||
|
|
||||||
+ cupsdCheckPermissions(ServerRoot, "classes.conf", 0600, RunUser,
|
|
||||||
+ Group, 0, 0) < 0 ||
|
|
||||||
+ cupsdCheckPermissions(ServerRoot, "printers.conf", 0600, RunUser,
|
|
||||||
+ Group, 0, 0) < 0 ||
|
|
||||||
+ cupsdCheckPermissions(ServerRoot, "passwd.md5", 0600, User,
|
|
||||||
+ Group, 0, 0) < 0) &&
|
|
||||||
+ FatalErrors & CUPSD_FATAL_PERMISSIONS)
|
|
||||||
return (0);
|
|
||||||
|
|
||||||
/*
|
|
||||||
@@ -855,7 +859,8 @@ cupsdReadConfiguration(void)
|
|
||||||
* is under the spool directory or does not exist...
|
|
||||||
*/
|
|
||||||
|
|
||||||
- if (cupsdCheckPermissions(TempDir, NULL, 01770, RunUser, Group, 1, 1) < 0)
|
|
||||||
+ if (cupsdCheckPermissions(TempDir, NULL, 01770, RunUser, Group, 1, 1) < 0 &&
|
|
||||||
+ (FatalErrors & CUPSD_FATAL_PERMISSIONS))
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -872,8 +877,10 @@ cupsdReadConfiguration(void)
|
|
||||||
if (MaxClients > (MaxFDs / 3) || MaxClients <= 0)
|
|
||||||
{
|
|
||||||
if (MaxClients > 0)
|
|
||||||
- cupsdLogMessage(CUPSD_LOG_INFO, "MaxClients limited to 1/3 (%d) of the file descriptor limit (%d)...",
|
|
||||||
- MaxFDs / 3, MaxFDs);
|
|
||||||
+ cupsdLogMessage(CUPSD_LOG_INFO,
|
|
||||||
+ "MaxClients limited to 1/3 (%d) of the file descriptor "
|
|
||||||
+ "limit (%d)...",
|
|
||||||
+ MaxFDs / 3, MaxFDs);
|
|
||||||
|
|
||||||
MaxClients = MaxFDs / 3;
|
|
||||||
}
|
|
||||||
@@ -1115,7 +1122,8 @@ cupsdReadConfiguration(void)
|
|
||||||
{
|
|
||||||
cupsdLogMessage(CUPSD_LOG_EMERG,
|
|
||||||
"Unable to load MIME database from \'%s\'!", ServerRoot);
|
|
||||||
- exit(errno);
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_CONFIG)
|
|
||||||
+ return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
cupsdLogMessage(CUPSD_LOG_INFO,
|
|
||||||
@@ -1912,6 +1920,86 @@ parse_aaa(cupsd_location_t *loc, /* I -
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * 'parse_fatal_errors()' - Parse FatalErrors values in a string.
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+static int /* O - FatalErrors bits */
|
|
||||||
+parse_fatal_errors(const char *s) /* I - FatalErrors string */
|
|
||||||
+{
|
|
||||||
+ int fatal; /* FatalErrors bits */
|
|
||||||
+ char value[1024], /* Value string */
|
|
||||||
+ *valstart, /* Pointer into value */
|
|
||||||
+ *valend; /* End of value */
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * Empty FatalErrors line yields NULL pointer...
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+ if (!s)
|
|
||||||
+ return (CUPSD_FATAL_NONE);
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * Loop through the value string,...
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+ strlcpy(value, s, sizeof(value));
|
|
||||||
+
|
|
||||||
+ fatal = CUPSD_FATAL_NONE;
|
|
||||||
+
|
|
||||||
+ for (valstart = value; *valstart;)
|
|
||||||
+ {
|
|
||||||
+ /*
|
|
||||||
+ * Get the current space/comma-delimited kind name...
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+ for (valend = valstart; *valend; valend ++)
|
|
||||||
+ if (isspace(*valend & 255) || *valend == ',')
|
|
||||||
+ break;
|
|
||||||
+
|
|
||||||
+ if (*valend)
|
|
||||||
+ *valend++ = '\0';
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * Add the error to the bitmask...
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+ if (!strcasecmp(valstart, "all"))
|
|
||||||
+ fatal = CUPSD_FATAL_ALL;
|
|
||||||
+ else if (!strcasecmp(valstart, "browse"))
|
|
||||||
+ fatal |= CUPSD_FATAL_BROWSE;
|
|
||||||
+ else if (!strcasecmp(valstart, "-browse"))
|
|
||||||
+ fatal &= ~CUPSD_FATAL_BROWSE;
|
|
||||||
+ else if (!strcasecmp(valstart, "config"))
|
|
||||||
+ fatal |= CUPSD_FATAL_CONFIG;
|
|
||||||
+ else if (!strcasecmp(valstart, "-config"))
|
|
||||||
+ fatal &= ~CUPSD_FATAL_CONFIG;
|
|
||||||
+ else if (!strcasecmp(valstart, "listen"))
|
|
||||||
+ fatal |= CUPSD_FATAL_LISTEN;
|
|
||||||
+ else if (!strcasecmp(valstart, "-listen"))
|
|
||||||
+ fatal &= ~CUPSD_FATAL_LISTEN;
|
|
||||||
+ else if (!strcasecmp(valstart, "log"))
|
|
||||||
+ fatal |= CUPSD_FATAL_LOG;
|
|
||||||
+ else if (!strcasecmp(valstart, "-log"))
|
|
||||||
+ fatal &= ~CUPSD_FATAL_LOG;
|
|
||||||
+ else if (!strcasecmp(valstart, "permissions"))
|
|
||||||
+ fatal |= CUPSD_FATAL_PERMISSIONS;
|
|
||||||
+ else if (!strcasecmp(valstart, "-permissions"))
|
|
||||||
+ fatal &= ~CUPSD_FATAL_PERMISSIONS;
|
|
||||||
+ else if (strcasecmp(valstart, "none"))
|
|
||||||
+ cupsdLogMessage(CUPSD_LOG_ERROR,
|
|
||||||
+ "Unknown FatalErrors kind \"%s\" ignored!", valstart);
|
|
||||||
+
|
|
||||||
+ for (valstart = valend; *valstart; valstart ++)
|
|
||||||
+ if (!isspace(*valstart & 255) || *valstart != ',')
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ return (fatal);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* 'parse_groups()' - Parse system group names in a string.
|
|
||||||
*/
|
|
||||||
|
|
||||||
@@ -2740,7 +2828,8 @@ read_configuration(cups_file_t *fp) /* I
|
|
||||||
cupsdLogMessage(CUPSD_LOG_WARN,
|
|
||||||
"Unknown default authorization type %s on line %d.",
|
|
||||||
value, linenum);
|
|
||||||
- return (0);
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_CONFIG)
|
|
||||||
+ return (0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#ifdef HAVE_SSL
|
|
||||||
@@ -2761,7 +2850,8 @@ read_configuration(cups_file_t *fp) /* I
|
|
||||||
cupsdLogMessage(CUPSD_LOG_WARN,
|
|
||||||
"Unknown default encryption %s on line %d.",
|
|
||||||
value, linenum);
|
|
||||||
- return (0);
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_CONFIG)
|
|
||||||
+ return (0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif /* HAVE_SSL */
|
|
||||||
@@ -3148,7 +3238,8 @@ read_location(cups_file_t *fp, /* I - C
|
|
||||||
if (!value)
|
|
||||||
{
|
|
||||||
cupsdLogMessage(CUPSD_LOG_ERROR, "Syntax error on line %d.", linenum);
|
|
||||||
- return (0);
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_CONFIG)
|
|
||||||
+ return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((loc = cupsdCopyLocation(&parent)) == NULL)
|
|
||||||
@@ -3196,7 +3287,8 @@ read_location(cups_file_t *fp, /* I - C
|
|
||||||
cupsdLogMessage(CUPSD_LOG_ERROR,
|
|
||||||
"Unknown Location directive %s on line %d.",
|
|
||||||
line, linenum);
|
|
||||||
- return (0);
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_CONFIG)
|
|
||||||
+ return (0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -3204,7 +3296,7 @@ read_location(cups_file_t *fp, /* I - C
|
|
||||||
"Unexpected end-of-file at line %d while reading location!",
|
|
||||||
linenum);
|
|
||||||
|
|
||||||
- return (0);
|
|
||||||
+ return ((FatalErrors & CUPSD_FATAL_CONFIG) ? 0 : linenum);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@@ -3262,7 +3354,8 @@ read_policy(cups_file_t *fp, /* I - Con
|
|
||||||
if (!value)
|
|
||||||
{
|
|
||||||
cupsdLogMessage(CUPSD_LOG_ERROR, "Syntax error on line %d.", linenum);
|
|
||||||
- return (0);
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_CONFIG)
|
|
||||||
+ return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
@@ -3336,7 +3429,8 @@ read_policy(cups_file_t *fp, /* I - Con
|
|
||||||
cupsdLogMessage(CUPSD_LOG_ERROR,
|
|
||||||
"Missing <Limit ops> directive before %s on line %d.",
|
|
||||||
line, linenum);
|
|
||||||
- return (0);
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_CONFIG)
|
|
||||||
+ return (0);
|
|
||||||
}
|
|
||||||
else if (!parse_aaa(op, line, value, linenum))
|
|
||||||
{
|
|
||||||
@@ -3349,7 +3443,8 @@ read_policy(cups_file_t *fp, /* I - Con
|
|
||||||
"Unknown Policy directive %s on line %d.",
|
|
||||||
line, linenum);
|
|
||||||
|
|
||||||
- return (0);
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_CONFIG)
|
|
||||||
+ return (0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -3357,7 +3452,7 @@ read_policy(cups_file_t *fp, /* I - Con
|
|
||||||
"Unexpected end-of-file at line %d while reading policy \"%s\"!",
|
|
||||||
linenum, policy);
|
|
||||||
|
|
||||||
- return (0);
|
|
||||||
+ return ((FatalErrors & CUPSD_FATAL_CONFIG) ? 0 : linenum);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
diff -up cups-1.3.8/scheduler/conf.h.str2536 cups-1.3.8/scheduler/conf.h
|
|
||||||
--- cups-1.3.8/scheduler/conf.h.str2536 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
+++ cups-1.3.8/scheduler/conf.h 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
@@ -38,6 +38,19 @@ typedef enum
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * FatalErrors flags...
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+#define CUPSD_FATAL_NONE 0 /* No errors are fatal */
|
|
||||||
+#define CUPSD_FATAL_BROWSE 1 /* Browse bind errors are fatal */
|
|
||||||
+#define CUPSD_FATAL_CONFIG 2 /* Config file syntax errors are fatal */
|
|
||||||
+#define CUPSD_FATAL_LISTEN 4 /* Listen/Port bind errors are fatal */
|
|
||||||
+#define CUPSD_FATAL_LOG 8 /* Log file errors are fatal */
|
|
||||||
+#define CUPSD_FATAL_PERMISSIONS 16 /* File permission errors are fatal */
|
|
||||||
+#define CUPSD_FATAL_ALL ~0 /* All errors are fatal */
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* Printcap formats...
|
|
||||||
*/
|
|
||||||
|
|
||||||
@@ -124,6 +137,8 @@ VAR int ClassifyOverride VALUE(0),
|
|
||||||
/* Allow overrides? */
|
|
||||||
ConfigFilePerm VALUE(0640),
|
|
||||||
/* Permissions for config files */
|
|
||||||
+ FatalErrors VALUE(CUPSD_FATAL_CONFIG),
|
|
||||||
+ /* Which errors are fatal? */
|
|
||||||
LogFilePerm VALUE(0644),
|
|
||||||
/* Permissions for log files */
|
|
||||||
LogLevel VALUE(CUPSD_LOG_ERROR),
|
|
||||||
diff -up cups-1.3.8/scheduler/dirsvc.c.str2536 cups-1.3.8/scheduler/dirsvc.c
|
|
||||||
--- cups-1.3.8/scheduler/dirsvc.c.str2536 2008-07-18 21:30:23.000000000 +0100
|
|
||||||
+++ cups-1.3.8/scheduler/dirsvc.c 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
@@ -954,9 +954,14 @@ cupsdStartBrowsing(void)
|
|
||||||
strerror(errno));
|
|
||||||
BrowseLocalProtocols &= ~BROWSE_CUPS;
|
|
||||||
BrowseRemoteProtocols &= ~BROWSE_CUPS;
|
|
||||||
- return;
|
|
||||||
+
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_BROWSE)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
}
|
|
||||||
+ }
|
|
||||||
|
|
||||||
+ if (BrowseSocket >= 0)
|
|
||||||
+ {
|
|
||||||
/*
|
|
||||||
* Bind the socket to browse port...
|
|
||||||
*/
|
|
||||||
@@ -981,50 +986,60 @@ cupsdStartBrowsing(void)
|
|
||||||
BrowseSocket = -1;
|
|
||||||
BrowseLocalProtocols &= ~BROWSE_CUPS;
|
|
||||||
BrowseRemoteProtocols &= ~BROWSE_CUPS;
|
|
||||||
- return;
|
|
||||||
+
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_BROWSE)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- /*
|
|
||||||
- * Set the "broadcast" flag...
|
|
||||||
- */
|
|
||||||
-
|
|
||||||
- val = 1;
|
|
||||||
- if (setsockopt(BrowseSocket, SOL_SOCKET, SO_BROADCAST, &val, sizeof(val)))
|
|
||||||
+ if (BrowseSocket >= 0)
|
|
||||||
{
|
|
||||||
- cupsdLogMessage(CUPSD_LOG_ERROR, "Unable to set broadcast mode - %s.",
|
|
||||||
- strerror(errno));
|
|
||||||
+ /*
|
|
||||||
+ * Set the "broadcast" flag...
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+ val = 1;
|
|
||||||
+ if (setsockopt(BrowseSocket, SOL_SOCKET, SO_BROADCAST, &val, sizeof(val)))
|
|
||||||
+ {
|
|
||||||
+ cupsdLogMessage(CUPSD_LOG_ERROR, "Unable to set broadcast mode - %s.",
|
|
||||||
+ strerror(errno));
|
|
||||||
|
|
||||||
#ifdef WIN32
|
|
||||||
- closesocket(BrowseSocket);
|
|
||||||
+ closesocket(BrowseSocket);
|
|
||||||
#else
|
|
||||||
- close(BrowseSocket);
|
|
||||||
+ close(BrowseSocket);
|
|
||||||
#endif /* WIN32 */
|
|
||||||
|
|
||||||
- BrowseSocket = -1;
|
|
||||||
- BrowseLocalProtocols &= ~BROWSE_CUPS;
|
|
||||||
- BrowseRemoteProtocols &= ~BROWSE_CUPS;
|
|
||||||
- return;
|
|
||||||
- }
|
|
||||||
+ BrowseSocket = -1;
|
|
||||||
+ BrowseLocalProtocols &= ~BROWSE_CUPS;
|
|
||||||
+ BrowseRemoteProtocols &= ~BROWSE_CUPS;
|
|
||||||
|
|
||||||
- /*
|
|
||||||
- * Close the socket on exec...
|
|
||||||
- */
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_BROWSE)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
|
|
||||||
- fcntl(BrowseSocket, F_SETFD, fcntl(BrowseSocket, F_GETFD) | FD_CLOEXEC);
|
|
||||||
+ if (BrowseSocket >= 0)
|
|
||||||
+ {
|
|
||||||
+ /*
|
|
||||||
+ * Close the socket on exec...
|
|
||||||
+ */
|
|
||||||
|
|
||||||
- /*
|
|
||||||
- * Finally, add the socket to the input selection set as needed...
|
|
||||||
- */
|
|
||||||
+ fcntl(BrowseSocket, F_SETFD, fcntl(BrowseSocket, F_GETFD) | FD_CLOEXEC);
|
|
||||||
|
|
||||||
- if (BrowseRemoteProtocols & BROWSE_CUPS)
|
|
||||||
- {
|
|
||||||
/*
|
|
||||||
- * We only listen if we want remote printers...
|
|
||||||
+ * Finally, add the socket to the input selection set as needed...
|
|
||||||
*/
|
|
||||||
|
|
||||||
- cupsdAddSelect(BrowseSocket, (cupsd_selfunc_t)update_cups_browse,
|
|
||||||
- NULL, NULL);
|
|
||||||
+ if (BrowseRemoteProtocols & BROWSE_CUPS)
|
|
||||||
+ {
|
|
||||||
+ /*
|
|
||||||
+ * We only listen if we want remote printers...
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+ cupsdAddSelect(BrowseSocket, (cupsd_selfunc_t)update_cups_browse,
|
|
||||||
+ NULL, NULL);
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
@@ -1043,6 +1058,10 @@ cupsdStartBrowsing(void)
|
|
||||||
"Unable to open an SLP handle; disabling SLP browsing!");
|
|
||||||
BrowseLocalProtocols &= ~BROWSE_SLP;
|
|
||||||
BrowseRemoteProtocols &= ~BROWSE_SLP;
|
|
||||||
+ BrowseSLPHandle = NULL;
|
|
||||||
+
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_BROWSE)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
BrowseSLPRefresh = 0;
|
|
||||||
@@ -1060,6 +1079,9 @@ cupsdStartBrowsing(void)
|
|
||||||
"Need to set BrowseLDAPDN to use LDAP browsing!");
|
|
||||||
BrowseLocalProtocols &= ~BROWSE_LDAP;
|
|
||||||
BrowseRemoteProtocols &= ~BROWSE_LDAP;
|
|
||||||
+
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_BROWSE)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
@@ -1105,6 +1127,9 @@ cupsdStartBrowsing(void)
|
|
||||||
"Unable to initialize LDAP; disabling LDAP browsing!");
|
|
||||||
BrowseLocalProtocols &= ~BROWSE_LDAP;
|
|
||||||
BrowseRemoteProtocols &= ~BROWSE_LDAP;
|
|
||||||
+
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_BROWSE)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
}
|
|
||||||
else if (ldap_set_option(BrowseLDAPHandle, LDAP_OPT_PROTOCOL_VERSION,
|
|
||||||
(const void *)&version) != LDAP_SUCCESS)
|
|
||||||
@@ -1116,6 +1141,9 @@ cupsdStartBrowsing(void)
|
|
||||||
"disabling LDAP browsing!");
|
|
||||||
BrowseLocalProtocols &= ~BROWSE_LDAP;
|
|
||||||
BrowseRemoteProtocols &= ~BROWSE_LDAP;
|
|
||||||
+
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_BROWSE)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
@@ -1134,6 +1162,9 @@ cupsdStartBrowsing(void)
|
|
||||||
ldap_unbind_ext(BrowseLDAPHandle, NULL, NULL);
|
|
||||||
BrowseLocalProtocols &= ~BROWSE_LDAP;
|
|
||||||
BrowseRemoteProtocols &= ~BROWSE_LDAP;
|
|
||||||
+
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_BROWSE)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
diff -up cups-1.3.8/scheduler/listen.c.str2536 cups-1.3.8/scheduler/listen.c
|
|
||||||
--- cups-1.3.8/scheduler/listen.c.str2536 2007-08-13 18:20:14.000000000 +0100
|
|
||||||
+++ cups-1.3.8/scheduler/listen.c 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
@@ -150,10 +150,15 @@ cupsdStartListening(void)
|
|
||||||
httpAddrFreeList(ServerAddrs);
|
|
||||||
|
|
||||||
if ((ServerAddrs = httpAddrGetList(ServerName, AF_UNSPEC, NULL)) == NULL)
|
|
||||||
+ {
|
|
||||||
cupsdLogMessage(CUPSD_LOG_ERROR,
|
|
||||||
"Unable to find IP address for server name \"%s\"!\n",
|
|
||||||
ServerName);
|
|
||||||
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_LISTEN)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
/*
|
|
||||||
* Setup socket listeners...
|
|
||||||
*/
|
|
||||||
@@ -194,6 +199,20 @@ cupsdStartListening(void)
|
|
||||||
cupsdLogMessage(CUPSD_LOG_ERROR,
|
|
||||||
"Unable to open listen socket for address %s:%d - %s.",
|
|
||||||
s, p, strerror(errno));
|
|
||||||
+
|
|
||||||
+#ifdef AF_INET6
|
|
||||||
+ /*
|
|
||||||
+ * IPv6 is often disabled while DNS returns IPv6 addresses...
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+ if (lis->address.addr.sa_family != AF_INET6 &&
|
|
||||||
+ (FatalErrors & CUPSD_FATAL_LISTEN))
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
+#else
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_LISTEN)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
+#endif /* AF_INET6 */
|
|
||||||
+
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -278,6 +297,10 @@ cupsdStartListening(void)
|
|
||||||
s, p, strerror(errno));
|
|
||||||
close(lis->fd);
|
|
||||||
lis->fd = -1;
|
|
||||||
+
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_LISTEN)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
+
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -290,7 +313,14 @@ cupsdStartListening(void)
|
|
||||||
cupsdLogMessage(CUPSD_LOG_ERROR,
|
|
||||||
"Unable to listen for clients on address %s:%d - %s.",
|
|
||||||
s, p, strerror(errno));
|
|
||||||
- exit(errno);
|
|
||||||
+
|
|
||||||
+ close(lis->fd);
|
|
||||||
+ lis->fd = -1;
|
|
||||||
+
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_LISTEN)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
+
|
|
||||||
+ continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -339,11 +369,8 @@ cupsdStartListening(void)
|
|
||||||
"No Listen or Port lines were found to allow access via "
|
|
||||||
"localhost!");
|
|
||||||
|
|
||||||
- /*
|
|
||||||
- * Commit suicide...
|
|
||||||
- */
|
|
||||||
-
|
|
||||||
- cupsdEndProcess(getpid(), 0);
|
|
||||||
+ if (FatalErrors & (CUPSD_FATAL_CONFIG | CUPSD_FATAL_LISTEN))
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
diff -up cups-1.3.8/scheduler/log.c.str2536 cups-1.3.8/scheduler/log.c
|
|
||||||
--- cups-1.3.8/scheduler/log.c.str2536 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
+++ cups-1.3.8/scheduler/log.c 2008-09-10 16:16:44.000000000 +0100
|
|
||||||
@@ -546,7 +546,20 @@ check_log_file(cups_file_t **lf, /* IO -
|
|
||||||
|
|
||||||
if (!strncmp(filename, CUPS_LOGDIR, strlen(CUPS_LOGDIR)))
|
|
||||||
{
|
|
||||||
- cupsdCheckPermissions(CUPS_LOGDIR, NULL, 0755, RunUser, Group, 1, -1);
|
|
||||||
+ /*
|
|
||||||
+ * Try updating the permissions of the containing log directory, using
|
|
||||||
+ * the log file permissions as a basis...
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+ int log_dir_perm = 0300 | LogFilePerm;
|
|
||||||
+ /* LogFilePerm + owner write/search */
|
|
||||||
+ if (log_dir_perm & 0040)
|
|
||||||
+ log_dir_perm |= 0010; /* Add group search */
|
|
||||||
+ if (log_dir_perm & 0004)
|
|
||||||
+ log_dir_perm |= 0001; /* Add other search */
|
|
||||||
+
|
|
||||||
+ cupsdCheckPermissions(CUPS_LOGDIR, NULL, log_dir_perm, RunUser, Group,
|
|
||||||
+ 1, -1);
|
|
||||||
|
|
||||||
*lf = cupsFileOpen(filename, "a");
|
|
||||||
}
|
|
||||||
@@ -555,6 +568,10 @@ check_log_file(cups_file_t **lf, /* IO -
|
|
||||||
{
|
|
||||||
syslog(LOG_ERR, "Unable to open log file \"%s\" - %s", filename,
|
|
||||||
strerror(errno));
|
|
||||||
+
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_LOG)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
+
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -622,6 +639,9 @@ check_log_file(cups_file_t **lf, /* IO -
|
|
||||||
syslog(LOG_ERR, "Unable to open log file \"%s\" - %s", filename,
|
|
||||||
strerror(errno));
|
|
||||||
|
|
||||||
+ if (FatalErrors & CUPSD_FATAL_LOG)
|
|
||||||
+ cupsdEndProcess(getpid(), 0);
|
|
||||||
+
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
@ -1,8 +1,8 @@
|
|||||||
diff -up cups-1.3.7/backend/usb-unix.c.usb-paperout cups-1.3.7/backend/usb-unix.c
|
diff -up cups-1.4b1/backend/usb-unix.c.usb-paperout cups-1.4b1/backend/usb-unix.c
|
||||||
--- cups-1.3.7/backend/usb-unix.c.usb-paperout 2008-07-15 13:47:33.000000000 +0100
|
--- cups-1.4b1/backend/usb-unix.c.usb-paperout 2008-11-12 09:30:03.000000000 +0000
|
||||||
+++ cups-1.3.7/backend/usb-unix.c 2008-07-15 13:47:33.000000000 +0100
|
+++ cups-1.4b1/backend/usb-unix.c 2008-11-12 09:30:03.000000000 +0000
|
||||||
@@ -31,6 +31,11 @@
|
@@ -30,6 +30,11 @@
|
||||||
#include "ieee1284.c"
|
|
||||||
#include <sys/select.h>
|
#include <sys/select.h>
|
||||||
|
|
||||||
+#ifdef __linux
|
+#ifdef __linux
|
||||||
@ -13,7 +13,7 @@ diff -up cups-1.3.7/backend/usb-unix.c.usb-paperout cups-1.3.7/backend/usb-unix.
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Local functions...
|
* Local functions...
|
||||||
@@ -323,7 +328,19 @@ open_device(const char *uri, /* I - Dev
|
@@ -324,7 +329,19 @@ open_device(const char *uri, /* I - Dev
|
||||||
if (!strncmp(uri, "usb:/dev/", 9))
|
if (!strncmp(uri, "usb:/dev/", 9))
|
||||||
#ifdef __linux
|
#ifdef __linux
|
||||||
{
|
{
|
||||||
@ -34,7 +34,7 @@ diff -up cups-1.3.7/backend/usb-unix.c.usb-paperout cups-1.3.7/backend/usb-unix.
|
|||||||
}
|
}
|
||||||
else if (!strncmp(uri, "usb://", 6))
|
else if (!strncmp(uri, "usb://", 6))
|
||||||
{
|
{
|
||||||
@@ -389,7 +406,14 @@ open_device(const char *uri, /* I - Dev
|
@@ -390,7 +407,14 @@ open_device(const char *uri, /* I - Dev
|
||||||
if (!strcmp(uri, device_uri))
|
if (!strcmp(uri, device_uri))
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
--- cups-1.2.3/cups/http.c.wbuffer 2006-09-13 16:41:57.000000000 +0100
|
diff -up cups-1.4b1/cups/http.c.wbuffer cups-1.4b1/cups/http.c
|
||||||
+++ cups-1.2.3/cups/http.c 2006-09-13 16:42:23.000000000 +0100
|
--- cups-1.4b1/cups/http.c.wbuffer 2008-08-20 01:07:25.000000000 +0100
|
||||||
@@ -1886,7 +1886,7 @@
|
+++ cups-1.4b1/cups/http.c 2008-11-12 09:13:29.000000000 +0000
|
||||||
|
@@ -2166,7 +2166,7 @@ httpWrite2(http_t *http, /* I - Con
|
||||||
|
|
||||||
if (length > 0)
|
if (length > 0)
|
||||||
{
|
{
|
||||||
- if (http->wused && (length + http->wused) > sizeof(http->wbuffer))
|
- if (http->wused && (length + http->wused) > sizeof(http->wbuffer))
|
||||||
+ if (http->wused && (length + http->wused) >= sizeof(http->wbuffer))
|
+ if (http->wused && (length + http->wused) >= sizeof(http->wbuffer))
|
||||||
{
|
{
|
||||||
DEBUG_printf((" flushing buffer (wused=%d, length=%d)\n",
|
DEBUG_printf(("httpWrite2: Flushing buffer (wused=%d, length="
|
||||||
http->wused, length));
|
CUPS_LLFMT ")\n", http->wused, CUPS_LLCAST length));
|
||||||
|
90
cups.spec
90
cups.spec
@ -1,4 +1,4 @@
|
|||||||
#define svn 7370
|
%define pre b1
|
||||||
%define initdir /etc/rc.d/init.d
|
%define initdir /etc/rc.d/init.d
|
||||||
%define use_alternatives 1
|
%define use_alternatives 1
|
||||||
%define lspp 1
|
%define lspp 1
|
||||||
@ -6,11 +6,11 @@
|
|||||||
|
|
||||||
Summary: Common Unix Printing System
|
Summary: Common Unix Printing System
|
||||||
Name: cups
|
Name: cups
|
||||||
Version: 1.3.9
|
Version: 1.4
|
||||||
Release: 3%{?svn:.svn%{svn}}%{?dist}
|
Release: 0.%{pre}.1%{?dist}
|
||||||
License: GPLv2
|
License: GPLv2
|
||||||
Group: System Environment/Daemons
|
Group: System Environment/Daemons
|
||||||
Source: ftp://ftp.easysw.com/pub/cups/test//cups-%{version}%{?svn:svn-r%{svn}}-source.tar.bz2
|
Source: ftp://ftp.easysw.com/pub/cups/test//cups-%{version}%{?pre}-source.tar.bz2
|
||||||
Source1: cups.init
|
Source1: cups.init
|
||||||
Source2: cupsprinter.png
|
Source2: cupsprinter.png
|
||||||
Source3: http://www.openprinting.org/download/printing/dnssd
|
Source3: http://www.openprinting.org/download/printing/dnssd
|
||||||
@ -22,14 +22,11 @@ Source8: postscript.ppd.gz
|
|||||||
Source9: cups.logrotate
|
Source9: cups.logrotate
|
||||||
Source10: ncp.backend
|
Source10: ncp.backend
|
||||||
Source12: cups.cron
|
Source12: cups.cron
|
||||||
Source13: pdftops.conf
|
|
||||||
Source14: textonly.filter
|
Source14: textonly.filter
|
||||||
Source15: textonly.ppd
|
Source15: textonly.ppd
|
||||||
Patch1: cups-no-gzip-man.patch
|
Patch1: cups-no-gzip-man.patch
|
||||||
Patch2: cups-1.1.16-system-auth.patch
|
Patch2: cups-1.1.16-system-auth.patch
|
||||||
Patch3: cups-multilib.patch
|
Patch3: cups-multilib.patch
|
||||||
Patch4: cups-ext.patch
|
|
||||||
Patch5: cups-includeifexists.patch
|
|
||||||
Patch6: cups-banners.patch
|
Patch6: cups-banners.patch
|
||||||
Patch7: cups-serverbin-compat.patch
|
Patch7: cups-serverbin-compat.patch
|
||||||
Patch8: cups-no-export-ssllibs.patch
|
Patch8: cups-no-export-ssllibs.patch
|
||||||
@ -39,16 +36,13 @@ Patch11: cups-direct-usb.patch
|
|||||||
Patch12: cups-lpr-help.patch
|
Patch12: cups-lpr-help.patch
|
||||||
Patch13: cups-peercred.patch
|
Patch13: cups-peercred.patch
|
||||||
Patch14: cups-pid.patch
|
Patch14: cups-pid.patch
|
||||||
Patch15: cups-foomatic-recommended.patch
|
|
||||||
Patch16: cups-eggcups.patch
|
Patch16: cups-eggcups.patch
|
||||||
Patch17: cups-getpass.patch
|
Patch17: cups-getpass.patch
|
||||||
Patch18: cups-driverd-timeout.patch
|
Patch18: cups-driverd-timeout.patch
|
||||||
Patch19: cups-strict-ppd-line-length.patch
|
Patch19: cups-strict-ppd-line-length.patch
|
||||||
Patch20: cups-logrotate.patch
|
Patch20: cups-logrotate.patch
|
||||||
Patch21: cups-usb-paperout.patch
|
Patch21: cups-usb-paperout.patch
|
||||||
Patch22: cups-getnameddest.patch
|
Patch22: cups-build.patch
|
||||||
Patch23: cups-str2101.patch
|
|
||||||
Patch24: cups-str2536.patch
|
|
||||||
Patch100: cups-lspp.patch
|
Patch100: cups-lspp.patch
|
||||||
Epoch: 1
|
Epoch: 1
|
||||||
Url: http://www.cups.org/
|
Url: http://www.cups.org/
|
||||||
@ -59,14 +53,17 @@ Requires: %{name}-libs = %{epoch}:%{version}-%{release}
|
|||||||
Provides: /usr/bin/lpq /usr/bin/lpr /usr/bin/lp /usr/bin/cancel /usr/bin/lprm /usr/bin/lpstat
|
Provides: /usr/bin/lpq /usr/bin/lpr /usr/bin/lp /usr/bin/cancel /usr/bin/lprm /usr/bin/lpstat
|
||||||
Prereq: /usr/sbin/alternatives
|
Prereq: /usr/sbin/alternatives
|
||||||
%endif
|
%endif
|
||||||
%if %{?svn:1}%{!?svn:0}
|
|
||||||
Requires: poppler-utils
|
Requires: poppler-utils
|
||||||
%endif
|
|
||||||
|
|
||||||
# Unconditionally obsolete LPRng so that upgrades work properly.
|
# Unconditionally obsolete LPRng so that upgrades work properly.
|
||||||
Obsoletes: lpd lpr LPRng <= 3.8.15-3
|
Obsoletes: lpd lpr LPRng <= 3.8.15-3
|
||||||
Provides: lpd lpr
|
Provides: lpd lpr
|
||||||
|
|
||||||
|
Obsoletes: cupsddk < 1.2.3-6
|
||||||
|
Provides: cupsddk = 1.2.3-6
|
||||||
|
Obsoletes: cupsddk-drivers < 1.2.3-6
|
||||||
|
Provides: cupsddk-drivers = 1.2.3-6
|
||||||
|
|
||||||
# kdelibs conflict for bug #192585.
|
# kdelibs conflict for bug #192585.
|
||||||
Conflicts: kdelibs < 6:3.5.2-6
|
Conflicts: kdelibs < 6:3.5.2-6
|
||||||
|
|
||||||
@ -80,6 +77,7 @@ BuildRequires: libpng-devel
|
|||||||
BuildRequires: libtiff-devel
|
BuildRequires: libtiff-devel
|
||||||
BuildRequires: krb5-devel
|
BuildRequires: krb5-devel
|
||||||
BuildRequires: avahi-compat-libdns_sd-devel
|
BuildRequires: avahi-compat-libdns_sd-devel
|
||||||
|
BuildRequires: poppler-utils
|
||||||
|
|
||||||
%if %lspp
|
%if %lspp
|
||||||
BuildPrereq: libselinux-devel >= 1.23
|
BuildPrereq: libselinux-devel >= 1.23
|
||||||
@ -113,6 +111,8 @@ Requires: %{name}-libs = %{epoch}:%{version}-%{release}
|
|||||||
Requires: gnutls-devel
|
Requires: gnutls-devel
|
||||||
Requires: krb5-devel
|
Requires: krb5-devel
|
||||||
Requires: zlib-devel
|
Requires: zlib-devel
|
||||||
|
Obsoletes: cupsddk-devel < 1.2.3-6
|
||||||
|
Provides: cupsddk-devel = 1.2.3-6
|
||||||
|
|
||||||
%package libs
|
%package libs
|
||||||
Summary: Common Unix Printing System - libraries
|
Summary: Common Unix Printing System - libraries
|
||||||
@ -131,6 +131,7 @@ Group: Development/Languages
|
|||||||
Requires: %{name} = %{epoch}:%{version}-%{release}
|
Requires: %{name} = %{epoch}:%{version}-%{release}
|
||||||
Requires: php-common
|
Requires: php-common
|
||||||
|
|
||||||
|
|
||||||
%description
|
%description
|
||||||
The Common UNIX Printing System provides a portable printing layer for
|
The Common UNIX Printing System provides a portable printing layer for
|
||||||
UNIX® operating systems. It has been developed by Easy Software Products
|
UNIX® operating systems. It has been developed by Easy Software Products
|
||||||
@ -161,12 +162,10 @@ UNIX® operating systems. This is the package that provices a PHP
|
|||||||
module.
|
module.
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
%setup -q -n %{name}-%{version}%{?svn:svn-r%{svn}}
|
%setup -q -n %{name}-%{version}%{?pre}
|
||||||
%patch1 -p1 -b .no-gzip-man
|
%patch1 -p1 -b .no-gzip-man
|
||||||
%patch2 -p1 -b .system-auth
|
%patch2 -p1 -b .system-auth
|
||||||
%patch3 -p1 -b .multilib
|
%patch3 -p1 -b .multilib
|
||||||
%patch4 -p1 -b .ext
|
|
||||||
%patch5 -p1 -b .includeifexists
|
|
||||||
%patch6 -p1 -b .banners
|
%patch6 -p1 -b .banners
|
||||||
%patch7 -p1 -b .serverbin-compat
|
%patch7 -p1 -b .serverbin-compat
|
||||||
%patch8 -p1 -b .no-export-ssllibs
|
%patch8 -p1 -b .no-export-ssllibs
|
||||||
@ -176,16 +175,13 @@ module.
|
|||||||
%patch12 -p1 -b .lpr-help
|
%patch12 -p1 -b .lpr-help
|
||||||
%patch13 -p1 -b .peercred
|
%patch13 -p1 -b .peercred
|
||||||
%patch14 -p1 -b .pid
|
%patch14 -p1 -b .pid
|
||||||
%patch15 -p1 -b .foomatic-recommended
|
|
||||||
%patch16 -p1 -b .eggcups
|
%patch16 -p1 -b .eggcups
|
||||||
%patch17 -p1 -b .getpass
|
%patch17 -p1 -b .getpass
|
||||||
%patch18 -p1 -b .driverd-timeout
|
%patch18 -p1 -b .driverd-timeout
|
||||||
%patch19 -p1 -b .strict-ppd-line-length
|
%patch19 -p1 -b .strict-ppd-line-length
|
||||||
%patch20 -p1 -b .logrotate
|
%patch20 -p1 -b .logrotate
|
||||||
%patch21 -p1 -b .usb-paperout
|
%patch21 -p1 -b .usb-paperout
|
||||||
%patch22 -p1 -b .getnameddest
|
%patch22 -p1 -b .build
|
||||||
%patch23 -p1 -b .str2101
|
|
||||||
%patch24 -p1 -b .str2536
|
|
||||||
|
|
||||||
%if %lspp
|
%if %lspp
|
||||||
%patch100 -p1 -b .lspp
|
%patch100 -p1 -b .lspp
|
||||||
@ -255,7 +251,6 @@ install -c -m 644 cups-lpd.real $RPM_BUILD_ROOT%{_sysconfdir}/xinetd.d/cups-lpd
|
|||||||
install -c -m 644 %{SOURCE9} $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/cups
|
install -c -m 644 %{SOURCE9} $RPM_BUILD_ROOT%{_sysconfdir}/logrotate.d/cups
|
||||||
install -c -m 755 %{SOURCE10} $RPM_BUILD_ROOT%{cups_serverbin}/backend/ncp
|
install -c -m 755 %{SOURCE10} $RPM_BUILD_ROOT%{cups_serverbin}/backend/ncp
|
||||||
install -c -m 755 %{SOURCE12} $RPM_BUILD_ROOT%{_sysconfdir}/cron.daily/cups
|
install -c -m 755 %{SOURCE12} $RPM_BUILD_ROOT%{_sysconfdir}/cron.daily/cups
|
||||||
install -c -m 644 %{SOURCE13} $RPM_BUILD_ROOT%{_sysconfdir}/cups/pdftops.conf
|
|
||||||
install -c -m 755 %{SOURCE14} $RPM_BUILD_ROOT%{cups_serverbin}/filter/textonly
|
install -c -m 755 %{SOURCE14} $RPM_BUILD_ROOT%{cups_serverbin}/filter/textonly
|
||||||
install -c -m 644 %{SOURCE15} $RPM_BUILD_ROOT%{_datadir}/cups/model/textonly.ppd
|
install -c -m 644 %{SOURCE15} $RPM_BUILD_ROOT%{_datadir}/cups/model/textonly.ppd
|
||||||
|
|
||||||
@ -294,13 +289,6 @@ rm -rf $RPM_BUILD_ROOT%{_mandir}/cat? $RPM_BUILD_ROOT%{_mandir}/*/cat?
|
|||||||
rm -f $RPM_BUILD_ROOT%{_datadir}/applications/cups.desktop
|
rm -f $RPM_BUILD_ROOT%{_datadir}/applications/cups.desktop
|
||||||
rm -rf $RPM_BUILD_ROOT%{_datadir}/icons
|
rm -rf $RPM_BUILD_ROOT%{_datadir}/icons
|
||||||
|
|
||||||
%if %{?svn:1}%{!?svn:0}
|
|
||||||
rm -f $RPM_BUILD_ROOT%{_bindir}/ppd{c,html,i,merge,po}
|
|
||||||
rm -f $RPM_BUILD_ROOT%{cups_serverbin}/filter/{command,raster}to{escpx,pclx}
|
|
||||||
rm -f $RPM_BUILD_ROOT%{cups_serverbin}/driver/drv
|
|
||||||
rm -rf $RPM_BUILD_ROOT%{_datadir}/cups/ppdc
|
|
||||||
%endif
|
|
||||||
|
|
||||||
%post
|
%post
|
||||||
/sbin/chkconfig --del cupsd 2>/dev/null || true # Make sure old versions aren't there anymore
|
/sbin/chkconfig --del cupsd 2>/dev/null || true # Make sure old versions aren't there anymore
|
||||||
/sbin/chkconfig --add cups || true
|
/sbin/chkconfig --add cups || true
|
||||||
@ -372,12 +360,9 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
%config(noreplace) %attr(0644,root,lp) /etc/cups/client.conf
|
%config(noreplace) %attr(0644,root,lp) /etc/cups/client.conf
|
||||||
%config(noreplace) %attr(0600,root,lp) /etc/cups/classes.conf
|
%config(noreplace) %attr(0600,root,lp) /etc/cups/classes.conf
|
||||||
%config(noreplace) %attr(0600,root,lp) /etc/cups/printers.conf
|
%config(noreplace) %attr(0600,root,lp) /etc/cups/printers.conf
|
||||||
%config(noreplace) %attr(0644,root,lp) /etc/cups/pdftops.conf
|
|
||||||
%config(noreplace) %attr(0644,root,lp) /etc/cups/snmp.conf
|
%config(noreplace) %attr(0644,root,lp) /etc/cups/snmp.conf
|
||||||
%config(noreplace) %attr(0644,root,lp) /etc/cups/subscriptions.conf
|
%config(noreplace) %attr(0644,root,lp) /etc/cups/subscriptions.conf
|
||||||
/etc/cups/interfaces
|
/etc/cups/interfaces
|
||||||
%config(noreplace) /etc/cups/mime.types
|
|
||||||
%config(noreplace) /etc/cups/mime.convs
|
|
||||||
%config(noreplace) %attr(0644,root,lp) /etc/cups/lpoptions
|
%config(noreplace) %attr(0644,root,lp) /etc/cups/lpoptions
|
||||||
%dir %attr(0755,root,lp) /etc/cups/ppd
|
%dir %attr(0755,root,lp) /etc/cups/ppd
|
||||||
%dir %attr(0700,root,lp) /etc/cups/ssl
|
%dir %attr(0700,root,lp) /etc/cups/ssl
|
||||||
@ -388,20 +373,6 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
%dir %{_datadir}/%{name}/www
|
%dir %{_datadir}/%{name}/www
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/favicon.*
|
%config(noreplace) %{_datadir}/%{name}/www/favicon.*
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/images
|
%config(noreplace) %{_datadir}/%{name}/www/images
|
||||||
%if %{?svn:1}%{!?svn:0}
|
|
||||||
%else
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/de
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/es
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/et
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/fr
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/he
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/id
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/it
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/ja
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/pl
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/sv
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/zh_TW
|
|
||||||
%endif
|
|
||||||
%config(noreplace) %{_datadir}/%{name}/www/*.css
|
%config(noreplace) %{_datadir}/%{name}/www/*.css
|
||||||
%config(noreplace) %doc %{_datadir}/%{name}/www/index.html
|
%config(noreplace) %doc %{_datadir}/%{name}/www/index.html
|
||||||
%config(noreplace) %doc %{_datadir}/%{name}/www/help
|
%config(noreplace) %doc %{_datadir}/%{name}/www/help
|
||||||
@ -411,6 +382,7 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
%{_bindir}/cupstestdsc
|
%{_bindir}/cupstestdsc
|
||||||
%{_bindir}/cancel*
|
%{_bindir}/cancel*
|
||||||
%{_bindir}/lp*
|
%{_bindir}/lp*
|
||||||
|
%{_bindir}/ppd*
|
||||||
%dir %{cups_serverbin}
|
%dir %{cups_serverbin}
|
||||||
%{cups_serverbin}/backend
|
%{cups_serverbin}/backend
|
||||||
%{cups_serverbin}/cgi-bin
|
%{cups_serverbin}/cgi-bin
|
||||||
@ -433,20 +405,7 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
%{_datadir}/cups/fonts
|
%{_datadir}/cups/fonts
|
||||||
%{_datadir}/cups/model
|
%{_datadir}/cups/model
|
||||||
%dir %{_datadir}/cups/templates
|
%dir %{_datadir}/cups/templates
|
||||||
%dir %{_datadir}/cups/templates/de
|
|
||||||
%dir %{_datadir}/cups/templates/es
|
|
||||||
%dir %{_datadir}/cups/templates/et
|
|
||||||
%dir %{_datadir}/cups/templates/fr
|
|
||||||
%dir %{_datadir}/cups/templates/he
|
|
||||||
%dir %{_datadir}/cups/templates/id
|
|
||||||
%dir %{_datadir}/cups/templates/it
|
|
||||||
%dir %{_datadir}/cups/templates/ja
|
|
||||||
%dir %{_datadir}/cups/templates/pl
|
|
||||||
%dir %{_datadir}/cups/templates/sv
|
|
||||||
%dir %{_datadir}/cups/templates/zh_TW
|
|
||||||
%config(noreplace) %{_datadir}/cups/templates/*.tmpl
|
%config(noreplace) %{_datadir}/cups/templates/*.tmpl
|
||||||
%config(noreplace) %{_datadir}/cups/templates/*/*.tmpl
|
|
||||||
%{_datadir}/locale/*/*
|
|
||||||
%{_datadir}/ppd
|
%{_datadir}/ppd
|
||||||
%dir %attr(1770,root,lp) /var/spool/cups/tmp
|
%dir %attr(1770,root,lp) /var/spool/cups/tmp
|
||||||
%dir %attr(0710,root,lp) /var/spool/cups
|
%dir %attr(0710,root,lp) /var/spool/cups
|
||||||
@ -454,6 +413,12 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
%{_datadir}/pixmaps/cupsprinter.png
|
%{_datadir}/pixmaps/cupsprinter.png
|
||||||
%{_sysconfdir}/cron.daily/cups
|
%{_sysconfdir}/cron.daily/cups
|
||||||
%{_sysconfdir}/dbus-1/system.d/cups.conf
|
%{_sysconfdir}/dbus-1/system.d/cups.conf
|
||||||
|
%{_datadir}/cups/drv
|
||||||
|
%{_datadir}/cups/examples
|
||||||
|
%dir %{_datadir}/cups/mime
|
||||||
|
%config(noreplace) %{_datadir}/cups/mime/mime.types
|
||||||
|
%config(noreplace) %{_datadir}/cups/mime/mime.convs
|
||||||
|
%{_datadir}/cups/ppdc/*.defs
|
||||||
|
|
||||||
%files libs
|
%files libs
|
||||||
%defattr(-,root,root)
|
%defattr(-,root,root)
|
||||||
@ -464,6 +429,7 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
%{_bindir}/cups-config
|
%{_bindir}/cups-config
|
||||||
%{_libdir}/*.so
|
%{_libdir}/*.so
|
||||||
%{_includedir}/cups
|
%{_includedir}/cups
|
||||||
|
%{_datadir}/cups/ppdc/*.h
|
||||||
|
|
||||||
%files lpd
|
%files lpd
|
||||||
%defattr(-,root,root)
|
%defattr(-,root,root)
|
||||||
@ -477,6 +443,14 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
%{_libdir}/php/modules/*.so
|
%{_libdir}/php/modules/*.so
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Tue Nov 11 2008 Tim Waugh <twaugh@redhat.com> 1:1.4-0.b1.1
|
||||||
|
- 1.4b1.
|
||||||
|
- No longer need ext, includeifexists, foomatic-recommended,
|
||||||
|
getnameddest, str2101, str2536 patches.
|
||||||
|
- Require poppler-utils at runtime and for build. No longer need
|
||||||
|
pdftops.conf.
|
||||||
|
- Obsolete cupsddk.
|
||||||
|
|
||||||
* Thu Oct 30 2008 Tim Waugh <twaugh@redhat.com> 1:1.3.9-3
|
* Thu Oct 30 2008 Tim Waugh <twaugh@redhat.com> 1:1.3.9-3
|
||||||
- Fixed LSPP labels (bug #468442).
|
- Fixed LSPP labels (bug #468442).
|
||||||
|
|
||||||
|
@ -1,4 +0,0 @@
|
|||||||
includeifexists /etc/xpdf/add-to-xpdfrc.japanese
|
|
||||||
includeifexists /etc/xpdf/add-to-xpdfrc.korean
|
|
||||||
includeifexists /etc/xpdf/add-to-xpdfrc.chinese-simplified
|
|
||||||
includeifexists /etc/xpdf/add-to-xpdfrc.chinese-traditional
|
|
Loading…
Reference in New Issue
Block a user