mirror of
https://github.com/git/git.git
synced 2026-03-18 20:50:07 +01:00
daemon: allow more than one host address given via --listen
When the host has more than one interfaces, daemon can listen to all of them by not giving any --listen option, or listen to only one. Teach it to accept more than one --listen options. Remove the hostname information form the die, if no socket could be created. It would only trigger when no interface out of either all interface or the ones specified on the command line with --listen options, can be listened to and so the user does know which "host" was asked. Signed-off-by: Alexander Sulfrian <alexander@sulfrian.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
committed by
Junio C Hamano
parent
9b178ba84d
commit
1656b65a8b
@@ -85,6 +85,7 @@ OPTIONS
|
||||
be either an IPv4 address or an IPv6 address if supported. If IPv6
|
||||
is not supported, then --listen=hostname is also not supported and
|
||||
--listen must be given an IPv4 address.
|
||||
Can be given more than once.
|
||||
Incompatible with '--inetd' option.
|
||||
|
||||
--port=n::
|
||||
|
||||
33
daemon.c
33
daemon.c
@@ -3,6 +3,7 @@
|
||||
#include "exec_cmd.h"
|
||||
#include "run-command.h"
|
||||
#include "strbuf.h"
|
||||
#include "string-list.h"
|
||||
|
||||
#include <syslog.h>
|
||||
|
||||
@@ -861,11 +862,20 @@ static int setup_named_sock(char *listen_addr, int listen_port, int **socklist_p
|
||||
|
||||
#endif
|
||||
|
||||
static int socksetup(char *listen_addr, int listen_port, int **socklist_p)
|
||||
static int socksetup(struct string_list *listen_addr, int listen_port, int **socklist_p)
|
||||
{
|
||||
int socknum = 0, *socklist = NULL;
|
||||
|
||||
socknum = setup_named_sock(listen_addr, listen_port, &socklist, socknum);
|
||||
if (!listen_addr->nr)
|
||||
socknum = setup_named_sock(NULL, listen_port, &socklist,
|
||||
socknum);
|
||||
else {
|
||||
int i;
|
||||
for (i = 0; i < listen_addr->nr; i++)
|
||||
socknum = setup_named_sock(listen_addr->items[i].string,
|
||||
listen_port, &socklist,
|
||||
socknum);
|
||||
}
|
||||
|
||||
*socklist_p = socklist;
|
||||
return socknum;
|
||||
@@ -959,14 +969,14 @@ static void store_pid(const char *path)
|
||||
die_errno("failed to write pid file '%s'", path);
|
||||
}
|
||||
|
||||
static int serve(char *listen_addr, int listen_port, struct passwd *pass, gid_t gid)
|
||||
static int serve(struct string_list *listen_addr, int listen_port, struct passwd *pass, gid_t gid)
|
||||
{
|
||||
int socknum, *socklist;
|
||||
|
||||
socknum = socksetup(listen_addr, listen_port, &socklist);
|
||||
if (socknum == 0)
|
||||
die("unable to allocate any listen sockets on host %s port %u",
|
||||
listen_addr, listen_port);
|
||||
die("unable to allocate any listen sockets on port %u",
|
||||
listen_port);
|
||||
|
||||
if (pass && gid &&
|
||||
(initgroups(pass->pw_name, gid) || setgid (gid) ||
|
||||
@@ -979,7 +989,7 @@ static int serve(char *listen_addr, int listen_port, struct passwd *pass, gid_t
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
int listen_port = 0;
|
||||
char *listen_addr = NULL;
|
||||
struct string_list listen_addr = STRING_LIST_INIT_NODUP;
|
||||
int inetd_mode = 0;
|
||||
const char *pid_file = NULL, *user_name = NULL, *group_name = NULL;
|
||||
int detach = 0;
|
||||
@@ -987,6 +997,7 @@ int main(int argc, char **argv)
|
||||
struct group *group;
|
||||
gid_t gid = 0;
|
||||
int i;
|
||||
int return_value;
|
||||
|
||||
git_extract_argv0_path(argv[0]);
|
||||
|
||||
@@ -994,7 +1005,7 @@ int main(int argc, char **argv)
|
||||
char *arg = argv[i];
|
||||
|
||||
if (!prefixcmp(arg, "--listen=")) {
|
||||
listen_addr = xstrdup_tolower(arg + 9);
|
||||
string_list_append(&listen_addr, xstrdup_tolower(arg + 9));
|
||||
continue;
|
||||
}
|
||||
if (!prefixcmp(arg, "--port=")) {
|
||||
@@ -1119,7 +1130,7 @@ int main(int argc, char **argv)
|
||||
if (inetd_mode && (group_name || user_name))
|
||||
die("--user and --group are incompatible with --inetd");
|
||||
|
||||
if (inetd_mode && (listen_port || listen_addr))
|
||||
if (inetd_mode && (listen_port || (listen_addr.nr > 0)))
|
||||
die("--listen= and --port= are incompatible with --inetd");
|
||||
else if (listen_port == 0)
|
||||
listen_port = DEFAULT_GIT_PORT;
|
||||
@@ -1174,5 +1185,9 @@ int main(int argc, char **argv)
|
||||
if (pid_file)
|
||||
store_pid(pid_file);
|
||||
|
||||
return serve(listen_addr, listen_port, pass, gid);
|
||||
return_value = serve(&listen_addr, listen_port, pass, gid);
|
||||
|
||||
string_list_clear(&listen_addr, 0);
|
||||
|
||||
return return_value;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user