#help (2024-03)
Where to get help about getting help!
2024-03-13
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
Hi, I’m trying to get templates to work and I believe my situation is such: there’s a TF component that has a setting in settings setting_a: "a"
and then the same component it has a variable that references that setting var_a: {{ .settings.setting_a }}
. I’m getting an error of invalid stack manifest
and yaml: key map: map[
… . Any ideas what could be going wrong here? Also it seems like if I put the variable value in double quotes then it is used as a literal string. Thanks!
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you need to quote the Go templates, use either single or double quotes
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
without the quotes, the yaml is invalid
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
It seems to me that both double and single quoting leads to the templated section being single quoted with the literal template as a value (as seen with a describe command).
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
here are working excamples:
Atmos supports Go templates in stack manifests.
vars:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it produces
atmos_component: vpc
atmos_manifest: orgs/acme/plat/dev/us-east-2
atmos_stack: plat-ue2-dev
terraform_workspace: plat-ue2-dev
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
I think I’ve been looking at the first one.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i don’t see the final values quoted. What yaml are you using?
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
relevant snippet (thanks for responding btw ):
settings:
setting_a: "a"
vars:
var_a: "{{ .settings.setting_a }}"
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
and it’s not that the final values are quote its that the value seems to just be the literal template var_a: '{{ .settings.setting_a }}'
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hmm, what Atmos version are you using?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i’m def not seeing the issue
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
terraform:
vars:
var_a: "{{ .settings.setting_a }}"
tags:
var_a: "{{ .settings.setting_a }}"
settings:
setting_a: "a"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
vars:
tags:
var_a: a
var_a: a
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
looks like 1.57.0
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
need to use 1.66.0
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
before that, Go templates were not supported, and that’s why those are literal values
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
thanks! works now
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
super
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
also you prob have figured it out, circular deps in templates are not supported (e.g. template a
references template b
, b
references c
, c
references a
). Atmos (at least currently) does only once pass to process the templates
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
Good tip, thanks! Had Golang templating existed before and just the utilization by stack manifests is new to 1.66.0? Looks quite helpful
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Go templates existed before only in imports. Now they are supported in stack manifests in 1.66.0
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but note that those are completely different methods
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
imports are special because they are used to process the manifests to actually find a component in a stack
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so you can’t just use templates in imports. You need to specify “context” with already defined values because imports are processed first before processing the component in the stack
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
ah okay, interesting.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for imports, Go templates are like this https://atmos.tools/core-concepts/stacks/imports#go-templates-in-imports
Imports are how we reduce duplication of configurations by creating reusable baselines. The imports should be thought of almost like blueprints. Once
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
import
is the special section where you can’t use Go templates without providing the static context
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s b/c of the multi-phase processing. When you execute atmos terraform apply vpc -s plat-ue2-prod
, Atmos does the following to find the component in the stack in all those stack manifest files:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Read all top-level stack manifests (defined in
atmos.yaml
in thestacks.included_path
excluding those from thestacks.excluded_paths
) - Process Go templates in all the imports (using the static
context
since no other section (vars
,settings
, etc.) is know yet for the component - Read all the imported files and merge them into a map (first deep-merging phase)
- Deep-merge all Atmos sections (
vars
,settings
etc.) from all scopes (Org, tenant, account, region, base component, component) into a final map of all components in all stacks (second deep-merging phase) - Find the component in the stack (or throw an error if not found)
- And finally, process the
Go
templates in the component in all other sections exceptimport
(import
is not used here since evrything was already imported and deep-merged)
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
Is there a canonical Atmos section to put info in a mixin that might be used for vars in a component? I don’t want to put the info in vars b/c I don’t want it added every time I reference the mixin and may want to process the info a bit while assigning it. Maybe metadata
makes sense? Maybe using another mixin is the better approach though.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
no, metadata
is a static section with a predefined schema https://atmos.tools/reference/schemas. https://atmos.tools/schemas/atmos/atmos-manifest/1.0/atmos-manifest.json
Atmos Schemas
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but settings
is a free-form map, you can put anything in there and then get it back in the Go
templates or from the command atmos describe component
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
components:
terraform:
vpc:
settings:
<anything can go here>
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
ah okay, so it’s not like terraform
or helm
settings only. thanks that helps.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can define anything in settings
, make it a separate component, or a separate base abstract component, then import it or inherit from it in other components (https://atmos.tools/core-concepts/components/inheritance)
Component Inheritance is one of the principles of Component-Oriented Programming (COP)
data:image/s3,"s3://crabby-images/0a401/0a4010e86921991c2929ed4ba5f4eda94e99cec5" alt="cricketsc avatar"
cool, thanks for all the info
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
let’s use atmos for all Atmos-related questions