]> git.saurik.com Git - apple/syslog.git/blame - syslogd.tproj/daemon.h
syslog-100.2.tar.gz
[apple/syslog.git] / syslogd.tproj / daemon.h
CommitLineData
b16a592a 1/*
c4fdb7d1 2 * Copyright (c) 2004-2009 Apple Inc. All rights reserved.
b16a592a
A
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
5dd30d76
A
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
11 * file.
b16a592a
A
12 *
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
5dd30d76
A
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
b16a592a
A
20 *
21 * @APPLE_LICENSE_HEADER_END@
22 */
23
24#ifndef __DAEMON_H__
25#define __DAEMON_H__
26
27#include <stdio.h>
28#include <sys/types.h>
29#include <sys/queue.h>
30#include <time.h>
31#include <asl.h>
32#include <asl_private.h>
57b0aad2
A
33#include <asl_store.h>
34#include <asl_memory.h>
35#include <asl_mini_memory.h>
b16a592a 36#include <notify.h>
5dd30d76 37#include <launch.h>
c4fdb7d1 38#include <libkern/OSAtomic.h>
5dd30d76
A
39
40#define ADDFD_FLAGS_LOCAL 0x00000001
41
42#define ASL_DB_NOTIFICATION "com.apple.system.logger.message"
57b0aad2 43#define SELF_DB_NOTIFICATION "self.logger.message"
5dd30d76
A
44
45#define ASL_KEY_READ_UID "ReadUID"
46#define ASL_KEY_READ_GID "ReadGID"
47#define ASL_KEY_EXPIRE_TIME "ASLExpireTime"
5dd30d76
A
48#define ASL_KEY_TIME_NSEC "TimeNanoSec"
49#define ASL_KEY_REF_PID "RefPID"
50#define ASL_KEY_REF_PROC "RefProc"
51#define ASL_KEY_SESSION "Session"
c4fdb7d1
A
52#define ASL_KEY_OPTION "ASLOption"
53
54#define ASL_OPT_IGNORE "ignore"
55#define ASL_OPT_STORE "store"
b16a592a
A
56
57#define _PATH_PIDFILE "/var/run/syslog.pid"
58#define _PATH_ASL_IN "/var/run/asl_input"
b16a592a
A
59#define _PATH_SYSLOG_CONF "/etc/syslog.conf"
60#define _PATH_SYSLOG_IN "/var/run/syslog"
61#define _PATH_KLOG "/dev/klog"
62#define _PATH_MODULE_LIB "/usr/lib/asl"
63
57b0aad2
A
64#define DB_TYPE_FILE 0x00000001
65#define DB_TYPE_MEMORY 0x00000002
66#define DB_TYPE_MINI 0x00000004
67
5dd30d76
A
68#define KERN_DISASTER_LEVEL 3
69
c4fdb7d1
A
70#define SOURCE_UNKNOWN 0
71#define SOURCE_INTERNAL 1
72#define SOURCE_ASL_SOCKET 2
73#define SOURCE_BSD_SOCKET 3
74#define SOURCE_UDP_SOCKET 4
75#define SOURCE_KERN 5
76#define SOURCE_ASL_MESSAGE 6
77#define SOURCE_LAUNCHD 7
78
79#define SOURCE_SESSION 100 /* does not generate messages */
80
81#define STORE_FLAGS_FILE_CACHE_SWEEP_REQUESTED 0x00000001
82
83#define RESET_NONE 0
84#define RESET_CONFIG 1
85#define RESET_NETWORK 2
86
57b0aad2
A
87struct global_s
88{
c4fdb7d1
A
89 OSSpinLock lock;
90 int client_count;
57b0aad2 91 int disaster_occurred;
c4fdb7d1 92 mach_port_t listen_set;
57b0aad2 93 mach_port_t server_port;
c4fdb7d1
A
94 mach_port_t self_port;
95 mach_port_t dead_session_port;
57b0aad2 96 launch_data_t launch_dict;
c4fdb7d1 97 uint32_t store_flags;
57b0aad2 98 time_t start_time;
57b0aad2 99 int kfd;
c4fdb7d1 100 int reset;
57b0aad2 101 uint64_t bsd_flush_time;
c4fdb7d1
A
102 pthread_mutex_t *db_lock;
103 pthread_mutex_t *work_queue_lock;
104 pthread_cond_t work_queue_cond;
105 asl_search_result_t *work_queue;
57b0aad2
A
106 asl_store_t *file_db;
107 asl_memory_t *memory_db;
108 asl_mini_memory_t *mini_db;
109 asl_mini_memory_t *disaster_db;
c4fdb7d1
A
110
111 /* parameters below are configurable as command-line args or in /etc/asl.conf */
112 int asl_log_filter;
113 int debug;
114 char *debug_file;
115 int dbtype;
116 uint32_t db_file_max;
117 uint32_t db_memory_max;
118 uint32_t db_mini_max;
119 uint32_t mps_limit;
120 uint64_t bsd_max_dup_time;
121 uint64_t asl_store_ping_time;
122 uint64_t mark_time;
123 time_t utmp_ttl;
124 time_t fs_ttl;
57b0aad2
A
125};
126
127extern struct global_s global;
5dd30d76 128
c4fdb7d1
A
129typedef asl_msg_t *(*aslreadfn)(int);
130typedef char *(*aslwritefn)(const char *, int);
131typedef char *(*aslexceptfn)(int);
132typedef int (*aslsendmsgfn)(asl_msg_t *msg, const char *outid);
133
134struct aslevent
135{
136 int source;
137 int fd;
138 unsigned char read:1;
139 unsigned char write:1;
140 unsigned char except:1;
141 aslreadfn readfn;
142 aslwritefn writefn;
143 aslexceptfn exceptfn;
144 char *sender;
145 uid_t uid;
146 gid_t gid;
147 TAILQ_ENTRY(aslevent) entries;
148};
149
b16a592a
A
150struct module_list
151{
152 char *name;
153 void *module;
154 int (*init)(void);
155 int (*reset)(void);
156 int (*close)(void);
157 TAILQ_ENTRY(module_list) entries;
158};
159
c4fdb7d1
A
160void config_debug(int enable, const char *path);
161void config_data_store(int type, uint32_t file_max, uint32_t memory_max, uint32_t mini_max);
162void config_timers(uint64_t bsd_max_dup, uint64_t asl_store_ping, uint64_t utmp, uint64_t fs);
163
164char **explode(const char *s, const char *delim);
165void freeList(char **l);
166
b16a592a
A
167int aslevent_init(void);
168int aslevent_fdsets(fd_set *, fd_set *, fd_set *);
5dd30d76
A
169void aslevent_handleevent(fd_set *, fd_set *, fd_set *);
170void asl_mark(void);
171void asl_archive(void);
b16a592a 172
c4fdb7d1
A
173void asl_client_count_increment();
174void asl_client_count_decrement();
175
b16a592a
A
176char *get_line_from_file(FILE *f);
177
178int asldebug(const char *, ...);
179int asl_log_string(const char *str);
180
181char *asl_msg_to_string(asl_msg_t *msg, uint32_t *len);
182asl_msg_t *asl_msg_from_string(const char *buf);
183int asl_msg_cmp(asl_msg_t *a, asl_msg_t *b);
184time_t asl_parse_time(const char *str);
185
c4fdb7d1 186int aslevent_addfd(int source, int fd, uint32_t flags, aslreadfn readfn, aslwritefn writefn, aslexceptfn exceptfn);
b16a592a
A
187int aslevent_removefd(int fd);
188int aslevent_addmatch(asl_msg_t *query, char *outid);
189
c4fdb7d1
A
190int asl_check_option(asl_msg_t *msg, const char *opt);
191
b16a592a
A
192int aslevent_addoutput(aslsendmsgfn, const char *outid);
193
c4fdb7d1
A
194void asl_enqueue_message(uint32_t source, struct aslevent *e, asl_msg_t *msg);
195asl_msg_t **asl_work_dequeue(uint32_t *count);
196void asl_message_match_and_log(asl_msg_t *msg);
197
b16a592a
A
198int asl_syslog_faciliy_name_to_num(const char *fac);
199const char *asl_syslog_faciliy_num_to_name(int num);
5dd30d76
A
200asl_msg_t *asl_input_parse(const char *in, int len, char *rhost, int flag);
201
c4fdb7d1 202void db_ping_store(void);
5dd30d76
A
203
204/* message refcount utilities */
205uint32_t asl_msg_type(asl_msg_t *m);
206asl_msg_t *asl_msg_retain(asl_msg_t *m);
207void asl_msg_release(asl_msg_t *m);
b16a592a
A
208
209/* notify SPI */
b16a592a
A
210uint32_t notify_register_plain(const char *name, int *out_token);
211
212#endif /* __DAEMON_H__ */