X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/bc363ea983a5b5db44c71bf0cb8310fddb740dc8..8950ac03f8fd0fb645c7d2374195ea884d091f72:/clientserver.c diff --git a/clientserver.c b/clientserver.c index 41b8dfa8..1baa1e09 100644 --- a/clientserver.c +++ b/clientserver.c @@ -1,6 +1,7 @@ /* -*- c-file-style: "linux"; -*- - Copyright (C) 1998-2000 by Andrew Tridgell + Copyright (C) 1998-2001 by Andrew Tridgell + Copyright (C) 2001 by Martin Pool This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -28,7 +29,6 @@ extern int rsync_port; char *auth_user; int sanitize_paths = 0; - /* * Run a client connected to an rsyncd. The alternative to this * function for remote-shell connections is do_cmd. @@ -63,7 +63,7 @@ int start_socket_client(char *host, char *path, int argc, char *argv[]) } if (*path == '/') { - rprintf(FERROR,"ERROR: The remote path must start with a module name\n"); + rprintf(FERROR,"ERROR: The remote path must start with a module name not a /\n"); return -1; } @@ -141,7 +141,7 @@ static int rsync_module(int fd, int i) char *argv[MAX_ARGS]; char **argp; char line[MAXPATHLEN]; - uid_t uid = (uid_t)-2; + uid_t uid = (uid_t)-2; /* canonically "nobody" */ gid_t gid = (gid_t)-2; char *p; char *addr = client_addr(fd); @@ -196,7 +196,7 @@ static int rsync_module(int fd, int i) if (!name_to_uid(p, &uid)) { if (!isdigit(*p)) { rprintf(FERROR,"Invalid uid %s\n", p); - io_printf(fd,"@ERROR: invalid uid\n"); + io_printf(fd,"@ERROR: invalid uid %s\n", p); return -1; } uid = atoi(p); @@ -206,12 +206,19 @@ static int rsync_module(int fd, int i) if (!name_to_gid(p, &gid)) { if (!isdigit(*p)) { rprintf(FERROR,"Invalid gid %s\n", p); - io_printf(fd,"@ERROR: invalid gid\n"); + io_printf(fd,"@ERROR: invalid gid %s\n", p); return -1; } gid = atoi(p); } } + + /* TODO: If we're not root, but the configuration requests + * that we change to some uid other than the current one, then + * log a warning. */ + + /* TODO: Perhaps take a list of gids, and make them into the + * supplementary groups. */ p = lp_include_from(i); add_exclude_file(p, 1, 1); @@ -315,7 +322,8 @@ static int rsync_module(int fd, int i) } } - ret = parse_arguments(argc, argv, 0); + argp = argv; + ret = parse_arguments(&argc, (const char ***) &argp, 0); if (request) { if (*auth_user) { @@ -330,22 +338,27 @@ static int rsync_module(int fd, int i) free(request); } -#if !TRIDGE +#ifndef DEBUG /* don't allow the logs to be flooded too fast */ if (verbose > 1) verbose = 1; #endif - argc -= optind; - argp = argv + optind; - optind = 0; - if (remote_version < 23) { if (remote_version == 22 || (remote_version > 17 && am_sender)) io_start_multiplex_out(fd); } - + + /* For later protocol versions, we don't start multiplexing + * until we've configured nonblocking in start_server. That + * means we're in a sticky situation now: there's no way to + * convey errors to the client. */ + + /* FIXME: Hold off on reporting option processing errors until + * we've set up nonblocking and multiplexed IO and can get the + * message back to them. */ if (!ret) { - option_error(); + option_error(); + exit_cleanup(RERR_UNSUPPORTED); } if (lp_timeout(i)) { @@ -470,7 +483,10 @@ int daemon_main(void) log_init(); - rprintf(FINFO,"rsyncd version %s starting\n",VERSION); + rprintf(FINFO, "rsyncd version %s starting, listening on port %d\n", VERSION, + rsync_port); + /* TODO: If listening on a particular address, then show that + * address too. */ if (((pid_file = lp_pid_file()) != NULL) && (*pid_file != '\0')) { char pidbuf[16]; @@ -483,7 +499,7 @@ int daemon_main(void) rsyserr(FLOG, errno, "failed to create pid file %s", pid_file); exit_cleanup(RERR_FILEIO); } - slprintf(pidbuf, sizeof(pidbuf), "%d\n", pid); + snprintf(pidbuf, sizeof(pidbuf), "%d\n", pid); write(fd, pidbuf, strlen(pidbuf)); close(fd); }