mirror of
https://github.com/systemd/systemd-stable.git
synced 2025-01-25 06:03:40 +03:00
unit: add simple only-by-dependency flag for units
This commit is contained in:
parent
c0120d992c
commit
bc0f8771f2
@ -281,6 +281,9 @@ static DBusHandlerResult bus_unit_message_dispatch(Unit *u, DBusMessage *message
|
|||||||
int r;
|
int r;
|
||||||
char *path;
|
char *path;
|
||||||
|
|
||||||
|
if (job_type == JOB_START && u->meta.only_by_dependency)
|
||||||
|
return bus_send_error_reply(m, message, NULL, -EPERM);
|
||||||
|
|
||||||
if (!dbus_message_get_args(
|
if (!dbus_message_get_args(
|
||||||
message,
|
message,
|
||||||
&error,
|
&error,
|
||||||
|
@ -1268,6 +1268,7 @@ static int load_from_path(Unit *u, const char *path) {
|
|||||||
{ "After", config_parse_deps, UINT_TO_PTR(UNIT_AFTER), "Unit" },
|
{ "After", config_parse_deps, UINT_TO_PTR(UNIT_AFTER), "Unit" },
|
||||||
{ "RecursiveStop", config_parse_bool, &u->meta.recursive_stop, "Unit" },
|
{ "RecursiveStop", config_parse_bool, &u->meta.recursive_stop, "Unit" },
|
||||||
{ "StopWhenUnneeded", config_parse_bool, &u->meta.stop_when_unneeded, "Unit" },
|
{ "StopWhenUnneeded", config_parse_bool, &u->meta.stop_when_unneeded, "Unit" },
|
||||||
|
{ "OnlyByDependency", config_parse_bool, &u->meta.only_by_dependency, "Unit" },
|
||||||
|
|
||||||
{ "PIDFile", config_parse_path, &u->service.pid_file, "Service" },
|
{ "PIDFile", config_parse_path, &u->service.pid_file, "Service" },
|
||||||
{ "ExecStartPre", config_parse_exec, u->service.exec_command+SERVICE_EXEC_START_PRE, "Service" },
|
{ "ExecStartPre", config_parse_exec, u->service.exec_command+SERVICE_EXEC_START_PRE, "Service" },
|
||||||
|
@ -593,7 +593,8 @@ void unit_dump(Unit *u, FILE *f, const char *prefix) {
|
|||||||
"%s\tActive Enter Timestamp: %s\n"
|
"%s\tActive Enter Timestamp: %s\n"
|
||||||
"%s\tActive Exit Timestamp: %s\n"
|
"%s\tActive Exit Timestamp: %s\n"
|
||||||
"%s\tInactive Enter Timestamp: %s\n"
|
"%s\tInactive Enter Timestamp: %s\n"
|
||||||
"%s\tGC Check Good: %s\n",
|
"%s\tGC Check Good: %s\n"
|
||||||
|
"%s\tOnly By Dependency: %s\n",
|
||||||
prefix, u->meta.id,
|
prefix, u->meta.id,
|
||||||
prefix, unit_description(u),
|
prefix, unit_description(u),
|
||||||
prefix, strna(u->meta.instance),
|
prefix, strna(u->meta.instance),
|
||||||
@ -603,7 +604,8 @@ void unit_dump(Unit *u, FILE *f, const char *prefix) {
|
|||||||
prefix, strna(format_timestamp(timestamp2, sizeof(timestamp2), u->meta.active_enter_timestamp)),
|
prefix, strna(format_timestamp(timestamp2, sizeof(timestamp2), u->meta.active_enter_timestamp)),
|
||||||
prefix, strna(format_timestamp(timestamp3, sizeof(timestamp3), u->meta.active_exit_timestamp)),
|
prefix, strna(format_timestamp(timestamp3, sizeof(timestamp3), u->meta.active_exit_timestamp)),
|
||||||
prefix, strna(format_timestamp(timestamp4, sizeof(timestamp4), u->meta.inactive_enter_timestamp)),
|
prefix, strna(format_timestamp(timestamp4, sizeof(timestamp4), u->meta.inactive_enter_timestamp)),
|
||||||
prefix, yes_no(unit_check_gc(u)));
|
prefix, yes_no(unit_check_gc(u)),
|
||||||
|
prefix, yes_no(u->meta.only_by_dependency));
|
||||||
|
|
||||||
SET_FOREACH(t, u->meta.names, i)
|
SET_FOREACH(t, u->meta.names, i)
|
||||||
fprintf(f, "%s\tName: %s\n", prefix, t);
|
fprintf(f, "%s\tName: %s\n", prefix, t);
|
||||||
|
@ -136,6 +136,9 @@ struct Meta {
|
|||||||
UnitLoadState load_state;
|
UnitLoadState load_state;
|
||||||
Unit *merged_into;
|
Unit *merged_into;
|
||||||
|
|
||||||
|
/* Refuse manual starting, allow starting only indirectly via dependency. */
|
||||||
|
bool only_by_dependency;
|
||||||
|
|
||||||
char *id; /* One name is special because we use it for identification. Points to an entry in the names set */
|
char *id; /* One name is special because we use it for identification. Points to an entry in the names set */
|
||||||
char *instance;
|
char *instance;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user