mirror of
				https://github.com/fankes/termux-app.git
				synced 2025-10-25 21:29:20 +08:00 
			
		
		
		
	Changed!: Changes introduced to disable/change logging in 60f37bde now also apply to stdin and plugin command results
				
					
				
			This commit is contained in:
		| @@ -436,4 +436,11 @@ public class Logger { | ||||
|         return (logLevel != null && logLevel >= LOG_LEVEL_OFF && logLevel <= MAX_LOG_LEVEL); | ||||
|     } | ||||
|  | ||||
|     /** Check if custom log level is valid and >= {@link #CURRENT_LOG_LEVEL}. If custom log level is | ||||
|      * not valid then {@link #LOG_LEVEL_VERBOSE} must be >= {@link #CURRENT_LOG_LEVEL}. */ | ||||
|     public static boolean shouldEnableLoggingForCustomLogLevel(Integer customLogLevel) { | ||||
|         customLogLevel = Logger.isLogLevelValid(customLogLevel) ? customLogLevel: Logger.LOG_LEVEL_VERBOSE; | ||||
|         return (customLogLevel >= CURRENT_LOG_LEVEL); | ||||
|     } | ||||
|  | ||||
| } | ||||
|   | ||||
| @@ -85,8 +85,10 @@ public class ExecutionCommand { | ||||
|  | ||||
|     /** | ||||
|      * The {@link ExecutionCommand} custom log level for background {@link com.termux.shared.shell.TermuxTask} | ||||
|      * commands. By default, @link com.termux.shared.shell.StreamGobbler} only logs if {@link Logger} | ||||
|      * `CURRENT_LOG_LEVEL` is >= {@link Logger#LOG_LEVEL_VERBOSE}. | ||||
|      * commands. By default, @link com.termux.shared.shell.StreamGobbler} only logs stdout and | ||||
|      * stderr if {@link Logger} `CURRENT_LOG_LEVEL` is >= {@link Logger#LOG_LEVEL_VERBOSE} and | ||||
|      * {@link com.termux.shared.shell.TermuxTask} only logs stdin if `CURRENT_LOG_LEVEL` is >= | ||||
|      * {@link Logger#LOG_LEVEL_DEBUG}. | ||||
|      */ | ||||
|     public Integer backgroundCustomLogLevel; | ||||
|  | ||||
| @@ -242,7 +244,7 @@ public class ExecutionCommand { | ||||
|         if (!hasExecuted()) | ||||
|             return getExecutionInputLogString(this, true, true); | ||||
|         else { | ||||
|             return getExecutionOutputLogString(this, true, true); | ||||
|             return getExecutionOutputLogString(this, true, true, true); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -298,9 +300,10 @@ public class ExecutionCommand { | ||||
|      * @param executionCommand The {@link ExecutionCommand} to convert. | ||||
|      * @param ignoreNull Set to {@code true} if non-critical {@code null} values are to be ignored. | ||||
|      * @param logResultData Set to {@code true} if {@link #resultData} should be logged. | ||||
|      * @param logStdoutAndStderr Set to {@code true} if {@link ResultData#stdout} and {@link ResultData#stderr} should be logged. | ||||
|      * @return Returns the log friendly {@link String}. | ||||
|      */ | ||||
|     public static String getExecutionOutputLogString(final ExecutionCommand executionCommand, boolean ignoreNull, boolean logResultData) { | ||||
|     public static String getExecutionOutputLogString(final ExecutionCommand executionCommand, boolean ignoreNull, boolean logResultData, boolean logStdoutAndStderr) { | ||||
|         if (executionCommand == null) return "null"; | ||||
|  | ||||
|         StringBuilder logString = new StringBuilder(); | ||||
| @@ -311,7 +314,7 @@ public class ExecutionCommand { | ||||
|         logString.append("\n").append(executionCommand.getCurrentStateLogString()); | ||||
|  | ||||
|         if (logResultData) | ||||
|             logString.append("\n").append(ResultData.getResultDataLogString(executionCommand.resultData, ignoreNull)); | ||||
|             logString.append("\n").append(ResultData.getResultDataLogString(executionCommand.resultData, logStdoutAndStderr)); | ||||
|  | ||||
|         return logString.toString(); | ||||
|     } | ||||
| @@ -328,7 +331,7 @@ public class ExecutionCommand { | ||||
|         StringBuilder logString = new StringBuilder(); | ||||
|  | ||||
|         logString.append(getExecutionInputLogString(executionCommand, false, true)); | ||||
|         logString.append(getExecutionOutputLogString(executionCommand, false, true)); | ||||
|         logString.append(getExecutionOutputLogString(executionCommand, false, true, true)); | ||||
|  | ||||
|         logString.append("\n").append(executionCommand.getCommandDescriptionLogString()); | ||||
|         logString.append("\n").append(executionCommand.getCommandHelpLogString()); | ||||
|   | ||||
| @@ -133,16 +133,18 @@ public class ResultData implements Serializable { | ||||
|      * Get a log friendly {@link String} for {@link ResultData} parameters. | ||||
|      * | ||||
|      * @param resultData The {@link ResultData} to convert. | ||||
|      * @param ignoreNull Set to {@code true} if non-critical {@code null} values are to be ignored. | ||||
|      * @param logStdoutAndStderr Set to {@code true} if {@link #stdout} and {@link #stderr} should be logged. | ||||
|      * @return Returns the log friendly {@link String}. | ||||
|      */ | ||||
|     public static String getResultDataLogString(final ResultData resultData, boolean ignoreNull) { | ||||
|     public static String getResultDataLogString(final ResultData resultData, boolean logStdoutAndStderr) { | ||||
|         if (resultData == null) return "null"; | ||||
|  | ||||
|         StringBuilder logString = new StringBuilder(); | ||||
|  | ||||
|         logString.append("\n").append(resultData.getStdoutLogString()); | ||||
|         logString.append("\n").append(resultData.getStderrLogString()); | ||||
|         if (logStdoutAndStderr) { | ||||
|             logString.append("\n").append(resultData.getStdoutLogString()); | ||||
|             logString.append("\n").append(resultData.getStderrLogString()); | ||||
|         } | ||||
|         logString.append("\n").append(resultData.getExitCodeLogString()); | ||||
|  | ||||
|         logString.append("\n\n").append(getErrorsListLogString(resultData)); | ||||
|   | ||||
| @@ -34,22 +34,24 @@ public class ResultSender { | ||||
|      * @param label The label for the command. | ||||
|      * @param resultConfig The {@link ResultConfig} object containing information on how to send the result. | ||||
|      * @param resultData The {@link ResultData} object containing result data. | ||||
|      * @param logStdoutAndStderr Set to {@code true} if {@link ResultData#stdout} and {@link ResultData#stderr} | ||||
|      *                           should be logged. | ||||
|      * @return Returns the {@link Error} if failed to send the result, otherwise {@code null}. | ||||
|      */ | ||||
|     public static Error sendCommandResultData(Context context, String logTag, String label, ResultConfig resultConfig, ResultData resultData) { | ||||
|     public static Error sendCommandResultData(Context context, String logTag, String label, ResultConfig resultConfig, ResultData resultData, boolean logStdoutAndStderr) { | ||||
|         if (context == null || resultConfig == null || resultData == null) | ||||
|             return FunctionErrno.ERRNO_NULL_OR_EMPTY_PARAMETERS.getError("context, resultConfig or resultData", "sendCommandResultData"); | ||||
|  | ||||
|         Error error; | ||||
|  | ||||
|         if (resultConfig.resultPendingIntent != null) { | ||||
|             error = sendCommandResultDataWithPendingIntent(context, logTag, label, resultConfig, resultData); | ||||
|             error = sendCommandResultDataWithPendingIntent(context, logTag, label, resultConfig, resultData, logStdoutAndStderr); | ||||
|             if (error != null || resultConfig.resultDirectoryPath == null) | ||||
|                 return error; | ||||
|         } | ||||
|  | ||||
|         if (resultConfig.resultDirectoryPath != null) { | ||||
|             return sendCommandResultDataToDirectory(context, logTag, label, resultConfig, resultData); | ||||
|             return sendCommandResultDataToDirectory(context, logTag, label, resultConfig, resultData, logStdoutAndStderr); | ||||
|         } else { | ||||
|             return FunctionErrno.ERRNO_UNSET_PARAMETERS.getError("resultConfig.resultPendingIntent or resultConfig.resultDirectoryPath", "sendCommandResultData"); | ||||
|         } | ||||
| @@ -63,15 +65,17 @@ public class ResultSender { | ||||
|      * @param label The label for the command. | ||||
|      * @param resultConfig The {@link ResultConfig} object containing information on how to send the result. | ||||
|      * @param resultData The {@link ResultData} object containing result data. | ||||
|      * @param logStdoutAndStderr Set to {@code true} if {@link ResultData#stdout} and {@link ResultData#stderr} | ||||
|      *                           should be logged. | ||||
|      * @return Returns the {@link Error} if failed to send the result, otherwise {@code null}. | ||||
|      */ | ||||
|     public static Error sendCommandResultDataWithPendingIntent(Context context, String logTag, String label, ResultConfig resultConfig, ResultData resultData) { | ||||
|     public static Error sendCommandResultDataWithPendingIntent(Context context, String logTag, String label, ResultConfig resultConfig, ResultData resultData, boolean logStdoutAndStderr) { | ||||
|         if (context == null || resultConfig == null || resultData == null || resultConfig.resultPendingIntent == null || resultConfig.resultBundleKey == null) | ||||
|             return FunctionErrno.ERRNO_NULL_OR_EMPTY_PARAMETER.getError("context, resultConfig, resultData, resultConfig.resultPendingIntent or resultConfig.resultBundleKey", "sendCommandResultDataWithPendingIntent"); | ||||
|  | ||||
|         logTag = DataUtils.getDefaultIfNull(logTag, LOG_TAG); | ||||
|  | ||||
|         Logger.logDebugExtended(logTag, "Sending result for command \"" + label + "\":\n" + resultConfig.toString() + "\n" + resultData.toString()); | ||||
|         Logger.logDebugExtended(logTag, "Sending result for command \"" + label + "\":\n" + resultConfig.toString() + "\n" + ResultData.getResultDataLogString(resultData, logStdoutAndStderr)); | ||||
|  | ||||
|         String resultDataStdout = resultData.stdout.toString(); | ||||
|         String resultDataStderr = resultData.stderr.toString(); | ||||
| @@ -152,9 +156,11 @@ public class ResultSender { | ||||
|      * @param label The label for the command. | ||||
|      * @param resultConfig The {@link ResultConfig} object containing information on how to send the result. | ||||
|      * @param resultData The {@link ResultData} object containing result data. | ||||
|      * @param logStdoutAndStderr Set to {@code true} if {@link ResultData#stdout} and {@link ResultData#stderr} | ||||
|      *                           should be logged. | ||||
|      * @return Returns the {@link Error} if failed to send the result, otherwise {@code null}. | ||||
|      */ | ||||
|     public static Error sendCommandResultDataToDirectory(Context context, String logTag, String label, ResultConfig resultConfig, ResultData resultData) { | ||||
|     public static Error sendCommandResultDataToDirectory(Context context, String logTag, String label, ResultConfig resultConfig, ResultData resultData, boolean logStdoutAndStderr) { | ||||
|         if (context == null || resultConfig == null || resultData == null || DataUtils.isNullOrEmpty(resultConfig.resultDirectoryPath)) | ||||
|             return FunctionErrno.ERRNO_NULL_OR_EMPTY_PARAMETER.getError("context, resultConfig, resultData or resultConfig.resultDirectoryPath", "sendCommandResultDataToDirectory"); | ||||
|  | ||||
| @@ -177,7 +183,7 @@ public class ResultSender { | ||||
|  | ||||
|         resultConfig.resultDirectoryPath = FileUtils.getCanonicalPath(resultConfig.resultDirectoryPath, null); | ||||
|  | ||||
|         Logger.logDebugExtended(logTag, "Writing result for command \"" + label + "\":\n" + resultConfig.toString() + "\n" + resultData.toString()); | ||||
|         Logger.logDebugExtended(logTag, "Writing result for command \"" + label + "\":\n" + resultConfig.toString() + "\n" + ResultData.getResultDataLogString(resultData, logStdoutAndStderr)); | ||||
|  | ||||
|         // If resultDirectoryPath is not a directory, or is not readable or writable, then just return | ||||
|         // Creation of missing directory and setting of read, write and execute permissions are | ||||
|   | ||||
| @@ -88,7 +88,7 @@ public class StreamGobbler extends Thread { | ||||
|     @Nullable | ||||
|     private final OnStreamClosedListener streamClosedListener; | ||||
|     @Nullable | ||||
|     private final Integer mLlogLevel; | ||||
|     private final Integer mLogLevel; | ||||
|     private volatile boolean active = true; | ||||
|     private volatile boolean calledOnClose = false; | ||||
|  | ||||
| @@ -104,7 +104,7 @@ public class StreamGobbler extends Thread { | ||||
|      * @param shell Name of the shell | ||||
|      * @param inputStream InputStream to read from | ||||
|      * @param outputList {@literal List<String>} to write to, or null | ||||
|      * @param logLevel The custom log level to use for logging by command output. If set to | ||||
|      * @param logLevel The custom log level to use for logging the command output. If set to | ||||
|      *                 {@code null}, then {@link Logger#LOG_LEVEL_VERBOSE} will be used. | ||||
|      */ | ||||
|     @AnyThread | ||||
| @@ -121,7 +121,7 @@ public class StreamGobbler extends Thread { | ||||
|         stringWriter = null; | ||||
|         lineListener = null; | ||||
|  | ||||
|         mLlogLevel = logLevel; | ||||
|         mLogLevel = logLevel; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -136,7 +136,7 @@ public class StreamGobbler extends Thread { | ||||
|      * @param shell Name of the shell | ||||
|      * @param inputStream InputStream to read from | ||||
|      * @param outputString {@literal List<String>} to write to, or null | ||||
|      * @param logLevel The custom log level to use for logging by command output. If set to | ||||
|      * @param logLevel The custom log level to use for logging the command output. If set to | ||||
|      *                 {@code null}, then {@link Logger#LOG_LEVEL_VERBOSE} will be used. | ||||
|      */ | ||||
|     @AnyThread | ||||
| @@ -153,7 +153,7 @@ public class StreamGobbler extends Thread { | ||||
|         stringWriter = outputString; | ||||
|         lineListener = null; | ||||
|  | ||||
|         mLlogLevel = logLevel; | ||||
|         mLogLevel = logLevel; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -167,7 +167,7 @@ public class StreamGobbler extends Thread { | ||||
|      * @param inputStream InputStream to read from | ||||
|      * @param onLineListener OnLineListener callback | ||||
|      * @param onStreamClosedListener OnStreamClosedListener callback | ||||
|      * @param logLevel The custom log level to use for logging by command output. If set to | ||||
|      * @param logLevel The custom log level to use for logging the command output. If set to | ||||
|      *                 {@code null}, then {@link Logger#LOG_LEVEL_VERBOSE} will be used. | ||||
|      */ | ||||
|     @AnyThread | ||||
| @@ -185,28 +185,22 @@ public class StreamGobbler extends Thread { | ||||
|         stringWriter = null; | ||||
|         lineListener = onLineListener; | ||||
|  | ||||
|         mLlogLevel = logLevel; | ||||
|         mLogLevel = logLevel; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void run() { | ||||
|         String defaultLogTag = Logger.DEFAULT_LOG_TAG; | ||||
|         int currentLogLevel = Logger.getLogLevel(); | ||||
|  | ||||
|         int customLogLevel; | ||||
|         if (Logger.isLogLevelValid(mLlogLevel)) { | ||||
|             customLogLevel = mLlogLevel; | ||||
|             Logger.logVerbose(LOG_TAG, "Using custom log level: " + customLogLevel + ", current log level: " + currentLogLevel); | ||||
|         } else { | ||||
|             customLogLevel = Logger.LOG_LEVEL_VERBOSE; | ||||
|         } | ||||
|         boolean loggingEnabled = Logger.shouldEnableLoggingForCustomLogLevel(mLogLevel); | ||||
|         if (loggingEnabled) | ||||
|             Logger.logVerbose(LOG_TAG, "Using custom log level: " + mLogLevel + ", current log level: " + Logger.getLogLevel()); | ||||
|  | ||||
|         // keep reading the InputStream until it ends (or an error occurs) | ||||
|         // optionally pausing when a command is executed that consumes the InputStream itself | ||||
|         try { | ||||
|             String line; | ||||
|             while ((line = reader.readLine()) != null) { | ||||
|                 if (customLogLevel >= currentLogLevel) | ||||
|                 if (loggingEnabled) | ||||
|                     Logger.logVerboseForce(defaultLogTag + "Command", String.format(Locale.ENGLISH, "[%s] %s", shell, line)); // This will get truncated by LOGGER_ENTRY_MAX_LEN, likely 4KB | ||||
|  | ||||
|                 if (stringWriter != null) stringWriter.append(line).append("\n"); | ||||
|   | ||||
| @@ -82,8 +82,8 @@ public final class TermuxTask { | ||||
|         } | ||||
|  | ||||
|         // No need to log stdin if logging is disabled, like for app internal scripts | ||||
|         int customLogLevel = Logger.isLogLevelValid(executionCommand.backgroundCustomLogLevel) ? executionCommand.backgroundCustomLogLevel: Logger.LOG_LEVEL_VERBOSE; | ||||
|         Logger.logDebugExtended(LOG_TAG, ExecutionCommand.getExecutionInputLogString(executionCommand, true, customLogLevel >= Logger.getLogLevel())); | ||||
|         Logger.logDebugExtended(LOG_TAG, ExecutionCommand.getExecutionInputLogString(executionCommand, | ||||
|             true, Logger.shouldEnableLoggingForCustomLogLevel(executionCommand.backgroundCustomLogLevel))); | ||||
|  | ||||
|         String taskName = ShellUtils.getExecutableBasename(executionCommand.executable); | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user