mirror of
https://github.com/systemd/systemd.git
synced 2025-01-10 05:18:17 +03:00
Merge pull request #32915 from yuwata/machine-id-setup
machine-id-setup: acquire machine ID from /run/machine-id if possible
This commit is contained in:
commit
eb0c2da89e
@ -48,24 +48,32 @@ static int acquire_machine_id_from_credential(sd_id128_t *ret) {
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int generate_machine_id(const char *root, sd_id128_t *ret) {
|
static int acquire_machine_id(const char *root, sd_id128_t *ret) {
|
||||||
_cleanup_close_ int fd = -EBADF;
|
_cleanup_close_ int fd = -EBADF;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
assert(ret);
|
assert(ret);
|
||||||
|
|
||||||
/* First, try reading the D-Bus machine id, unless it is a symlink */
|
/* First, try reading the machine ID from /run/machine-id, which may not be mounted on
|
||||||
|
* /etc/machine-id yet. This is important on switching root, Otherwise, machine ID may be changed
|
||||||
|
* after the transition. */
|
||||||
|
if (empty_or_root(root) && running_in_chroot() <= 0 &&
|
||||||
|
id128_read("/run/machine-id", ID128_FORMAT_PLAIN, ret) >= 0) {
|
||||||
|
log_info("Reusing machine ID stored in /run/machine-id.");
|
||||||
|
return 1; /* Indicate that the machine ID is reused. */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Then, try reading the D-Bus machine id, unless it is a symlink */
|
||||||
fd = chase_and_open("/var/lib/dbus/machine-id", root, CHASE_PREFIX_ROOT | CHASE_NOFOLLOW, O_RDONLY|O_CLOEXEC|O_NOCTTY, NULL);
|
fd = chase_and_open("/var/lib/dbus/machine-id", root, CHASE_PREFIX_ROOT | CHASE_NOFOLLOW, O_RDONLY|O_CLOEXEC|O_NOCTTY, NULL);
|
||||||
if (fd >= 0 && id128_read_fd(fd, ID128_FORMAT_PLAIN | ID128_REFUSE_NULL, ret) >= 0) {
|
if (fd >= 0 && id128_read_fd(fd, ID128_FORMAT_PLAIN | ID128_REFUSE_NULL, ret) >= 0) {
|
||||||
log_info("Initializing machine ID from D-Bus machine ID.");
|
log_info("Initializing machine ID from D-Bus machine ID.");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isempty(root) && running_in_chroot() <= 0) {
|
if (empty_or_root(root) && running_in_chroot() <= 0) {
|
||||||
/* Let's use a system credential for the machine ID if we can */
|
/* Let's use a system credential for the machine ID if we can */
|
||||||
r = acquire_machine_id_from_credential(ret);
|
if (acquire_machine_id_from_credential(ret) >= 0)
|
||||||
if (r >= 0)
|
return 0;
|
||||||
return r;
|
|
||||||
|
|
||||||
/* If that didn't work, see if we are running in a container,
|
/* If that didn't work, see if we are running in a container,
|
||||||
* and a machine ID was passed in via $container_uuid the way
|
* and a machine ID was passed in via $container_uuid the way
|
||||||
@ -105,7 +113,7 @@ static int generate_machine_id(const char *root, sd_id128_t *ret) {
|
|||||||
int machine_id_setup(const char *root, bool force_transient, sd_id128_t machine_id, sd_id128_t *ret) {
|
int machine_id_setup(const char *root, bool force_transient, sd_id128_t machine_id, sd_id128_t *ret) {
|
||||||
const char *etc_machine_id, *run_machine_id;
|
const char *etc_machine_id, *run_machine_id;
|
||||||
_cleanup_close_ int fd = -EBADF;
|
_cleanup_close_ int fd = -EBADF;
|
||||||
bool writable;
|
bool writable, write_run_machine_id = true;
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
etc_machine_id = prefix_roota(root, "/etc/machine-id");
|
etc_machine_id = prefix_roota(root, "/etc/machine-id");
|
||||||
@ -146,10 +154,11 @@ int machine_id_setup(const char *root, bool force_transient, sd_id128_t machine_
|
|||||||
if (id128_read_fd(fd, ID128_FORMAT_PLAIN, &machine_id) >= 0)
|
if (id128_read_fd(fd, ID128_FORMAT_PLAIN, &machine_id) >= 0)
|
||||||
goto finish;
|
goto finish;
|
||||||
|
|
||||||
/* Hmm, so, the id currently stored is not useful, then let's generate one */
|
/* Hmm, so, the id currently stored is not useful, then let's acquire one. */
|
||||||
r = generate_machine_id(root, &machine_id);
|
r = acquire_machine_id(root, &machine_id);
|
||||||
if (r < 0)
|
if (r < 0)
|
||||||
return r;
|
return r;
|
||||||
|
write_run_machine_id = !r;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (writable) {
|
if (writable) {
|
||||||
@ -187,11 +196,13 @@ int machine_id_setup(const char *root, bool force_transient, sd_id128_t machine_
|
|||||||
|
|
||||||
run_machine_id = prefix_roota(root, "/run/machine-id");
|
run_machine_id = prefix_roota(root, "/run/machine-id");
|
||||||
|
|
||||||
WITH_UMASK(0022)
|
if (write_run_machine_id) {
|
||||||
r = id128_write(run_machine_id, ID128_FORMAT_PLAIN, machine_id);
|
WITH_UMASK(0022)
|
||||||
if (r < 0) {
|
r = id128_write(run_machine_id, ID128_FORMAT_PLAIN, machine_id);
|
||||||
(void) unlink(run_machine_id);
|
if (r < 0) {
|
||||||
return log_error_errno(r, "Cannot write %s: %m", run_machine_id);
|
(void) unlink(run_machine_id);
|
||||||
|
return log_error_errno(r, "Cannot write %s: %m", run_machine_id);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* And now, let's mount it over */
|
/* And now, let's mount it over */
|
||||||
|
Loading…
Reference in New Issue
Block a user