Better pid handling.
[rsync/rsync.git] / rsync.h
... / ...
CommitLineData
1/*
2 Copyright (C) by Andrew Tridgell 1996, 2000
3 Copyright (C) Paul Mackerras 1996
4 Copyright (C) 2001, 2002 by Martin Pool <mbp@samba.org>
5
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
10
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19*/
20
21
22#define False 0
23#define True 1
24
25#define BLOCK_SIZE 700
26#define RSYNC_RSH_ENV "RSYNC_RSH"
27#define RSYNC_RSH_IO_ENV "RSYNC_RSH_IO"
28
29#define RSYNC_NAME "rsync"
30#define RSYNCD_SYSCONF "/etc/rsyncd.conf"
31#define RSYNCD_USERCONF "rsyncd.conf"
32
33#define DEFAULT_LOCK_FILE "/var/run/rsyncd.lock"
34#define URL_PREFIX "rsync://"
35
36#define BACKUP_SUFFIX "~"
37
38/* a non-zero CHAR_OFFSET makes the rolling sum stronger, but is
39 incompatible with older versions :-( */
40#define CHAR_OFFSET 0
41
42/* These flags are only used during the flist transfer. */
43
44#define XMIT_TOP_DIR (1<<0)
45#define XMIT_SAME_MODE (1<<1)
46#define XMIT_EXTENDED_FLAGS (1<<2)
47#define XMIT_SAME_RDEV_pre28 XMIT_EXTENDED_FLAGS /* Only in protocols < 28 */
48#define XMIT_SAME_UID (1<<3)
49#define XMIT_SAME_GID (1<<4)
50#define XMIT_SAME_NAME (1<<5)
51#define XMIT_LONG_NAME (1<<6)
52#define XMIT_SAME_TIME (1<<7)
53#define XMIT_SAME_HIGH_RDEV (1<<8)
54#define XMIT_HAS_IDEV_DATA (1<<9)
55#define XMIT_SAME_DEV (1<<10)
56
57/* These flags are used in the live flist data. */
58
59#define FLAG_TOP_DIR (1<<0)
60#define FLAG_HLINK_EOL (1<<1) /* generator only */
61#define FLAG_MOUNT_POINT (1<<2) /* sender only */
62
63/* update this if you make incompatible changes */
64#define PROTOCOL_VERSION 28
65
66/* We refuse to interoperate with versions that are not in this range.
67 * Note that we assume we'll work with later versions: the onus is on
68 * people writing them to make sure that they don't send us anything
69 * we won't understand.
70 *
71 * Interoperation with old but supported protocol versions
72 * should cause a warning to be printed. At a future date
73 * the old protocol will become the minimum and
74 * compatibility code removed.
75 *
76 * There are two possible explanations for the limit at
77 * MAX_PROTOCOL_VERSION: either to allow new major-rev versions that
78 * do not interoperate with us, and (more likely) so that we can
79 * detect an attempt to connect rsync to a non-rsync server, which is
80 * unlikely to begin by sending a byte between MIN_PROTOCL_VERSION and
81 * MAX_PROTOCOL_VERSION. */
82
83#define MIN_PROTOCOL_VERSION 19
84#define OLD_PROTOCOL_VERSION 20
85#define MAX_PROTOCOL_VERSION 40
86
87#define RSYNC_PORT 873
88
89#define SPARSE_WRITE_SIZE (1024)
90#define WRITE_SIZE (32*1024)
91#define CHUNK_SIZE (32*1024)
92#define MAX_MAP_SIZE (256*1024)
93#define IO_BUFFER_SIZE (4092)
94
95#define IOERR_GENERAL (1<<0) /* For backward compatibility, this must == 1 */
96#define IOERR_VANISHED (1<<1)
97
98#define MAX_ARGS 1000
99
100#define MPLEX_BASE 7
101
102#define NO_EXCLUDES 0
103#define SERVER_EXCLUDES 1
104#define ALL_EXCLUDES 2
105
106#define MISSING_OK 0
107#define MISSING_FATAL 1
108
109#define ADD_INCLUDE 1
110#define ADD_EXCLUDE 0
111
112#define FULL_FLUSH 1
113#define NORMAL_FLUSH 0
114
115/* Log-message categories. FLOG is only used on the daemon side to
116 * output messages to the log file. */
117enum logcode { FERROR=1, FINFO=2, FLOG=3 };
118
119/* Messages types that are sent over the message channel. The logcode
120 * values must all be present here with identical numbers. */
121enum msgcode {
122 MSG_DATA=0, /* raw data on the multiplexed stream */
123 MSG_ERROR=FERROR, MSG_INFO=FINFO, MSG_LOG=FLOG, /* remote logging */
124 MSG_REDO=4, /* reprocess indicated flist index */
125 MSG_DONE=5, /* current phase is done */
126};
127
128#include "errcode.h"
129
130#include "config.h"
131
132/* The default RSYNC_RSH is always set in config.h. */
133
134#include <sys/types.h>
135
136#ifdef HAVE_UNISTD_H
137#include <unistd.h>
138#endif
139#include <stdio.h>
140#include <stddef.h>
141
142#ifdef HAVE_SYS_PARAM_H
143#include <sys/param.h>
144#endif
145
146#ifdef HAVE_STDLIB_H
147#include <stdlib.h>
148#endif
149
150#if defined(HAVE_MALLOC_H) && (defined(HAVE_MALLINFO) || !defined(HAVE_STDLIB_H))
151#include <malloc.h>
152#endif
153
154#ifdef HAVE_SYS_SOCKET_H
155#include <sys/socket.h>
156#endif
157
158#ifdef HAVE_STRING_H
159#include <string.h>
160#endif
161
162#ifdef TIME_WITH_SYS_TIME
163#include <sys/time.h>
164#include <time.h>
165#else
166#ifdef HAVE_SYS_TIME_H
167#include <sys/time.h>
168#else
169#include <time.h>
170#endif
171#endif
172
173#ifdef HAVE_FCNTL_H
174#include <fcntl.h>
175#else
176#ifdef HAVE_SYS_FCNTL_H
177#include <sys/fcntl.h>
178#endif
179#endif
180
181#include <sys/stat.h>
182
183#ifdef HAVE_SYS_IOCTL_H
184#include <sys/ioctl.h>
185#endif
186
187#ifdef HAVE_SYS_FILIO_H
188#include <sys/filio.h>
189#endif
190
191#include <signal.h>
192#ifdef HAVE_SYS_WAIT_H
193#include <sys/wait.h>
194#endif
195#ifdef HAVE_CTYPE_H
196#include <ctype.h>
197#endif
198#ifdef HAVE_GRP_H
199#include <grp.h>
200#endif
201#include <errno.h>
202
203#ifdef HAVE_UTIME_H
204#include <utime.h>
205#endif
206
207#ifdef HAVE_SYS_SELECT_H
208#include <sys/select.h>
209#endif
210
211#ifdef HAVE_SYS_MODE_H
212/* apparently AIX needs this for S_ISLNK */
213#ifndef S_ISLNK
214#include <sys/mode.h>
215#endif
216#endif
217
218#ifdef HAVE_GLOB_H
219#include <glob.h>
220#endif
221
222/* these are needed for the uid/gid mapping code */
223#include <pwd.h>
224#include <grp.h>
225
226#include <stdarg.h>
227#include <netinet/in.h>
228#include <arpa/inet.h>
229#include <netdb.h>
230#include <syslog.h>
231#include <sys/file.h>
232
233#if HAVE_DIRENT_H
234# include <dirent.h>
235#else
236# define dirent direct
237# if HAVE_SYS_NDIR_H
238# include <sys/ndir.h>
239# endif
240# if HAVE_SYS_DIR_H
241# include <sys/dir.h>
242# endif
243# if HAVE_NDIR_H
244# include <ndir.h>
245# endif
246#endif
247
248#ifdef HAVE_COMPAT_H
249#include <compat.h>
250#endif
251
252#include <assert.h>
253
254
255#define BOOL int
256
257#ifndef uchar
258#define uchar unsigned char
259#endif
260
261#if HAVE_UNSIGNED_CHAR
262#define schar signed char
263#else
264#define schar char
265#endif
266
267#ifndef int32
268#if (SIZEOF_INT == 4)
269#define int32 int
270#elif (SIZEOF_LONG == 4)
271#define int32 long
272#elif (SIZEOF_SHORT == 4)
273#define int32 short
274#else
275/* I hope this works */
276#define int32 int
277#define LARGE_INT32
278#endif
279#endif
280
281#ifndef uint32
282#define uint32 unsigned int32
283#endif
284
285#if HAVE_OFF64_T
286#define OFF_T off64_t
287#define STRUCT_STAT struct stat64
288#else
289#define OFF_T off_t
290#define STRUCT_STAT struct stat
291#endif
292
293#if HAVE_OFF64_T
294#define int64 off64_t
295#elif (SIZEOF_LONG == 8)
296#define int64 long
297#elif (SIZEOF_INT == 8)
298#define int64 int
299#elif HAVE_LONGLONG
300#define int64 long long
301#else
302/* As long as it gets... */
303#define int64 off_t
304#define NO_INT64
305#endif
306
307#if (SIZEOF_LONG == 8)
308#define uint64 unsigned long
309#elif (SIZEOF_INT == 8)
310#define uint64 unsigned int
311#elif HAVE_LONGLONG
312#define uint64 unsigned long long
313#else
314/* As long as it gets... */
315#define uint64 unsigned off_t
316#endif
317
318/* Starting from protocol version 26, we always use 64-bit
319 * ino_t and dev_t internally, even if this platform does not
320 * allow files to have 64-bit inums. That's because the
321 * receiver needs to find duplicate (dev,ino) tuples to detect
322 * hardlinks, and it might have files coming from a platform
323 * that has 64-bit inums.
324 *
325 * The only exception is if we're on a platform with no 64-bit type at
326 * all.
327 *
328 * Because we use read_longint() to get these off the wire, if you
329 * transfer devices or hardlinks with dev or inum > 2**32 to a machine
330 * with no 64-bit types then you will get an overflow error. Probably
331 * not many people have that combination of machines, and you can
332 * avoid it by not preserving hardlinks or not transferring device
333 * nodes. It's not clear that any other behaviour is better.
334 *
335 * Note that if you transfer devices from a 64-bit-devt machine (say,
336 * Solaris) to a 32-bit-devt machine (say, Linux-2.2/x86) then the
337 * device numbers will be truncated. But it's a kind of silly thing
338 * to do anyhow.
339 *
340 * FIXME: In future, we should probable split the device number into
341 * major/minor, and transfer the two parts as 32-bit ints. That gives
342 * you somewhat more of a chance that they'll come from a big machine
343 * to a little one in a useful way.
344 *
345 * FIXME: Really we need an unsigned type, and we perhaps ought to
346 * cope with platforms on which this is an unsigned int or even a
347 * struct. Later.
348 */
349#define INO64_T uint64
350#define DEV64_T uint64
351
352#ifndef MIN
353#define MIN(a,b) ((a)<(b)?(a):(b))
354#endif
355
356#ifndef MAX
357#define MAX(a,b) ((a)>(b)?(a):(b))
358#endif
359
360#ifndef MAXHOSTNAMELEN
361#define MAXHOSTNAMELEN 256
362#endif
363
364/* the length of the md4 checksum */
365#define MD4_SUM_LENGTH 16
366#define SUM_LENGTH 16
367#define SHORT_SUM_LENGTH 2
368#define BLOCKSUM_BIAS 10
369
370#ifndef MAXPATHLEN
371#define MAXPATHLEN 1024
372#endif
373
374#ifndef NAME_MAX
375#define NAME_MAX 255
376#endif
377
378#ifndef INADDR_NONE
379#define INADDR_NONE 0xffffffff
380#endif
381
382#ifndef IN_LOOPBACKNET
383#define IN_LOOPBACKNET 127
384#endif
385
386#define GID_NONE (gid_t) -1
387
388#define HL_CHECK_MASTER 0
389#define HL_SKIP 1
390
391struct hlink {
392 int hlindex;
393 struct file_struct *next;
394};
395
396struct idev {
397 INO64_T inode;
398 DEV64_T dev;
399};
400
401#define F_DEV link_u.idev->dev
402#define F_INODE link_u.idev->inode
403
404#define F_HLINDEX link_u.links->hlindex
405#define F_NEXT link_u.links->next
406
407struct file_struct {
408 time_t modtime;
409 OFF_T length;
410 mode_t mode;
411 union {
412 DEV64_T rdev; /* The device number, if this is a device */
413 char *sum; /* Only a normal file can have a checksum */
414 char *link; /* Holds symlink string, if a symlink */
415 } u;
416 union {
417 struct idev *idev;
418 struct hlink *links;
419 } link_u;
420 char *basename;
421 char *dirname;
422 char *basedir;
423 uid_t uid;
424 gid_t gid;
425 uchar flags;
426};
427
428#define ARENA_SIZE (32 * 1024)
429
430struct string_area {
431 char *base;
432 char *end;
433 char *current;
434 struct string_area *next;
435};
436
437struct file_list {
438 int count;
439 int malloced;
440 struct file_struct **files;
441 struct string_area *string_area;
442};
443
444struct sum_buf {
445 OFF_T offset; /**< offset in file of this chunk */
446 unsigned int len; /**< length of chunk of file */
447 int i; /**< index of this chunk */
448 uint32 sum1; /**< simple checksum */
449 char sum2[SUM_LENGTH]; /**< checksum */
450};
451
452struct sum_struct {
453 OFF_T flength; /**< total file length */
454 size_t count; /**< how many chunks */
455 unsigned int blength; /**< block_length */
456 unsigned int remainder; /**< flength % block_length */
457 int s2length; /**< sum2_length */
458 struct sum_buf *sums; /**< points to info for each chunk */
459};
460
461struct map_struct {
462 char *p; /* Window pointer */
463 int fd; /* File Descriptor */
464 int p_size; /* Window size at allocation */
465 int p_len; /* Window size after fill */
466 /* p_size and p_len could be
467 * consolodated by using a local
468 * variable in map_ptr() */
469 int status; /* first errno from read errors */
470 OFF_T file_size; /* File size (from stat) */
471 OFF_T p_offset; /* Window start */
472 OFF_T p_fd_offset; /* offset of cursor in fd ala lseek */
473};
474
475#define MATCHFLG_WILD (1<<0) /* pattern has '*', '[', and/or '?' */
476#define MATCHFLG_WILD2 (1<<1) /* pattern has '**' */
477#define MATCHFLG_WILD2_PREFIX (1<<2) /* pattern starts with '**' */
478#define MATCHFLG_ABS_PATH (1<<3) /* path-match on absolute path */
479struct exclude_struct {
480 char *pattern;
481 int match_flags;
482 int include;
483 int directory;
484 int slash_cnt;
485};
486
487struct stats {
488 int64 total_size;
489 int64 total_transferred_size;
490 int64 total_written;
491 int64 total_read;
492 int64 literal_data;
493 int64 matched_data;
494 int flist_size;
495 int num_files;
496 int num_transferred_files;
497 int current_file_index;
498};
499
500
501/* we need this function because of the silly way in which duplicate
502 entries are handled in the file lists - we can't change this
503 without breaking existing versions */
504static inline int flist_up(struct file_list *flist, int i)
505{
506 while (!flist->files[i]->basename) i++;
507 return i;
508}
509
510#include "byteorder.h"
511#include "lib/mdfour.h"
512#include "lib/wildmatch.h"
513#include "lib/permstring.h"
514#include "lib/addrinfo.h"
515
516#include "proto.h"
517
518/* We have replacement versions of these if they're missing. */
519#ifndef HAVE_ASPRINTF
520int asprintf(char **ptr, const char *format, ...);
521#endif
522
523#ifndef HAVE_VASPRINTF
524int vasprintf(char **ptr, const char *format, va_list ap);
525#endif
526
527#if !defined(HAVE_VSNPRINTF) || !defined(HAVE_C99_VSNPRINTF)
528#define vsnprintf rsync_vsnprintf
529int vsnprintf(char *str, size_t count, const char *fmt, va_list args);
530#endif
531
532#if !defined(HAVE_SNPRINTF) || !defined(HAVE_C99_VSNPRINTF)
533#define snprintf rsync_snprintf
534int snprintf(char *str,size_t count,const char *fmt,...);
535#endif
536
537
538#if !HAVE_STRERROR
539extern char *sys_errlist[];
540#define strerror(i) sys_errlist[i]
541#endif
542
543#ifndef HAVE_STRCHR
544# define strchr index
545# define strrchr rindex
546#endif
547
548#ifndef HAVE_ERRNO_DECL
549extern int errno;
550#endif
551
552#define SUPPORT_LINKS HAVE_READLINK
553#define SUPPORT_HARD_LINKS HAVE_LINK
554
555/* This could be bad on systems which have no lchown and where chown
556 * follows symbollic links. On such systems it might be better not to
557 * try to chown symlinks at all. */
558#ifndef HAVE_LCHOWN
559#define lchown chown
560#endif
561
562#define SIGNAL_CAST (RETSIGTYPE (*)())
563
564#ifndef EWOULDBLOCK
565#define EWOULDBLOCK EAGAIN
566#endif
567
568#ifndef STDIN_FILENO
569#define STDIN_FILENO 0
570#endif
571
572#ifndef STDOUT_FILENO
573#define STDOUT_FILENO 1
574#endif
575
576#ifndef STDERR_FILENO
577#define STDERR_FILENO 2
578#endif
579
580#ifndef S_IWUSR
581#define S_IWUSR 0200
582#endif
583
584#ifndef ACCESSPERMS
585#define ACCESSPERMS 0777
586#endif
587
588#ifndef S_ISVTX
589#define S_ISVTX 0
590#endif
591
592#define CHMOD_BITS (S_ISUID | S_ISGID | S_ISVTX | ACCESSPERMS)
593
594#ifndef _S_IFMT
595#define _S_IFMT 0170000
596#endif
597
598#ifndef _S_IFLNK
599#define _S_IFLNK 0120000
600#endif
601
602#ifndef S_ISLNK
603#define S_ISLNK(mode) (((mode) & (_S_IFMT)) == (_S_IFLNK))
604#endif
605
606#ifndef S_ISBLK
607#define S_ISBLK(mode) (((mode) & (_S_IFMT)) == (_S_IFBLK))
608#endif
609
610#ifndef S_ISCHR
611#define S_ISCHR(mode) (((mode) & (_S_IFMT)) == (_S_IFCHR))
612#endif
613
614#ifndef S_ISSOCK
615#ifdef _S_IFSOCK
616#define S_ISSOCK(mode) (((mode) & (_S_IFMT)) == (_S_IFSOCK))
617#else
618#define S_ISSOCK(mode) (0)
619#endif
620#endif
621
622#ifndef S_ISFIFO
623#ifdef _S_IFIFO
624#define S_ISFIFO(mode) (((mode) & (_S_IFMT)) == (_S_IFIFO))
625#else
626#define S_ISFIFO(mode) (0)
627#endif
628#endif
629
630#ifndef S_ISDIR
631#define S_ISDIR(mode) (((mode) & (_S_IFMT)) == (_S_IFDIR))
632#endif
633
634#ifndef S_ISREG
635#define S_ISREG(mode) (((mode) & (_S_IFMT)) == (_S_IFREG))
636#endif
637
638/* work out what fcntl flag to use for non-blocking */
639#ifdef O_NONBLOCK
640# define NONBLOCK_FLAG O_NONBLOCK
641#elif defined(SYSV)
642# define NONBLOCK_FLAG O_NDELAY
643#else
644# define NONBLOCK_FLAG FNDELAY
645#endif
646
647#ifndef INADDR_LOOPBACK
648#define INADDR_LOOPBACK 0x7f000001
649#endif
650
651#ifndef INADDR_NONE
652#define INADDR_NONE 0xffffffff
653#endif
654
655#define IS_DEVICE(mode) (S_ISCHR(mode) || S_ISBLK(mode) || S_ISSOCK(mode) || S_ISFIFO(mode))
656
657/* Initial mask on permissions given to temporary files. Mask off setuid
658 bits and group access because of potential race-condition security
659 holes, and mask other access because mode 707 is bizarre */
660#define INITACCESSPERMS 0700
661
662/* handler for null strings in printf format */
663#define NS(s) ((s)?(s):"<NULL>")
664
665#if !defined(__GNUC__) || defined(APPLE)
666/* Apparently the OS X port of gcc gags on __attribute__.
667 *
668 * <http://www.opensource.apple.com/bugs/X/gcc/2512150.html> */
669#define __attribute__(x)
670
671#endif
672
673/* Convenient wrappers for malloc and realloc. Use them. */
674#define new(type) ((type *)malloc(sizeof(type)))
675#define new_array(type, num) ((type *)_new_array(sizeof(type), (num)))
676#define realloc_array(ptr, type, num) ((type *)_realloc_array((ptr), sizeof(type), (num)))
677
678/* use magic gcc attributes to catch format errors */
679 void rprintf(enum logcode , const char *, ...)
680 __attribute__((format (printf, 2, 3)))
681;
682
683/* This is just like rprintf, but it also tries to print some
684 * representation of the error code. Normally errcode = errno. */
685void rsyserr(enum logcode, int, const char *, ...)
686 __attribute__((format (printf, 3, 4)))
687 ;
688
689#ifdef REPLACE_INET_NTOA
690#define inet_ntoa rep_inet_ntoa
691#endif
692
693/* Make sure that the O_BINARY flag is defined. */
694#ifndef O_BINARY
695#define O_BINARY 0
696#endif
697
698#ifndef HAVE_STRLCPY
699size_t strlcpy(char *d, const char *s, size_t bufsize);
700#endif
701
702#ifndef HAVE_STRLCAT
703size_t strlcat(char *d, const char *s, size_t bufsize);
704#endif
705
706#ifndef WEXITSTATUS
707#define WEXITSTATUS(stat) ((int)(((stat)>>8)&0xFF))
708#endif
709
710#define exit_cleanup(code) _exit_cleanup(code, __FILE__, __LINE__)
711
712
713extern int verbose;
714
715#ifndef HAVE_INET_NTOP
716const char *
717inet_ntop(int af, const void *src, char *dst, size_t size);
718#endif /* !HAVE_INET_NTOP */
719
720#ifndef HAVE_INET_PTON
721int inet_pton(int af, const char *src, void *dst);
722#endif
723
724#ifdef MAINTAINER_MODE
725const char *get_panic_action(void);
726#endif
727
728#define UNUSED(x) x __attribute__((__unused__))
729
730extern const char *io_write_phase, *io_read_phase;