diff options
| author | Lennart Poettering <lennart@poettering.net> | 2015-10-14 19:39:28 +0200 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2015-10-14 19:39:28 +0200 | 
| commit | 64f283c39b1b8311f4dd99466ecc8df7e4407950 (patch) | |
| tree | 33528fafccaf94de0ec165007446ec662623973f | |
| parent | 6777e2ad7282bb52076b92e130cba17cebb81b02 (diff) | |
| parent | e0d6e0fa55054b7eacf58c511abff710fef5712f (diff) | |
Merge pull request #1528 from evverx/systemd-run-syslog-pri-fac
systemd-run can launch units with SyslogLevel and SyslogFacility
| -rw-r--r-- | shell-completion/bash/systemd-run | 3 | ||||
| -rw-r--r-- | src/basic/util.c | 8 | ||||
| -rw-r--r-- | src/basic/util.h | 2 | ||||
| -rw-r--r-- | src/core/dbus-execute.c | 32 | ||||
| -rw-r--r-- | src/shared/bus-util.c | 24 | 
5 files changed, 67 insertions, 2 deletions
| diff --git a/shell-completion/bash/systemd-run b/shell-completion/bash/systemd-run index b1387a28b6..462ee33959 100644 --- a/shell-completion/bash/systemd-run +++ b/shell-completion/bash/systemd-run @@ -83,7 +83,8 @@ _systemd_run() {                           LimitMEMLOCK= LimitLOCKS= LimitSIGPENDING= LimitMSGQUEUE=                           LimitNICE= LimitRTPRIO= LimitRTTIME= PrivateTmp= PrivateDevices=                           PrivateNetwork= NoNewPrivileges= WorkingDirectory= RootDirectory= -                         TTYPath= SyslogIdentifier= SyslogLevelPrefix=' +                         TTYPath= SyslogIdentifier= SyslogLevelPrefix= SyslogLevel= +                         SyslogFacility='              COMPREPLY=( $(compgen -W '$comps' -- "$cur") )              return 0 diff --git a/src/basic/util.c b/src/basic/util.c index ca5e4befa0..8b896a2df3 100644 --- a/src/basic/util.c +++ b/src/basic/util.c @@ -3699,6 +3699,10 @@ static const char *const log_facility_unshifted_table[LOG_NFACILITIES] = {  DEFINE_STRING_TABLE_LOOKUP_WITH_FALLBACK(log_facility_unshifted, int, LOG_FAC(~0)); +bool log_facility_unshifted_is_valid(int facility) { +        return facility >= 0 && facility <= LOG_FAC(~0); +} +  static const char *const log_level_table[] = {          [LOG_EMERG] = "emerg",          [LOG_ALERT] = "alert", @@ -3712,6 +3716,10 @@ static const char *const log_level_table[] = {  DEFINE_STRING_TABLE_LOOKUP_WITH_FALLBACK(log_level, int, LOG_DEBUG); +bool log_level_is_valid(int level) { +        return level >= 0 && level <= LOG_DEBUG; +} +  static const char* const sched_policy_table[] = {          [SCHED_OTHER] = "other",          [SCHED_BATCH] = "batch", diff --git a/src/basic/util.h b/src/basic/util.h index 79c7ad1b39..2544ad0830 100644 --- a/src/basic/util.h +++ b/src/basic/util.h @@ -456,9 +456,11 @@ int sigchld_code_from_string(const char *s) _pure_;  int log_facility_unshifted_to_string_alloc(int i, char **s);  int log_facility_unshifted_from_string(const char *s); +bool log_facility_unshifted_is_valid(int faciliy);  int log_level_to_string_alloc(int i, char **s);  int log_level_from_string(const char *s); +bool log_level_is_valid(int level);  int sched_policy_to_string_alloc(int i, char **s);  int sched_policy_from_string(const char *s); diff --git a/src/core/dbus-execute.c b/src/core/dbus-execute.c index 88db179958..8b1f830476 100644 --- a/src/core/dbus-execute.c +++ b/src/core/dbus-execute.c @@ -881,6 +881,38 @@ int bus_exec_context_set_transient_property(                  }                  return 1; +        } else if (streq(name, "SyslogLevel")) { +                int level; + +                r = sd_bus_message_read(message, "i", &level); +                if (r < 0) +                        return r; + +                if (!log_level_is_valid(level)) +                        return sd_bus_error_setf(error, SD_BUS_ERROR_INVALID_ARGS, "Log level value out of range"); + +                if (mode != UNIT_CHECK) { +                        c->syslog_priority = (c->syslog_priority & LOG_FACMASK) | level; +                        unit_write_drop_in_private_format(u, mode, name, "SyslogLevel=%i\n", level); +                } + +                return 1; +        } else if (streq(name, "SyslogFacility")) { +                int facility; + +                r = sd_bus_message_read(message, "i", &facility); +                if (r < 0) +                        return r; + +                if (!log_facility_unshifted_is_valid(facility)) +                        return sd_bus_error_setf(error, SD_BUS_ERROR_INVALID_ARGS, "Log facility value out of range"); + +                if (mode != UNIT_CHECK) { +                        c->syslog_priority = (facility << 3) | LOG_PRI(c->syslog_priority); +                        unit_write_drop_in_private_format(u, mode, name, "SyslogFacility=%i\n", facility); +                } + +                return 1;          } else if (streq(name, "Nice")) {                  int n; diff --git a/src/shared/bus-util.c b/src/shared/bus-util.c index 65922dd93b..3a45ac4064 100644 --- a/src/shared/bus-util.c +++ b/src/shared/bus-util.c @@ -1497,7 +1497,29 @@ int bus_append_unit_property_assignment(sd_bus_message *m, const char *assignmen                                "RootDirectory", "SyslogIdentifier"))                  r = sd_bus_message_append(m, "v", "s", eq); -        else if (streq(field, "DeviceAllow")) { +        else if (streq(field, "SyslogLevel")) { +                int level; + +                level = log_level_from_string(eq); +                if (level < 0) { +                        log_error("Failed to parse %s value %s.", field, eq); +                        return -EINVAL; +                } + +                r = sd_bus_message_append(m, "v", "i", level); + +        } else if (streq(field, "SyslogFacility")) { +                int facility; + +                facility = log_facility_unshifted_from_string(eq); +                if (facility < 0) { +                        log_error("Failed to parse %s value %s.", field, eq); +                        return -EINVAL; +                } + +                r = sd_bus_message_append(m, "v", "i", facility); + +        } else if (streq(field, "DeviceAllow")) {                  if (isempty(eq))                          r = sd_bus_message_append(m, "v", "a(ss)", 0); | 
