1
0
mirror of https://github.com/systemd/systemd.git synced 2025-03-21 02:50:18 +03:00

util: split all hostname related calls into hostname-util.c

This commit is contained in:
Lennart Poettering 2015-05-18 17:10:07 +02:00
parent 3b920d78b4
commit 958b66ea16
29 changed files with 234 additions and 152 deletions

View File

@ -915,7 +915,9 @@ libsystemd_shared_la_SOURCES = \
src/shared/import-util.c \
src/shared/import-util.h \
src/shared/sysctl-util.c \
src/shared/sysctl-util.h
src/shared/sysctl-util.h \
src/shared/hostname-util.h \
src/shared/hostname-util.c
if HAVE_UTMP
libsystemd_shared_la_SOURCES += \

View File

@ -23,11 +23,12 @@
#include <errno.h>
#include <stdlib.h>
#include "hostname-setup.h"
#include "macro.h"
#include "util.h"
#include "log.h"
#include "fileio.h"
#include "hostname-util.h"
#include "hostname-setup.h"
static int read_and_strip_hostname(const char *path, char **hn) {
char *s;

View File

@ -36,6 +36,7 @@
#include "locale-util.h"
#include "ask-password-api.h"
#include "terminal-util.h"
#include "hostname-util.h"
static char *arg_root = NULL;
static char *arg_locale = NULL; /* $LANG */

View File

@ -26,13 +26,13 @@
#include <string.h>
#include "sd-bus.h"
#include "sd-id128.h"
#include "hostname-util.h"
#include "bus-util.h"
#include "bus-error.h"
#include "util.h"
#include "spawn-polkit-agent.h"
#include "build.h"
#include "sd-id128.h"
#include "architecture.h"
static bool arg_ask_password = true;

View File

@ -33,6 +33,7 @@
#include "bus-util.h"
#include "event-util.h"
#include "selinux-util.h"
#include "hostname-util.h"
#define VALID_DEPLOYMENT_CHARS (DIGITS LETTERS "-.:")

View File

@ -38,6 +38,7 @@
#include "import-common.h"
#include "pull-dkr.h"
#include "process-util.h"
#include "hostname-util.h"
typedef enum DkrProgress {
DKR_SEARCHING,

View File

@ -42,6 +42,7 @@
#include "build.h"
#include "fileio.h"
#include "sigbus.h"
#include "hostname-util.h"
static char *arg_key_pem = NULL;
static char *arg_cert_pem = NULL;

View File

@ -61,6 +61,7 @@
#include "bus-util.h"
#include "bus-error.h"
#include "terminal-util.h"
#include "hostname-util.h"
#define DEFAULT_FSS_INTERVAL_USEC (15*USEC_PER_MINUTE)

View File

@ -39,6 +39,10 @@
#include "missing.h"
#include "conf-parser.h"
#include "selinux-util.h"
#include "acl-util.h"
#include "formats-util.h"
#include "process-util.h"
#include "hostname-util.h"
#include "journal-internal.h"
#include "journal-vacuum.h"
#include "journal-authenticate.h"
@ -49,9 +53,6 @@
#include "journald-native.h"
#include "journald-audit.h"
#include "journald-server.h"
#include "acl-util.h"
#include "formats-util.h"
#include "process-util.h"
#ifdef HAVE_SELINUX
#include <selinux/selinux.h>

View File

@ -27,7 +27,7 @@
#include "fileio.h"
#include "unaligned.h"
#include "in-addr-util.h"
#include "hostname-util.h"
#include "dhcp-protocol.h"
#include "dhcp-lease-internal.h"
#include "sd-dhcp-lease.h"

View File

@ -42,6 +42,7 @@
#include "bus-error.h"
#include "formats-util.h"
#include "terminal-util.h"
#include "hostname-util.h"
static int parse_argv(
pam_handle_t *handle,

View File

@ -22,6 +22,7 @@
#include <netinet/ether.h>
#include <linux/if.h>
#include "hostname-util.h"
#include "networkd-link.h"
#include "network-internal.h"
#include "dhcp-lease-internal.h"

View File

@ -25,6 +25,7 @@
#include "conf-files.h"
#include "conf-parser.h"
#include "util.h"
#include "hostname-util.h"
#include "networkd.h"
#include "networkd-netdev.h"
#include "networkd-link.h"

View File

@ -52,11 +52,11 @@
#include <blkid/blkid.h>
#endif
#include "random-util.h"
#include "sd-daemon.h"
#include "sd-bus.h"
#include "sd-id128.h"
#include "sd-rtnl.h"
#include "random-util.h"
#include "log.h"
#include "util.h"
#include "mkdir.h"
@ -95,6 +95,7 @@
#include "formats-util.h"
#include "process-util.h"
#include "terminal-util.h"
#include "hostname-util.h"
#ifdef HAVE_SECCOMP
#include "seccomp-util.h"

View File

@ -29,6 +29,7 @@
#include "local-addresses.h"
#include "macro.h"
#include "nss-util.h"
#include "hostname-util.h"
#include "util.h"
/* We use 127.0.0.2 as IPv4 address. This has the advantage over

View File

@ -25,9 +25,10 @@
#include "strv.h"
#include "socket-util.h"
#include "af-list.h"
#include "random-util.h"
#include "hostname-util.h"
#include "resolved-dns-domain.h"
#include "resolved-dns-scope.h"
#include "random-util.h"
#define MULTICAST_RATELIMIT_INTERVAL_USEC (1*USEC_PER_SEC)
#define MULTICAST_RATELIMIT_BURST 1000

View File

@ -32,6 +32,7 @@
#include "fileio-label.h"
#include "ordered-set.h"
#include "random-util.h"
#include "hostname-util.h"
#include "resolved-dns-domain.h"
#include "resolved-conf.h"

View File

@ -35,8 +35,9 @@
#include "ima-util.h"
#include "selinux-util.h"
#include "audit.h"
#include "condition.h"
#include "cap-list.h"
#include "hostname-util.h"
#include "condition.h"
Condition* condition_new(ConditionType type, const char *parameter, bool trigger, bool negate) {
Condition *c;

160
src/shared/hostname-util.c Normal file
View File

@ -0,0 +1,160 @@
/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
/***
This file is part of systemd.
Copyright 2015 Lennart Poettering
systemd is free software; you can redistribute it and/or modify it
under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 2.1 of the License, or
(at your option) any later version.
systemd is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with systemd; If not, see <http://www.gnu.org/licenses/>.
***/
#include <sys/utsname.h>
#include <ctype.h>
#include "util.h"
#include "hostname-util.h"
bool hostname_is_set(void) {
struct utsname u;
assert_se(uname(&u) >= 0);
if (isempty(u.nodename))
return false;
/* This is the built-in kernel default host name */
if (streq(u.nodename, "(none)"))
return false;
return true;
}
char* gethostname_malloc(void) {
struct utsname u;
assert_se(uname(&u) >= 0);
if (isempty(u.nodename) || streq(u.nodename, "(none)"))
return strdup(u.sysname);
return strdup(u.nodename);
}
static bool hostname_valid_char(char c) {
return
(c >= 'a' && c <= 'z') ||
(c >= 'A' && c <= 'Z') ||
(c >= '0' && c <= '9') ||
c == '-' ||
c == '_' ||
c == '.';
}
bool hostname_is_valid(const char *s) {
const char *p;
bool dot;
if (isempty(s))
return false;
/* Doesn't accept empty hostnames, hostnames with trailing or
* leading dots, and hostnames with multiple dots in a
* sequence. Also ensures that the length stays below
* HOST_NAME_MAX. */
for (p = s, dot = true; *p; p++) {
if (*p == '.') {
if (dot)
return false;
dot = true;
} else {
if (!hostname_valid_char(*p))
return false;
dot = false;
}
}
if (dot)
return false;
if (p-s > HOST_NAME_MAX)
return false;
return true;
}
char* hostname_cleanup(char *s, bool lowercase) {
char *p, *d;
bool dot;
assert(s);
for (p = s, d = s, dot = true; *p; p++) {
if (*p == '.') {
if (dot)
continue;
*(d++) = '.';
dot = true;
} else if (hostname_valid_char(*p)) {
*(d++) = lowercase ? tolower(*p) : *p;
dot = false;
}
}
if (dot && d > s)
d[-1] = 0;
else
*d = 0;
strshorten(s, HOST_NAME_MAX);
return s;
}
bool is_localhost(const char *hostname) {
assert(hostname);
/* This tries to identify local host and domain names
* described in RFC6761 plus the redhatism of .localdomain */
return streq(hostname, "localhost") ||
streq(hostname, "localhost.") ||
streq(hostname, "localdomain.") ||
streq(hostname, "localdomain") ||
endswith(hostname, ".localhost") ||
endswith(hostname, ".localhost.") ||
endswith(hostname, ".localdomain") ||
endswith(hostname, ".localdomain.");
}
int sethostname_idempotent(const char *s) {
char buf[HOST_NAME_MAX + 1] = {};
assert(s);
if (gethostname(buf, sizeof(buf)) < 0)
return -errno;
if (streq(buf, s))
return 0;
if (sethostname(s, strlen(s)) < 0)
return -errno;
return 1;
}

View File

@ -0,0 +1,37 @@
/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
#pragma once
/***
This file is part of systemd.
Copyright 2010-2015 Lennart Poettering
systemd is free software; you can redistribute it and/or modify it
under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation; either version 2.1 of the License, or
(at your option) any later version.
systemd is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with systemd; If not, see <http://www.gnu.org/licenses/>.
***/
#include <stdbool.h>
#include "macro.h"
bool hostname_is_set(void);
char* gethostname_malloc(void);
bool hostname_is_valid(const char *s) _pure_;
char* hostname_cleanup(char *s, bool lowercase);
bool is_localhost(const char *hostname);
int sethostname_idempotent(const char *s);

View File

@ -24,6 +24,7 @@
#include "macro.h"
#include "util.h"
#include "hostname-util.h"
#include "specifier.h"
/*

View File

@ -92,6 +92,7 @@
#include "process-util.h"
#include "random-util.h"
#include "terminal-util.h"
#include "hostname-util.h"
/* Put this test here for a lack of better place */
assert_cc(EAGAIN == EWOULDBLOCK);
@ -1934,26 +1935,6 @@ int sigprocmask_many(int how, ...) {
return 0;
}
char* gethostname_malloc(void) {
struct utsname u;
assert_se(uname(&u) >= 0);
if (!isempty(u.nodename) && !streq(u.nodename, "(none)"))
return strdup(u.nodename);
return strdup(u.sysname);
}
bool hostname_is_set(void) {
struct utsname u;
assert_se(uname(&u) >= 0);
return !isempty(u.nodename) && !streq(u.nodename, "(none)");
}
char *lookup_uid(uid_t uid) {
long bufsize;
char *name;
@ -2585,79 +2566,6 @@ char* strshorten(char *s, size_t l) {
return s;
}
static bool hostname_valid_char(char c) {
return
(c >= 'a' && c <= 'z') ||
(c >= 'A' && c <= 'Z') ||
(c >= '0' && c <= '9') ||
c == '-' ||
c == '_' ||
c == '.';
}
bool hostname_is_valid(const char *s) {
const char *p;
bool dot;
if (isempty(s))
return false;
/* Doesn't accept empty hostnames, hostnames with trailing or
* leading dots, and hostnames with multiple dots in a
* sequence. Also ensures that the length stays below
* HOST_NAME_MAX. */
for (p = s, dot = true; *p; p++) {
if (*p == '.') {
if (dot)
return false;
dot = true;
} else {
if (!hostname_valid_char(*p))
return false;
dot = false;
}
}
if (dot)
return false;
if (p-s > HOST_NAME_MAX)
return false;
return true;
}
char* hostname_cleanup(char *s, bool lowercase) {
char *p, *d;
bool dot;
for (p = s, d = s, dot = true; *p; p++) {
if (*p == '.') {
if (dot)
continue;
*(d++) = '.';
dot = true;
} else if (hostname_valid_char(*p)) {
*(d++) = lowercase ? tolower(*p) : *p;
dot = false;
}
}
if (dot && d > s)
d[-1] = 0;
else
*d = 0;
strshorten(s, HOST_NAME_MAX);
return s;
}
bool machine_name_is_valid(const char *s) {
if (!hostname_is_valid(s))
@ -5355,23 +5263,6 @@ int tempfn_random_child(const char *p, char **ret) {
return 0;
}
/* make sure the hostname is not "localhost" */
bool is_localhost(const char *hostname) {
assert(hostname);
/* This tries to identify local host and domain names
* described in RFC6761 plus the redhatism of .localdomain */
return streq(hostname, "localhost") ||
streq(hostname, "localhost.") ||
streq(hostname, "localdomain.") ||
streq(hostname, "localdomain") ||
endswith(hostname, ".localhost") ||
endswith(hostname, ".localhost.") ||
endswith(hostname, ".localdomain") ||
endswith(hostname, ".localdomain.");
}
int take_password_lock(const char *root) {
struct flock flock = {
@ -5729,26 +5620,6 @@ int free_and_strdup(char **p, const char *s) {
return 1;
}
int sethostname_idempotent(const char *s) {
int r;
char buf[HOST_NAME_MAX + 1] = {};
assert(s);
r = gethostname(buf, sizeof(buf));
if (r < 0)
return -errno;
if (streq(buf, s))
return 0;
r = sethostname(s, strlen(s));
if (r < 0)
return -errno;
return 1;
}
int ptsname_malloc(int fd, char **ret) {
size_t l = 100;

View File

@ -351,10 +351,7 @@ char* dirname_malloc(const char *path);
void sigset_add_many(sigset_t *ss, ...);
int sigprocmask_many(int how, ...);
bool hostname_is_set(void);
char* lookup_uid(uid_t uid);
char* gethostname_malloc(void);
char* getlogname_malloc(void);
char* getusername_malloc(void);
@ -397,9 +394,6 @@ bool nulstr_contains(const char*nulstr, const char *needle);
bool plymouth_running(void);
bool hostname_is_valid(const char *s) _pure_;
char* hostname_cleanup(char *s, bool lowercase);
bool machine_name_is_valid(const char *s) _pure_;
char* strshorten(char *s, size_t l);
@ -846,8 +840,6 @@ int tempfn_xxxxxx(const char *p, char **ret);
int tempfn_random(const char *p, char **ret);
int tempfn_random_child(const char *p, char **ret);
bool is_localhost(const char *hostname);
int take_password_lock(const char *root);
int is_symlink(const char *path);
@ -864,8 +856,6 @@ int unquote_many_words(const char **p, UnquoteFlags flags, ...) _sentinel_;
int free_and_strdup(char **p, const char *s);
int sethostname_idempotent(const char *s);
#define INOTIFY_EVENT_MAX (sizeof(struct inotify_event) + NAME_MAX + 1)
#define FOREACH_INOTIFY_EVENT(e, buffer, sz) \

View File

@ -29,8 +29,9 @@
#include "macro.h"
#include "path-util.h"
#include "utmp-wtmp.h"
#include "terminal-util.h"
#include "hostname-util.h"
#include "utmp-wtmp.h"
int utmp_get_runlevel(int *runlevel, int *previous) {
struct utmpx *found, lookup = { .ut_type = RUN_LVL };

View File

@ -71,6 +71,7 @@
#include "formats-util.h"
#include "process-util.h"
#include "terminal-util.h"
#include "hostname-util.h"
static char **arg_types = NULL;
static char **arg_states = NULL;

View File

@ -28,6 +28,7 @@
#include "ima-util.h"
#include "apparmor-util.h"
#include "smack-util.h"
#include "hostname-util.h"
static void test_condition_test_path(void) {
Condition *condition;

View File

@ -36,6 +36,7 @@
#include "strv.h"
#include "fileio.h"
#include "test-helper.h"
#include "hostname-util.h"
static int test_unit_file_get_set(void) {
int r;

View File

@ -35,6 +35,7 @@
#include "macro.h"
#include "path-util.h"
#include "test-helper.h"
#include "hostname-util.h"
static void test_unit_name_is_valid(void) {
assert_se(unit_name_is_valid("foo.service", UNIT_NAME_ANY));

View File

@ -38,6 +38,7 @@
#include "conf-parser.h"
#include "virt.h"
#include "process-util.h"
#include "hostname-util.h"
static void test_streq_ptr(void) {
assert_se(streq_ptr(NULL, NULL));