mirror of
https://github.com/yarrick/iodine.git
synced 2024-11-22 04:56:07 +03:00
Simplify cleanup code
This commit is contained in:
parent
ec0e3f2e51
commit
7a51b22909
@ -2587,32 +2587,32 @@ main(int argc, char **argv)
|
|||||||
read_password(password, sizeof(password));
|
read_password(password, sizeof(password));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Mark both file descriptors as unused */
|
||||||
|
dns_fds.v4fd = -1;
|
||||||
|
dns_fds.v6fd = -1;
|
||||||
|
|
||||||
created_users = init_users(my_ip, netmask);
|
created_users = init_users(my_ip, netmask);
|
||||||
|
|
||||||
if ((tun_fd = open_tun(device)) == -1) {
|
if ((tun_fd = open_tun(device)) == -1) {
|
||||||
retval = 1;
|
/* nothing to clean up, just return */
|
||||||
goto cleanup_none;
|
return 1;
|
||||||
}
|
}
|
||||||
if (!skipipconfig) {
|
if (!skipipconfig) {
|
||||||
const char *other_ip = users_get_first_ip();
|
const char *other_ip = users_get_first_ip();
|
||||||
if (tun_setip(argv[0], other_ip, netmask) != 0 || tun_setmtu(mtu) != 0) {
|
if (tun_setip(argv[0], other_ip, netmask) != 0 || tun_setmtu(mtu) != 0) {
|
||||||
retval = 1;
|
retval = 1;
|
||||||
free((void*) other_ip);
|
free((void*) other_ip);
|
||||||
goto cleanup_tun;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
free((void*) other_ip);
|
free((void*) other_ip);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Mark both file descriptors as unused */
|
|
||||||
dns_fds.v4fd = -1;
|
|
||||||
dns_fds.v6fd = -1;
|
|
||||||
|
|
||||||
#ifdef HAVE_SYSTEMD
|
#ifdef HAVE_SYSTEMD
|
||||||
nb_fds = sd_listen_fds(0);
|
nb_fds = sd_listen_fds(0);
|
||||||
if (nb_fds > 1) {
|
if (nb_fds > 1) {
|
||||||
retval = 1;
|
retval = 1;
|
||||||
warnx("Too many file descriptors received!\n");
|
warnx("Too many file descriptors received!\n");
|
||||||
goto cleanup_tun;
|
goto cleanup;
|
||||||
} else if (nb_fds == 1) {
|
} else if (nb_fds == 1) {
|
||||||
/* XXX: assume we get IPv4 socket */
|
/* XXX: assume we get IPv4 socket */
|
||||||
dns_fds.v4fd = SD_LISTEN_FDS_START;
|
dns_fds.v4fd = SD_LISTEN_FDS_START;
|
||||||
@ -2620,11 +2620,11 @@ main(int argc, char **argv)
|
|||||||
#endif
|
#endif
|
||||||
if ((dns_fds.v4fd = open_dns(&dns4addr, dns4addr_len)) < 0) {
|
if ((dns_fds.v4fd = open_dns(&dns4addr, dns4addr_len)) < 0) {
|
||||||
retval = 1;
|
retval = 1;
|
||||||
goto cleanup_tun;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
if ((dns_fds.v6fd = open_dns(&dns6addr, dns6addr_len)) < 0) {
|
if ((dns_fds.v6fd = open_dns(&dns6addr, dns6addr_len)) < 0) {
|
||||||
retval = 1;
|
retval = 1;
|
||||||
goto cleanup_dns;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
#ifdef HAVE_SYSTEMD
|
#ifdef HAVE_SYSTEMD
|
||||||
}
|
}
|
||||||
@ -2632,7 +2632,7 @@ main(int argc, char **argv)
|
|||||||
if (bind_enable) {
|
if (bind_enable) {
|
||||||
if ((bind_fd = open_dns_from_host(NULL, 0, AF_INET, 0)) < 0) {
|
if ((bind_fd = open_dns_from_host(NULL, 0, AF_INET, 0)) < 0) {
|
||||||
retval = 1;
|
retval = 1;
|
||||||
goto cleanup_dns;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2681,14 +2681,12 @@ main(int argc, char **argv)
|
|||||||
|
|
||||||
syslog(LOG_INFO, "stopping");
|
syslog(LOG_INFO, "stopping");
|
||||||
close_dns(bind_fd);
|
close_dns(bind_fd);
|
||||||
cleanup_dns:
|
cleanup:
|
||||||
if (dns_fds.v6fd >= 0)
|
if (dns_fds.v6fd >= 0)
|
||||||
close_dns(dns_fds.v6fd);
|
close_dns(dns_fds.v6fd);
|
||||||
if (dns_fds.v4fd >= 0)
|
if (dns_fds.v4fd >= 0)
|
||||||
close_dns(dns_fds.v4fd);
|
close_dns(dns_fds.v4fd);
|
||||||
cleanup_tun:
|
|
||||||
close_tun(tun_fd);
|
close_tun(tun_fd);
|
||||||
cleanup_none:
|
|
||||||
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user