diff --git a/src/main/java/org/jboss/logmanager/ExtLogRecord.java b/src/main/java/org/jboss/logmanager/ExtLogRecord.java index cd0448c6..2152a934 100644 --- a/src/main/java/org/jboss/logmanager/ExtLogRecord.java +++ b/src/main/java/org/jboss/logmanager/ExtLogRecord.java @@ -19,6 +19,8 @@ package org.jboss.logmanager; +import static java.security.AccessController.doPrivileged; + import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; @@ -26,6 +28,7 @@ import java.lang.invoke.MethodHandles; import java.lang.invoke.MethodType; import java.lang.reflect.UndeclaredThrowableException; +import java.security.PrivilegedAction; import java.text.MessageFormat; import java.util.Map; import java.util.MissingResourceException; @@ -108,7 +111,7 @@ public ExtLogRecord(final java.util.logging.Level level, final String msg, final longThreadID = Thread.currentThread().getId(); // todo: threadId() on 19+ hostName = HostName.getQualifiedHostName(); processName = io.smallrye.common.os.Process.getProcessName(); - processId = io.smallrye.common.os.Process.getProcessId(); + processId = doPrivileged((PrivilegedAction) ProcessHandle::current).pid(); } /** diff --git a/src/main/java/org/jboss/logmanager/handlers/SyslogHandler.java b/src/main/java/org/jboss/logmanager/handlers/SyslogHandler.java index f15391ba..2967dc2b 100644 --- a/src/main/java/org/jboss/logmanager/handlers/SyslogHandler.java +++ b/src/main/java/org/jboss/logmanager/handlers/SyslogHandler.java @@ -19,6 +19,7 @@ package org.jboss.logmanager.handlers; +import static java.security.AccessController.doPrivileged; import static java.time.temporal.ChronoField.DAY_OF_MONTH; import static java.time.temporal.ChronoField.HOUR_OF_DAY; import static java.time.temporal.ChronoField.MILLI_OF_SECOND; @@ -34,6 +35,7 @@ import java.net.InetAddress; import java.net.UnknownHostException; import java.nio.charset.StandardCharsets; +import java.security.PrivilegedAction; import java.text.Normalizer; import java.text.Normalizer.Form; import java.time.ZoneId; @@ -346,7 +348,6 @@ public static enum SyslogType { private String hostname; private Facility facility; private SyslogType syslogType; - private final String pid; private OutputStream out; private Protocol protocol; private boolean useCountingFraming; @@ -503,8 +504,6 @@ public SyslogHandler(final InetAddress serverAddress, final int port, final Faci this.serverAddress = serverAddress; this.port = port; this.facility = facility; - final long pid = io.smallrye.common.os.Process.getProcessId(); - this.pid = (pid != -1 ? Long.toString(pid) : null); this.appName = "java"; this.hostname = checkPrintableAscii("host name", hostname); this.syslogType = (syslogType == null ? SyslogType.RFC5424 : syslogType); @@ -780,14 +779,11 @@ public void setEscapeEnabled(final boolean escapeEnabled) { * Returns the pid being used as the PROCID for RFC5424 messages. * * @return the pid or {@code null} if the pid could not be determined + * @deprecated Always returns the current process ID, as a string. */ + @Deprecated public String getPid() { - lock.lock(); - try { - return pid; - } finally { - lock.unlock(); - } + return String.valueOf(doPrivileged((PrivilegedAction) ProcessHandle::current).pid()); } /**