]>
Commit | Line | Data |
---|---|---|
ef416fc2 | 1 | /* |
7e86f2f6 | 2 | * Configuration file definitions for the CUPS scheduler. |
ef416fc2 | 3 | * |
d1b0cd5f | 4 | * Copyright © 2020-2025 by OpenPrinting. |
be3b49a3 MS |
5 | * Copyright © 2007-2018 by Apple Inc. |
6 | * Copyright © 1997-2007 by Easy Software Products, all rights reserved. | |
ef416fc2 | 7 | * |
be3b49a3 MS |
8 | * Licensed under Apache License v2.0. See the file "LICENSE" for more |
9 | * information. | |
ef416fc2 | 10 | */ |
11 | ||
12 | ||
13 | /* | |
14 | * Log levels... | |
15 | */ | |
16 | ||
17 | typedef enum | |
18 | { | |
a469f8a5 | 19 | CUPSD_LOG_PPD = -5, /* Used internally for PPD keywords */ |
c9fc04c6 | 20 | CUPSD_LOG_ATTR, /* Used internally for attributes */ |
a469f8a5 MS |
21 | CUPSD_LOG_STATE, /* Used internally for printer-state-reasons */ |
22 | CUPSD_LOG_JOBSTATE, /* Used internally for job-state-reasons */ | |
f7deaa1a | 23 | CUPSD_LOG_PAGE, /* Used internally for page logging */ |
ef416fc2 | 24 | CUPSD_LOG_NONE, |
f7deaa1a | 25 | CUPSD_LOG_EMERG, /* Emergency issues */ |
26 | CUPSD_LOG_ALERT, /* Something bad happened that needs attention */ | |
27 | CUPSD_LOG_CRIT, /* Critical error but server continues */ | |
28 | CUPSD_LOG_ERROR, /* Error condition */ | |
29 | CUPSD_LOG_WARN, /* Warning */ | |
30 | CUPSD_LOG_NOTICE, /* Normal condition that needs logging */ | |
31 | CUPSD_LOG_INFO, /* General information */ | |
32 | CUPSD_LOG_DEBUG, /* General debugging */ | |
33 | CUPSD_LOG_DEBUG2 /* Detailed debugging */ | |
ef416fc2 | 34 | } cupsd_loglevel_t; |
35 | ||
1f0275e3 MS |
36 | typedef enum |
37 | { | |
c9dcc485 | 38 | CUPSD_ACCESSLOG_NONE, /* Log no requests */ |
1f0275e3 MS |
39 | CUPSD_ACCESSLOG_CONFIG, /* Log config requests */ |
40 | CUPSD_ACCESSLOG_ACTIONS, /* Log config, print, and job management requests */ | |
41 | CUPSD_ACCESSLOG_ALL /* Log everything */ | |
42 | } cupsd_accesslog_t; | |
43 | ||
dfd5680b MS |
44 | typedef enum |
45 | { | |
46 | CUPSD_TIME_STANDARD, /* "Standard" Apache/CLF format */ | |
47 | CUPSD_TIME_USECS /* Standard format with microseconds */ | |
48 | } cupsd_time_t; | |
49 | ||
8fe0183a MS |
50 | typedef enum |
51 | { | |
52 | CUPSD_SANDBOXING_OFF, /* No sandboxing */ | |
53 | CUPSD_SANDBOXING_RELAXED, /* Relaxed sandboxing */ | |
54 | CUPSD_SANDBOXING_STRICT /* Strict sandboxing */ | |
55 | } cupsd_sandboxing_t; | |
56 | ||
ef416fc2 | 57 | |
49d87452 MS |
58 | /* |
59 | * FatalErrors flags... | |
60 | */ | |
61 | ||
62 | #define CUPSD_FATAL_NONE 0 /* No errors are fatal */ | |
63 | #define CUPSD_FATAL_BROWSE 1 /* Browse bind errors are fatal */ | |
64 | #define CUPSD_FATAL_CONFIG 2 /* Config file syntax errors are fatal */ | |
65 | #define CUPSD_FATAL_LISTEN 4 /* Listen/Port bind errors are fatal */ | |
66 | #define CUPSD_FATAL_LOG 8 /* Log file errors are fatal */ | |
67 | #define CUPSD_FATAL_PERMISSIONS 16 /* File permission errors are fatal */ | |
68 | #define CUPSD_FATAL_ALL ~0 /* All errors are fatal */ | |
69 | ||
70 | ||
ef416fc2 | 71 | /* |
72 | * Printcap formats... | |
73 | */ | |
74 | ||
f7deaa1a | 75 | #define PRINTCAP_BSD 0 /* Berkeley LPD format */ |
76 | #define PRINTCAP_SOLARIS 1 /* Solaris lpsched format */ | |
8072030b | 77 | #define PRINTCAP_PLIST 2 /* macOS plist format */ |
ef416fc2 | 78 | |
79 | ||
e07d4801 MS |
80 | /* |
81 | * ServerAlias data... | |
82 | */ | |
83 | ||
84 | typedef struct | |
85 | { | |
86 | size_t namelen; /* Length of alias name */ | |
87 | char name[1]; /* Alias name */ | |
88 | } cupsd_alias_t; | |
89 | ||
90 | ||
ef416fc2 | 91 | /* |
92 | * Globals... | |
93 | */ | |
94 | ||
95 | VAR char *ConfigurationFile VALUE(NULL), | |
c41769ff MS |
96 | /* cupsd.conf file to use */ |
97 | *CupsFilesFile VALUE(NULL), | |
98 | /* cups-files.conf file to use */ | |
ef416fc2 | 99 | *ServerName VALUE(NULL), |
100 | /* FQDN for server */ | |
101 | *ServerAdmin VALUE(NULL), | |
102 | /* Administrator's email */ | |
103 | *ServerRoot VALUE(NULL), | |
104 | /* Root directory for scheduler */ | |
105 | *ServerBin VALUE(NULL), | |
106 | /* Root directory for binaries */ | |
107 | *StateDir VALUE(NULL), | |
108 | /* Root directory for state data */ | |
109 | *RequestRoot VALUE(NULL), | |
110 | /* Directory for request files */ | |
111 | *DocumentRoot VALUE(NULL); | |
112 | /* Root directory for documents */ | |
a674f249 MS |
113 | VAR cups_lang_t *Languages VALUE(NULL); |
114 | /* Languages that cupsd is providing */ | |
e07d4801 MS |
115 | VAR cups_array_t *ServerAlias VALUE(NULL); |
116 | /* Alias names for server */ | |
f11a948a | 117 | VAR int ServerNameIsIP VALUE(0); |
d1c13e16 | 118 | /* Is the ServerName an IP address? */ |
ef416fc2 | 119 | VAR int NumSystemGroups VALUE(0); |
120 | /* Number of system group names */ | |
ac884b6a MS |
121 | VAR char *SystemGroups[MAX_SYSTEM_GROUPS] |
122 | VALUE({0}); | |
ef416fc2 | 123 | /* System group names */ |
ac884b6a MS |
124 | VAR gid_t SystemGroupIDs[MAX_SYSTEM_GROUPS] |
125 | VALUE({0}); | |
ef416fc2 | 126 | /* System group IDs */ |
127 | VAR char *AccessLog VALUE(NULL), | |
128 | /* Access log filename */ | |
129 | *ErrorLog VALUE(NULL), | |
130 | /* Error log filename */ | |
131 | *PageLog VALUE(NULL), | |
132 | /* Page log filename */ | |
133 | *CacheDir VALUE(NULL), | |
134 | /* Cache file directory */ | |
135 | *DataDir VALUE(NULL), | |
136 | /* Data file directory */ | |
137 | *DefaultLanguage VALUE(NULL), | |
138 | /* Default language encoding */ | |
ef416fc2 | 139 | *DefaultLocale VALUE(NULL), |
140 | /* Default locale */ | |
c5571a1d MS |
141 | *DefaultPaperSize VALUE(NULL), |
142 | /* Default paper size */ | |
323c5de1 | 143 | *ErrorPolicy VALUE(NULL), |
144 | /* Default printer-error-policy */ | |
ef416fc2 | 145 | *TempDir VALUE(NULL), |
146 | /* Temporary directory */ | |
147 | *Printcap VALUE(NULL), | |
148 | /* Printcap file */ | |
ef416fc2 | 149 | *RemoteRoot VALUE(NULL), |
150 | /* Remote root user */ | |
151 | *Classification VALUE(NULL); | |
152 | /* Classification of system */ | |
fe80a7e9 MS |
153 | VAR cups_array_t *ReadyPaperSizes VALUE(NULL); |
154 | /* List of paper sizes to list as ready */ | |
7e86f2f6 | 155 | VAR uid_t User VALUE(1), |
ef416fc2 | 156 | /* User ID for server */ |
7e86f2f6 MS |
157 | RunUser VALUE(0); |
158 | /* User to run as, used for files */ | |
ef416fc2 | 159 | VAR gid_t Group VALUE(0); |
160 | /* Group ID for server */ | |
dfd5680b | 161 | VAR cupsd_accesslog_t AccessLogLevel VALUE(CUPSD_ACCESSLOG_ACTIONS); |
1f0275e3 | 162 | /* Access log level */ |
dfd5680b | 163 | VAR int ClassifyOverride VALUE(0), |
ef416fc2 | 164 | /* Allow overrides? */ |
178cb736 MS |
165 | LogDebugHistory VALUE(200), |
166 | /* Amount of automatic debug history */ | |
49d87452 MS |
167 | FatalErrors VALUE(CUPSD_FATAL_CONFIG), |
168 | /* Which errors are fatal? */ | |
a29fd7dd MS |
169 | StrictConformance VALUE(FALSE), |
170 | /* Require strict IPP conformance? */ | |
7e86f2f6 | 171 | SyncOnClose VALUE(FALSE); |
8a259669 | 172 | /* Call fsync() when closing files? */ |
7e86f2f6 MS |
173 | VAR mode_t ConfigFilePerm VALUE(0640U), |
174 | /* Permissions for config files */ | |
175 | LogFilePerm VALUE(0644U); | |
ef416fc2 | 176 | /* Permissions for log files */ |
b112a671 MS |
177 | VAR gid_t LogFileGroup VALUE(0); |
178 | /* Group ID for log files */ | |
dfd5680b | 179 | VAR cupsd_loglevel_t LogLevel VALUE(CUPSD_LOG_WARN); |
1f0275e3 | 180 | /* Error log level */ |
cdf1d705 VT |
181 | VAR int StripUserDomain VALUE(FALSE); |
182 | /* Strip domain in local username? */ | |
dfd5680b MS |
183 | VAR cupsd_time_t LogTimeFormat VALUE(CUPSD_TIME_STANDARD); |
184 | /* Log file time format */ | |
a1797929 MS |
185 | VAR cups_file_t *LogStderr VALUE(NULL); |
186 | /* Stderr file, if any */ | |
8fe0183a MS |
187 | VAR cupsd_sandboxing_t Sandboxing VALUE(CUPSD_SANDBOXING_STRICT); |
188 | /* Sandboxing level */ | |
189 | VAR int UseSandboxing VALUE(1); | |
190 | /* Use sandboxing for child procs? */ | |
dfd5680b | 191 | VAR int MaxClients VALUE(100), |
ef416fc2 | 192 | /* Maximum number of clients */ |
193 | MaxClientsPerHost VALUE(0), | |
194 | /* Maximum number of clients per host */ | |
f7deaa1a | 195 | MaxCopies VALUE(CUPS_DEFAULT_MAX_COPIES), |
ef416fc2 | 196 | /* Maximum number of copies per job */ |
197 | MaxLogSize VALUE(1024 * 1024), | |
198 | /* Maximum size of log files */ | |
ef416fc2 | 199 | MaxRequestSize VALUE(0), |
200 | /* Maximum size of IPP requests */ | |
201 | HostNameLookups VALUE(FALSE), | |
202 | /* Do we do reverse lookups? */ | |
203 | Timeout VALUE(DEFAULT_TIMEOUT), | |
204 | /* Timeout during requests */ | |
205 | KeepAlive VALUE(TRUE), | |
206 | /* Support the Keep-Alive option? */ | |
ef416fc2 | 207 | FileDevice VALUE(FALSE), |
208 | /* Allow file: devices? */ | |
209 | FilterLimit VALUE(0), | |
210 | /* Max filter cost at any time */ | |
211 | FilterLevel VALUE(0), | |
212 | /* Current filter level */ | |
213 | FilterNice VALUE(0), | |
214 | /* Nice value for filters */ | |
49d87452 | 215 | ReloadTimeout VALUE(DEFAULT_KEEPALIVE), |
ef416fc2 | 216 | /* Timeout before reload from SIGHUP */ |
217 | RootCertDuration VALUE(300), | |
218 | /* Root certificate update interval */ | |
fa73b229 | 219 | PrintcapFormat VALUE(PRINTCAP_BSD), |
ef416fc2 | 220 | /* Format of printcap file? */ |
dfd5680b | 221 | DefaultShared VALUE(TRUE), |
fa73b229 | 222 | /* Share printers by default? */ |
229681c1 | 223 | MultipleOperationTimeout VALUE(DEFAULT_TIMEOUT), |
dfd5680b | 224 | /* multiple-operation-time-out value */ |
229681c1 MS |
225 | WebInterface VALUE(CUPS_DEFAULT_WEBIF); |
226 | /* Enable the web interface? */ | |
ef416fc2 | 227 | VAR cups_file_t *AccessFile VALUE(NULL), |
228 | /* Access log file */ | |
229 | *ErrorFile VALUE(NULL), | |
230 | /* Error log file */ | |
231 | *PageFile VALUE(NULL); | |
232 | /* Page log file */ | |
01ce6322 MS |
233 | VAR char *PageLogFormat VALUE(NULL); |
234 | /* Page log format */ | |
ef416fc2 | 235 | VAR mime_t *MimeDatabase VALUE(NULL); |
236 | /* MIME type database */ | |
237 | VAR int NumMimeTypes VALUE(0); | |
238 | /* Number of MIME types */ | |
239 | VAR const char **MimeTypes VALUE(NULL); | |
240 | /* Array of MIME types */ | |
241 | ||
efed0562 MS |
242 | VAR int CreateSelfSignedCerts VALUE(TRUE); |
243 | /* Automatically create self-signed certs? */ | |
72d05bc9 MS |
244 | VAR char *ServerKeychain VALUE(NULL); |
245 | /* Keychain holding cert + key */ | |
ef416fc2 | 246 | |
1166bf58 | 247 | #ifdef HAVE_ONDEMAND |
1720786e | 248 | VAR int IdleExitTimeout VALUE(60); |
a4d04587 | 249 | /* Time after which an idle cupsd will exit */ |
c187d9ab | 250 | #endif /* HAVE_ONDEMAND */ |
ef416fc2 | 251 | |
f7deaa1a | 252 | #ifdef HAVE_AUTHORIZATION_H |
253 | VAR char *SystemGroupAuthKey VALUE(NULL); | |
254 | /* System group auth key */ | |
255 | #endif /* HAVE_AUTHORIZATION_H */ | |
256 | ||
dcb445bc MS |
257 | #ifdef HAVE_GSSAPI |
258 | VAR char *GSSServiceName VALUE(NULL); | |
259 | /* GSS service name */ | |
4a78452e | 260 | VAR int HaveServerCreds VALUE(0); |
dcb445bc | 261 | /* Do we have server credentials? */ |
4a78452e | 262 | VAR gss_cred_id_t ServerCreds; /* Server's GSS credentials */ |
dcb445bc MS |
263 | #endif /* HAVE_GSSAPI */ |
264 | ||
f7deaa1a | 265 | |
ef416fc2 | 266 | /* |
267 | * Prototypes... | |
268 | */ | |
269 | ||
e07d4801 | 270 | extern void cupsdAddAlias(cups_array_t *aliases, const char *name); |
22c9029b | 271 | extern int cupsdCheckLogFile(cups_file_t **lf, const char *logname); |
b94498cf | 272 | extern int cupsdCheckPermissions(const char *filename, |
7e86f2f6 MS |
273 | const char *suffix, mode_t mode, |
274 | uid_t user, gid_t group, int is_dir, | |
b94498cf | 275 | int create_dir); |
22c9029b | 276 | extern int cupsdCheckProgram(const char *filename, cupsd_printer_t *p); |
dcb445bc | 277 | extern int cupsdDefaultAuthType(void); |
e07d4801 | 278 | extern void cupsdFreeAliases(cups_array_t *aliases); |
dfd5680b | 279 | extern char *cupsdGetDateTime(struct timeval *t, cupsd_time_t format); |
be3b49a3 MS |
280 | extern int cupsdLogClient(cupsd_client_t *con, int level, const char *message, ...) _CUPS_FORMAT(3, 4); |
281 | extern void cupsdLogFCMessage(void *context, _cups_fc_result_t result, const char *message); | |
f7deaa1a | 282 | #ifdef HAVE_GSSAPI |
be3b49a3 | 283 | extern int cupsdLogGSSMessage(int level, OM_uint32 major_status, OM_uint32 minor_status, const char *message, ...) _CUPS_FORMAT(4, 5); |
f7deaa1a | 284 | #endif /* HAVE_GSSAPI */ |
85dda01c | 285 | extern int cupsdLogJob(cupsd_job_t *job, int level, const char *message, |
be3b49a3 MS |
286 | ...) _CUPS_FORMAT(3, 4); |
287 | extern int cupsdLogMessage(int level, const char *message, ...) _CUPS_FORMAT(2, 3); | |
ef416fc2 | 288 | extern int cupsdLogPage(cupsd_job_t *job, const char *page); |
d1b0cd5f | 289 | extern int cupsdLogPrinter(cupsd_printer_t *p, int level, const char *message, ...) _CUPS_FORMAT(3, 4); |
f7deaa1a | 290 | extern int cupsdLogRequest(cupsd_client_t *con, http_status_t code); |
b94498cf | 291 | extern int cupsdReadConfiguration(void); |
75bd9771 | 292 | extern int cupsdWriteErrorLog(int level, const char *message); |
eeae5d04 | 293 | extern void cupsdWriteStrings(void); |