avoid-importing-input
Summary: Avoid importing input
Category: Imports
Avoid
package policy
# This is always redundant
import input
# This might be useful, but better to move to a local assignment
import input.user.email
allow if "admin" in input.user.roles
allow if {
endswith(email, "@acmecorp.com")
}
Prefer
package policy
allow if "admin" in input.user.roles
allow if {
email := input.user.email
endswith(email, "@acmecorp.com")
}
Rationale
Using an import for input
is not necessary, as both input
and data
are globally available.
Exceptions
Using an alias for input
can sometimes be useful, e.g. when using input
is known to represent something specific,
like a Terraform plan. Aliasing of specific input attributes should however be avoided in favor of local assignments.
package policy
# This is acceptable
import input as tfplan
# But this should be avoided - use assignment instead:
# username := input.user.name
import input.user.name as username
allow if {
some resource_change in tfplan.resource_changes
# ...
}
Configuration Options
This linter rule provides the following configuration options:
rules:
imports:
avoid-importing-input:
# one of "error", "warning", "ignore"
level: error
Related Resources
- Rego Style Guide: Avoid importing
input
- OPA Docs: Terraform Tutorial
- GitHub: Source Code
Community
If you think you've found a problem with this rule or its documentation, would like to suggest improvements, new rules,
or just talk about Regal in general, please join us in the #regal
channel in the Styra Community
Slack!