Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Empty deniedProcessEnvironmentVariablesSubstrings filters out all environment variables #9604

Open
olfkadolf opened this issue Dec 13, 2024 · 3 comments
Assignees
Labels
bug Issues that are considered to be bugs configuration About configuration topics needs info An issue where further information is required

Comments

@olfkadolf
Copy link

Describe the bug

When ort setting deniedProcessEnvironmentVariablesSubstrings is left with no values, by default ALL env. variables will be filtered out.
In my case I suddenly ran into issues with node throwing '127' on version resolve in ORT.
Finally I discovered that my PATH variable was no longer set (actually that is displayed in the logs but I overlooked it for quite some time)

To Reproduce

Steps to reproduce the behavior:

Update your ORT config like this:

ort:
  allowedProcessEnvironmentVariableNames:
    - PASSPORT
    - USER_HOME
  deniedProcessEnvironmentVariablesSubstrings:
  #  - PASS
  #  - SECRET
  #  - TOKEN
  #  - USER

Expected behavior

No variables should be filtered out when deniedProcessEnvironmentVariablesSubstrings is left without values.

Console / log output

Exception in thread "main" java.io.IOException: Running 'npm --version' in '/home/ort' failed with exit code 127:
/usr/bin/env: 'node': No such file or directory

	at org.ossreviewtoolkit.utils.common.ProcessCapture.requireSuccess(ProcessCapture.kt:154)
	at org.ossreviewtoolkit.utils.common.CommandLineTool$DefaultImpls.getVersion(CommandLineTool.kt:88)
	at org.ossreviewtoolkit.plugins.packagemanagers.node.npm.NpmCommand.getVersion(Npm.kt:53)
	at org.ossreviewtoolkit.utils.common.CommandLineTool$DefaultImpls.checkVersion(CommandLineTool.kt:104)
	at org.ossreviewtoolkit.plugins.packagemanagers.node.npm.NpmCommand.checkVersion(Npm.kt:53)
	at org.ossreviewtoolkit.utils.common.CommandLineTool$DefaultImpls.checkVersion$default(CommandLineTool.kt:103)
	at org.ossreviewtoolkit.plugins.packagemanagers.node.npm.Npm.beforeResolution(Npm.kt:142)
	at org.ossreviewtoolkit.analyzer.PackageManager.resolveDependencies(PackageManager.kt:286)
	at org.ossreviewtoolkit.analyzer.PackageManagerRunner$run$3.invokeSuspend(Analyzer.kt:321)
	at kotlin.coroutines.jvm.internal.BaseContinuationImpl.resumeWith(ContinuationImpl.kt:33)
	at kotlinx.coroutines.DispatchedTask.run(DispatchedTask.kt:101)
	at kotlinx.coroutines.internal.LimitedDispatcher$Worker.run(LimitedDispatcher.kt:113)
	at kotlinx.coroutines.scheduling.TaskImpl.run(Tasks.kt:89)
	at kotlinx.coroutines.scheduling.CoroutineScheduler.runSafely(CoroutineScheduler.kt:589)
	at kotlinx.coroutines.scheduling.CoroutineScheduler$Worker.executeTask(CoroutineScheduler.kt:823)
	at kotlinx.coroutines.scheduling.CoroutineScheduler$Worker.runWorker(CoroutineScheduler.kt:720)
	at kotlinx.coroutines.scheduling.CoroutineScheduler$Worker.run(CoroutineScheduler.kt:707)
10:53:29.162 [DefaultDispatcher-worker-1] DEBUG org.ossreviewtoolkit.utils.common.EnvironmentVariableFilter - Filtering out these variables from the environment: [CARGO_HOME, RUSTUP_HOME, SHLVL, PYENV_ROOT, DOTNET_HOME, LC_ALL, RBENV_ROOT, HOME, ARTIFACTORY_PASSWORD, NUGET_INSPECTOR_HOME, ANDROID_HOME, HASKELL_HOME, PATH, JAVA_VERSION, ARTIFACTORY_SECRET, DART_SDK, LANG, ANDROID_USER_HOME, NVM_DIR, BAZEL_HOME, LANGUAGE, JAVA_HOME, RUST_HOME, SBT_HOME, GEM_HOME, ARTIFACTORY_USERNAME, USER, PWD, _, SWIFT_HOME, HOSTNAME]

Environment

Tested on Gitlab Linux runner.

Additional context

NA.

@olfkadolf olfkadolf added bug Issues that are considered to be bugs to triage Issues that need triaging labels Dec 13, 2024
@sschuberth sschuberth self-assigned this Dec 13, 2024
@sschuberth sschuberth added configuration About configuration topics and removed to triage Issues that need triaging labels Dec 13, 2024
@sschuberth
Copy link
Member

I cannot reproduce this. See the new test over here which passes.

@sschuberth sschuberth added the needs info An issue where further information is required label Dec 13, 2024
@sschuberth
Copy link
Member

Do you have any further info, @olfkadolf?

@olfkadolf
Copy link
Author

Do you have any further info, @olfkadolf?

@sschuberth , no I don't. Due to a lack of time I have configured deniedProcessEnvironmentVariablesSubstrings with a value of XXXXXXX. Functionally the problem is now solved.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Issues that are considered to be bugs configuration About configuration topics needs info An issue where further information is required
Projects
None yet
Development

No branches or pull requests

2 participants