xref: /freebsd/sbin/dhclient/dhcpd.h (revision faf25f48d601ae39f5752602f3020e2e92605625)
1 /*	$OpenBSD: dhcpd.h,v 1.33 2004/05/06 22:29:15 deraadt Exp $	*/
2 
3 /*-
4  * SPDX-License-Identifier: BSD-3-Clause
5  *
6  * Copyright (c) 2004 Henning Brauer <henning@openbsd.org>
7  * Copyright (c) 1995, 1996, 1997, 1998, 1999
8  * The Internet Software Consortium.    All rights reserved.
9  *
10  * Redistribution and use in source and binary forms, with or without
11  * modification, are permitted provided that the following conditions
12  * are met:
13  *
14  * 1. Redistributions of source code must retain the above copyright
15  *    notice, this list of conditions and the following disclaimer.
16  * 2. Redistributions in binary form must reproduce the above copyright
17  *    notice, this list of conditions and the following disclaimer in the
18  *    documentation and/or other materials provided with the distribution.
19  * 3. Neither the name of The Internet Software Consortium nor the names
20  *    of its contributors may be used to endorse or promote products derived
21  *    from this software without specific prior written permission.
22  *
23  * THIS SOFTWARE IS PROVIDED BY THE INTERNET SOFTWARE CONSORTIUM AND
24  * CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
25  * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
26  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
27  * DISCLAIMED.  IN NO EVENT SHALL THE INTERNET SOFTWARE CONSORTIUM OR
28  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
29  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
30  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
31  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
32  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
33  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
34  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35  * SUCH DAMAGE.
36  *
37  * This software has been written for the Internet Software Consortium
38  * by Ted Lemon <mellon@fugue.com> in cooperation with Vixie
39  * Enterprises.  To learn more about the Internet Software Consortium,
40  * see ``http://www.vix.com/isc''.  To learn more about Vixie
41  * Enterprises, see ``http://www.vix.com''.
42  *
43  * $FreeBSD$
44  */
45 
46 #include <sys/param.h>
47 
48 #include <sys/socket.h>
49 #include <sys/sockio.h>
50 #include <sys/stat.h>
51 #include <sys/time.h>
52 #include <sys/un.h>
53 #include <sys/wait.h>
54 
55 #include <net/if.h>
56 #include <net/if_dl.h>
57 #include <net/route.h>
58 
59 #include <netinet/in.h>
60 #include <arpa/inet.h>
61 
62 #include <ctype.h>
63 #include <errno.h>
64 #include <fcntl.h>
65 #include <libutil.h>
66 #include <limits.h>
67 #include <netdb.h>
68 #include <paths.h>
69 #include <unistd.h>
70 #include <stdarg.h>
71 #include <stdio.h>
72 #include <stdlib.h>
73 #include <string.h>
74 #include <syslog.h>
75 #include <time.h>
76 #include <unistd.h>
77 
78 #include <libcasper.h>
79 #include <casper/cap_syslog.h>
80 
81 #include "dhcp.h"
82 #include "tree.h"
83 
84 #define	LOCAL_PORT	68
85 #define	REMOTE_PORT	67
86 
87 struct option_data {
88 	size_t		 len;
89 	u_int8_t	*data;
90 };
91 
92 struct string_list {
93 	struct string_list	*next;
94 	char			*string;
95 };
96 
97 struct iaddr {
98 	size_t len;
99 	unsigned char iabuf[16];
100 };
101 
102 struct iaddrlist {
103 	struct iaddrlist *next;
104 	struct iaddr addr;
105 };
106 
107 struct packet {
108 	struct dhcp_packet	*raw;
109 	int			 packet_length;
110 	int			 packet_type;
111 	int			 options_valid;
112 	int			 client_port;
113 	struct iaddr		 client_addr;
114 	struct interface_info	*interface;
115 	struct hardware		*haddr;
116 	struct option_data	 options[256];
117 };
118 
119 struct hardware {
120 	u_int8_t htype;
121 	u_int8_t hlen;
122 	u_int8_t haddr[16];
123 };
124 
125 struct client_lease {
126 	struct client_lease	*next;
127 	time_t			 expiry, renewal, rebind;
128 	struct iaddr		 address;
129 	struct iaddr		 nextserver;
130 	char			*server_name;
131 	char			*filename;
132 	struct string_list	*medium;
133 	unsigned int		 is_static : 1;
134 	unsigned int		 is_bootp : 1;
135 	struct option_data	 options[256];
136 };
137 
138 /* Possible states in which the client can be. */
139 enum dhcp_state {
140 	S_REBOOTING,
141 	S_INIT,
142 	S_SELECTING,
143 	S_REQUESTING,
144 	S_BOUND,
145 	S_RENEWING,
146 	S_REBINDING
147 };
148 
149 struct client_config {
150 	struct option_data	defaults[256];
151 	enum {
152 		ACTION_DEFAULT,
153 		ACTION_SUPERSEDE,
154 		ACTION_PREPEND,
155 		ACTION_APPEND
156 	} default_actions[256];
157 
158 	struct option_data	 send_options[256];
159 	u_int8_t		 required_options[256];
160 	u_int8_t		 requested_options[256];
161 	int			 requested_option_count;
162 	u_int			 vlan_pcp;
163 	time_t			 timeout;
164 	time_t			 initial_interval;
165 	time_t			 retry_interval;
166 	time_t			 select_interval;
167 	time_t			 reboot_timeout;
168 	time_t			 backoff_cutoff;
169 	struct string_list	*media;
170 	char			*script_name;
171 	enum { IGNORE, ACCEPT, PREFER }
172 				 bootp_policy;
173 	struct string_list	*medium;
174 	struct iaddrlist	*reject_list;
175 };
176 
177 struct client_state {
178 	struct client_lease	 *active;
179 	struct client_lease	 *new;
180 	struct client_lease	 *offered_leases;
181 	struct client_lease	 *leases;
182 	struct client_lease	 *alias;
183 	enum dhcp_state		  state;
184 	struct iaddr		  destination;
185 	u_int32_t		  xid;
186 	u_int16_t		  secs;
187 	time_t			  first_sending;
188 	time_t			  interval;
189 	struct string_list	 *medium;
190 	struct dhcp_packet	  packet;
191 	int			  packet_length;
192 	struct iaddr		  requested_address;
193 	struct client_config	 *config;
194 	char			**scriptEnv;
195 	int			  scriptEnvsize;
196 	struct string_list	 *env;
197 	int			  envc;
198 };
199 
200 struct interface_info {
201 	struct interface_info	*next;
202 	struct hardware		 hw_address;
203 	struct in_addr		 primary_address;
204 	char			 name[IFNAMSIZ];
205 	int			 rfdesc;
206 	int			 wfdesc;
207 	int			 ufdesc;
208 	unsigned char		*rbuf;
209 	size_t			 rbuf_max;
210 	size_t			 rbuf_offset;
211 	size_t			 rbuf_len;
212 	struct ifreq		*ifp;
213 	struct client_state	*client;
214 	int			 noifmedia;
215 	int			 errors;
216 	int			 dead;
217 	u_int16_t		 index;
218 	int			 linkstat;
219 };
220 
221 struct timeout {
222 	struct timeout	*next;
223 	time_t		 when;
224 	void		 (*func)(void *);
225 	void		*what;
226 };
227 
228 struct protocol {
229 	struct protocol	*next;
230 	int fd;
231 	void (*handler)(struct protocol *);
232 	void *local;
233 };
234 
235 #define DEFAULT_HASH_SIZE 97
236 
237 struct hash_bucket {
238 	struct hash_bucket *next;
239 	const unsigned char *name;
240 	int len;
241 	unsigned char *value;
242 };
243 
244 struct hash_table {
245 	int hash_count;
246 	struct hash_bucket *buckets[DEFAULT_HASH_SIZE];
247 };
248 
249 /* Default path to dhcpd config file. */
250 #define	_PATH_DHCLIENT_CONF	"/etc/dhclient.conf"
251 #define	_PATH_DHCLIENT_DB	"/var/db/dhclient.leases"
252 #define	DHCPD_LOG_FACILITY	LOG_DAEMON
253 
254 #define	MAX_TIME 0x7fffffff
255 #define	MIN_TIME 0
256 
257 /* External definitions... */
258 
259 /* options.c */
260 int cons_options(struct packet *, struct dhcp_packet *, int,
261     struct tree_cache **, int, int, int, u_int8_t *, int);
262 const char *pretty_print_option(unsigned int,
263     unsigned char *, int, int, int);
264 void do_packet(struct interface_info *, struct dhcp_packet *,
265     int, unsigned int, struct iaddr, struct hardware *);
266 
267 /* errwarn.c */
268 extern int warnings_occurred;
269 void error(const char *, ...) __attribute__ ((__format__ (__printf__, 1, 2))) __dead2;
270 int warning(const char *, ...) __attribute__ ((__format__ (__printf__, 1, 2)));
271 int note(const char *, ...) __attribute__ ((__format__ (__printf__, 1, 2)));
272 int debug(const char *, ...) __attribute__ ((__format__ (__printf__, 1, 2)));
273 int parse_warn(const char *, ...) __attribute__ ((__format__ (__printf__, 1, 2)));
274 
275 /* conflex.c */
276 extern int lexline, lexchar;
277 extern char *token_line;
278 extern const char *tlname;
279 extern char comments[4096];
280 extern int comment_index;
281 extern int eol_token;
282 void new_parse(const char *);
283 int next_token(char **, FILE *);
284 int peek_token(char **, FILE *);
285 
286 /* parse.c */
287 void skip_to_semi(FILE *);
288 int parse_semi(FILE *);
289 char *parse_string(FILE *);
290 int parse_ip_addr(FILE *, struct iaddr *);
291 void parse_hardware_param(FILE *, struct hardware *);
292 void parse_lease_time(FILE *, time_t *);
293 unsigned char *parse_numeric_aggregate(FILE *, unsigned char *, size_t *,
294     int, unsigned, int);
295 void convert_num(unsigned char *, char *, unsigned, int);
296 time_t parse_date(FILE *);
297 
298 /* tree.c */
299 pair cons(caddr_t, pair);
300 
301 /* alloc.c */
302 struct string_list	*new_string_list(size_t size);
303 struct hash_table	*new_hash_table(int);
304 struct hash_bucket	*new_hash_bucket(void);
305 
306 /* bpf.c */
307 int if_register_bpf(struct interface_info *, int);
308 void if_register_send(struct interface_info *);
309 void if_register_receive(struct interface_info *);
310 void send_packet_unpriv(int, struct dhcp_packet *, size_t, struct in_addr,
311     struct in_addr);
312 struct imsg_hdr;
313 void send_packet_priv(struct interface_info *, struct imsg_hdr *, int);
314 ssize_t receive_packet(struct interface_info *, unsigned char *, size_t,
315     struct sockaddr_in *, struct hardware *);
316 
317 /* dispatch.c */
318 extern void (*bootp_packet_handler)(struct interface_info *,
319     struct dhcp_packet *, int, unsigned int, struct iaddr, struct hardware *);
320 void discover_interfaces(struct interface_info *);
321 void reinitialize_interfaces(void);
322 void dispatch(void);
323 void got_one(struct protocol *);
324 void add_timeout(time_t, void (*)(void *), void *);
325 void cancel_timeout(void (*)(void *), void *);
326 void add_protocol(const char *, int, void (*)(struct protocol *), void *);
327 void remove_protocol(struct protocol *);
328 int interface_link_status(char *);
329 void interface_set_mtu_unpriv(int, u_int16_t);
330 void interface_set_mtu_priv(char *, u_int16_t);
331 
332 /* hash.c */
333 struct hash_table *new_hash(void);
334 void add_hash(struct hash_table *, const unsigned char *, int, unsigned char *);
335 void *hash_lookup(struct hash_table *, unsigned char *, int);
336 
337 /* tables.c */
338 extern struct option dhcp_options[256];
339 extern unsigned char dhcp_option_default_priority_list[];
340 extern int sizeof_dhcp_option_default_priority_list;
341 extern struct hash_table universe_hash;
342 extern struct universe dhcp_universe;
343 void initialize_universes(void);
344 
345 /* convert.c */
346 u_int32_t getULong(unsigned char *);
347 int32_t getLong(unsigned char *);
348 u_int16_t getUShort(unsigned char *);
349 int16_t getShort(unsigned char *);
350 void putULong(unsigned char *, u_int32_t);
351 void putLong(unsigned char *, int32_t);
352 void putUShort(unsigned char *, unsigned int);
353 void putShort(unsigned char *, int);
354 
355 /* inet.c */
356 struct iaddr subnet_number(struct iaddr, struct iaddr);
357 struct iaddr broadcast_addr(struct iaddr, struct iaddr);
358 int addr_eq(struct iaddr, struct iaddr);
359 char *piaddr(struct iaddr);
360 
361 /* dhclient.c */
362 extern cap_channel_t *capsyslog;
363 extern const char *path_dhclient_conf;
364 extern char *path_dhclient_db;
365 extern time_t cur_time;
366 extern int log_priority;
367 extern int log_perror;
368 
369 extern struct client_config top_level_config;
370 
371 extern struct pidfh *pidfile;
372 
373 extern struct interface_info *ifi;
374 
375 void dhcpoffer(struct packet *);
376 void dhcpack(struct packet *);
377 void dhcpnak(struct packet *);
378 
379 void send_discover(void *);
380 void send_request(void *);
381 void send_decline(void *);
382 
383 void state_reboot(void *);
384 void state_init(void *);
385 void state_selecting(void *);
386 void state_requesting(void *);
387 void state_bound(void *);
388 void state_panic(void *);
389 
390 void bind_lease(struct interface_info *);
391 
392 void make_discover(struct interface_info *, struct client_lease *);
393 void make_request(struct interface_info *, struct client_lease *);
394 void make_decline(struct interface_info *, struct client_lease *);
395 
396 void free_client_lease(struct client_lease *);
397 void rewrite_client_leases(void);
398 void write_client_lease(struct interface_info *, struct client_lease *, int);
399 
400 void	 priv_script_init(const char *, char *);
401 void	 priv_script_write_params(const char *, struct client_lease *);
402 int	 priv_script_go(void);
403 
404 void script_init(const char *, struct string_list *);
405 void script_write_params(const char *, struct client_lease *);
406 int script_go(void);
407 void client_envadd(struct client_state *,
408     const char *, const char *, const char *, ...);
409 void script_set_env(struct client_state *, const char *, const char *,
410     const char *);
411 void script_flush_env(struct client_state *);
412 int dhcp_option_ev_name(char *, size_t, struct option *);
413 
414 struct client_lease *packet_to_lease(struct packet *);
415 void go_daemon(void);
416 void client_location_changed(void);
417 
418 void bootp(struct packet *);
419 void dhcp(struct packet *);
420 
421 /* packet.c */
422 void assemble_hw_header(struct interface_info *, unsigned char *, int *);
423 void assemble_udp_ip_header(unsigned char *, int *, u_int32_t, u_int32_t,
424     unsigned int, unsigned char *, int);
425 ssize_t decode_hw_header(unsigned char *, int, struct hardware *);
426 ssize_t decode_udp_ip_header(unsigned char *, int, struct sockaddr_in *,
427     unsigned char *, int);
428 
429 /* clparse.c */
430 int read_client_conf(void);
431 void read_client_leases(void);
432 void parse_client_statement(FILE *, struct interface_info *,
433     struct client_config *);
434 unsigned parse_X(FILE *, u_int8_t *, unsigned);
435 int parse_option_list(FILE *, u_int8_t *);
436 void parse_interface_declaration(FILE *, struct client_config *);
437 struct interface_info *interface_or_dummy(char *);
438 void make_client_state(struct interface_info *);
439 void make_client_config(struct interface_info *, struct client_config *);
440 void parse_client_lease_statement(FILE *, int);
441 void parse_client_lease_declaration(FILE *, struct client_lease *,
442     struct interface_info **);
443 struct option *parse_option_decl(FILE *, struct option_data *);
444 void parse_string_list(FILE *, struct string_list **, int);
445 void parse_reject_statement(FILE *, struct client_config *);
446 
447 /* privsep.c */
448 struct buf	*buf_open(size_t);
449 int		 buf_add(struct buf *, const void *, size_t);
450 int		 buf_close(int, struct buf *);
451 ssize_t		 buf_read(int, void *, size_t);
452 void		 dispatch_imsg(struct interface_info *, int);
453