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

Introduce Atmos YAML functions #810

Merged
merged 99 commits into from
Dec 4, 2024
Merged

Introduce Atmos YAML functions #810

merged 99 commits into from
Dec 4, 2024

Conversation

aknysh
Copy link
Member

@aknysh aknysh commented Nov 30, 2024

what

why

Atmos YAML Functions are a crucial part of Atmos stack manifests. They allow you to manipulate data and perform operations on the data to customize the stack configurations.

Atmos YAML functions are based on YAML Explicit typing and user-defined Explicit Tags (local data types). Explicit tags are denoted by the exclamation point ("!") symbol. Atmos detects the tags in the stack manifests and executes the corresponding functions.

NOTE: YAML data types can be divided into three categories: core, defined, and user-defined. Core are ones expected to exist in any parser (e.g. floats, ints, strings, lists, maps). Many more advanced data types, such as binary data, are defined in the YAML specification but not supported in all implementations. Finally, YAML defines a way to extend the data type definitions locally to accommodate user-defined classes, structures, primitives, and functions.

Atmos YAML functions

NOTE; You can use Atmos Stack Manifest Templating and Atmos YAML functions in the same stack configurations at the same time. Atmos processes the templates first, and then executes the YAML functions, allowing you to provide the parameters to the YAML functions dynamically.

Examples

components:
  terraform:
    component2:
      vars:
        # Handle the output of type list from the `atmos.Component` template function
        test_1: !template '{{ toJson (atmos.Component "component1" "plat-ue2-dev").outputs.test_list }}'

        # Handle the output of type map from the `atmos.Component` template function
        test_2: !template '{{ toJson (atmos.Component "component1" .stack).outputs.test_map }}'

        # Execute the shell script and assign the result to the `test_3` variable
        test_3: !exec echo 42

        # Execute the shell script to get the `test_label_id` output from the `component1` component in the stack `plat-ue2-dev`
        test_4: !exec atmos terraform output component1 -s plat-ue2-dev --skip-init -- -json test_label_id

        # Execute the shell script to get the `test_map` output from the `component1` component in the current stack
        test_5: !exec atmos terraform output component1 -s {{ .stack }} --skip-init -- -json test_map

        # Execute the shell script to get the `test_list` output from the `component1` component in the current stack
        test_6: !exec atmos terraform output component1 -s {{ .stack }} --skip-init -- -json test_list

        # Get the `test_label_id` output of type string from the `component1` component in the stack `plat-ue2-dev`
        test_7: !terraform.output component1 plat-ue2-dev test_label_id

        # Get the `test_label_id` output of type string from the `component1` component in the current stack
        test_8: !terraform.output component1 {{ .stack }} test_label_id

        # Get the `test_list` output of type list from the `component1` component in the current stack
        test_9: !terraform.output component1 {{ .stack }} test_list

        # Get the `test_map` output of type map from the `component1` component in the current stack
        test_10: !terraform.output component1 {{ .stack }} test_map

Summary by CodeRabbit

Release Notes

  • New Features

    • Introduced new YAML functions: !exec, !template, and !terraform.output for enhanced stack manifest capabilities.
    • Added support for custom YAML tags processing in Atmos configurations.
    • Enhanced configuration options for Atlantis integration, allowing for more flexible setups.
    • Updated Atmos and Terraform versions in the Dockerfile for improved functionality.
    • Introduced new constants related to Atmos YAML functions for better configuration handling.
  • Documentation Updates

    • Enhanced documentation for using remote state in Terraform components.
    • Updated guides for the atmos.Component function and the new YAML functions.
    • Clarified Atlantis integration setup options and workflows.
    • Improved explanations on handling outputs and using the new YAML functions.
    • Added documentation for new functions and updated existing guides for clarity.
  • Dependency Updates

    • Upgraded various dependencies to their latest versions for improved performance and security.

# Conflicts:
#	website/docs/integrations/github-actions/setup-atmos.mdx
# Conflicts:
#	examples/quick-start-advanced/Dockerfile
#	go.mod
#	go.sum
#	internal/exec/help.go
#	website/docs/integrations/atlantis.mdx
# Conflicts:
#	examples/quick-start-advanced/Dockerfile
#	website/docs/integrations/atlantis.mdx
coderabbitai[bot]
coderabbitai bot previously approved these changes Dec 3, 2024
@aknysh aknysh requested a review from osterman December 3, 2024 18:13
…put.mdx

Co-authored-by: Erik Osterman (CEO @ Cloud Posse) <[email protected]>
@aknysh aknysh temporarily deployed to preview December 3, 2024 18:59 — with GitHub Actions Inactive
coderabbitai[bot]
coderabbitai bot previously approved these changes Dec 3, 2024
…put.mdx

Co-authored-by: Erik Osterman (CEO @ Cloud Posse) <[email protected]>
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 1

🧹 Outside diff range and nitpick comments (2)
website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx (2)

21-32: Consider adding validation details for arguments.

The arguments section would benefit from additional information about:

  • Required vs optional arguments
  • Validation rules for each argument (e.g., allowed characters, length limits)
  • Error messages users might encounter with invalid arguments

144-144: Add missing comma after "e.g."

Add a comma after "e.g." to follow proper punctuation rules.

-The cache is per Atmos CLI command execution, e.g. each new execution
+The cache is per Atmos CLI command execution, e.g., each new execution
🧰 Tools
🪛 LanguageTool

[style] ~144-~144: A comma is missing here.
Context: ...che is per Atmos CLI command execution, e.g. each new execution of a command like `a...

(EG_NO_COMMA)

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 042b78b and 60837ed.

📒 Files selected for processing (2)
  • website/docs/core-concepts/stacks/templates/templates.mdx (1 hunks)
  • website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
  • website/docs/core-concepts/stacks/templates/templates.mdx
🧰 Additional context used
📓 Learnings (1)
website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx (2)
Learnt from: aknysh
PR: cloudposse/atmos#810
File: website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx:0-0
Timestamp: 2024-12-03T04:01:16.446Z
Learning: In the `terraform.output.mdx` documentation file (`website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx`), the cache invalidation and cache scope behavior for the `!terraform.output` function are already described.
Learnt from: aknysh
PR: cloudposse/atmos#810
File: website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx:104-110
Timestamp: 2024-12-03T03:49:30.395Z
Learning: In the documentation for `!terraform.output`, warnings about template variable availability are already covered in other sections, so no need to suggest adding them here.
🪛 LanguageTool
website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx

[typographical] ~133-~133: Consider using a typographic opening quote here.
Context: ... ``` :::tip Important By using the printf "%s-%s-%s" function, you are constructin...

(EN_QUOTES)


[style] ~144-~144: A comma is missing here.
Context: ...che is per Atmos CLI command execution, e.g. each new execution of a command like `a...

(EG_NO_COMMA)


[style] ~178-~178: Using many exclamation marks might seem excessive (in this case: 11 exclamation marks for a text that’s 4081 characters long)
Context: ...e stacks or components. - When using !terraform.output with [`atmos describe ...

(EN_EXCESSIVE_EXCLAMATION)

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (3)
website/docs/core-concepts/stacks/yaml-functions/yaml-functions.mdx (3)

14-32: Consider using typographic quotes for better readability.

Replace the straight quotes with typographic quotes in the following line:

-Explicit tags are denoted by the exclamation point (__"!"__) symbol.
+Explicit tags are denoted by the exclamation point (__"!"__) symbol.
🧰 Tools
🪛 LanguageTool

[typographical] ~23-~23: Consider using a typographic close quote here.
Context: ...are denoted by the exclamation point ("!") symbol. Atmos detects the tags in ...

(EN_QUOTES)


[typographical] ~23-~23: Consider using a typographic close quote here.
Context: ...e denoted by the exclamation point ("!") symbol. Atmos detects the tags in th...

(EN_QUOTES)


34-44: Clarify the preferred approach for terraform outputs.

The documentation should explicitly mention that !terraform.output is the recommended approach for accessing terraform outputs, even though !exec atmos terraform output is shown in examples.

🧰 Tools
🪛 LanguageTool

[style] ~37-~37: Three successive sentences begin with the same word. Consider rewording the sentence or use a thesaurus to find a synonym.
Context: ...YAML document, whether generated by the atmos.Component template function or any Go template. ...

(ENGLISH_WORD_REPEAT_BEGINNING_RULE)


[style] ~42-~42: Using many exclamation marks might seem excessive (in this case: 4 exclamation marks for a text that’s 2490 characters long)
Context: ...ctions in Atmos stack manifests - The [!terraform.output](/core-concepts/stac...

(EN_EXCESSIVE_EXCLAMATION)


68-110: Consider updating examples to align with best practices.

While the examples are comprehensive, consider:

  1. Replacing !exec atmos terraform output examples (lines 90-96) with !terraform.output for consistency with recommended practices
  2. Adding comments to explain when !exec is more appropriate than !terraform.output
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 60837ed and 5a4b2b3.

📒 Files selected for processing (1)
  • website/docs/core-concepts/stacks/yaml-functions/yaml-functions.mdx (1 hunks)
🧰 Additional context used
📓 Learnings (1)
website/docs/core-concepts/stacks/yaml-functions/yaml-functions.mdx (1)
Learnt from: aknysh
PR: cloudposse/atmos#810
File: examples/tests/stacks/catalog/terraform/template-functions-test2/defaults.yaml:28-32
Timestamp: 2024-12-01T00:33:20.298Z
Learning: In `examples/tests/stacks/catalog/terraform/template-functions-test2/defaults.yaml`, `!exec atmos terraform output` is used in examples to demonstrate its usage, even though `!terraform.output` is the recommended approach according to the documentation.
🪛 LanguageTool
website/docs/core-concepts/stacks/yaml-functions/yaml-functions.mdx

[typographical] ~23-~23: Consider using a typographic close quote here.
Context: ...are denoted by the exclamation point ("!") symbol. Atmos detects the tags in ...

(EN_QUOTES)


[typographical] ~23-~23: Consider using a typographic close quote here.
Context: ...e denoted by the exclamation point ("!") symbol. Atmos detects the tags in th...

(EN_QUOTES)


[style] ~37-~37: Three successive sentences begin with the same word. Consider rewording the sentence or use a thesaurus to find a synonym.
Context: ...YAML document, whether generated by the atmos.Component template function or any Go template. ...

(ENGLISH_WORD_REPEAT_BEGINNING_RULE)


[style] ~42-~42: Using many exclamation marks might seem excessive (in this case: 4 exclamation marks for a text that’s 2490 characters long)
Context: ...ctions in Atmos stack manifests - The [!terraform.output](/core-concepts/stac...

(EN_EXCESSIVE_EXCLAMATION)

🔇 Additional comments (3)
website/docs/core-concepts/stacks/yaml-functions/yaml-functions.mdx (3)

1-13: LGTM! Frontmatter and imports are well-structured.

The metadata and component imports follow MDX best practices.


46-67: LGTM! Clear explanation of processing order and supported sections.

The documentation effectively communicates how templates and YAML functions work together and provides a comprehensive list of supported sections.


112-116: LGTM! Good introduction to native functions.

The section effectively sets up the detailed documentation that follows.

…put.mdx

Co-authored-by: coderabbitai[bot] <136622811+coderabbitai[bot]@users.noreply.github.com>
@aknysh aknysh requested a review from osterman December 3, 2024 20:00
@aknysh aknysh temporarily deployed to preview December 3, 2024 20:05 — with GitHub Actions Inactive
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

🧹 Outside diff range and nitpick comments (3)
website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx (3)

23-32: Consider enhancing argument descriptions with example values.

While the arguments are well-documented, adding example values would make it even clearer:

 <dl>
   <dt>`component`</dt>
-  <dd>Atmos component name</dd>
+  <dd>Atmos component name (e.g., `vpc`, `eks`, `rds`)</dd>

   <dt>`stack`</dt>
-  <dd>Atmos stack name</dd>
+  <dd>Atmos stack name (e.g., `plat-ue2-dev`, `plat-ue2-prod`)</dd>

   <dt>`output`</dt>
-  <dd>Terraform output</dd>
+  <dd>Terraform output (e.g., `vpc_id`, `subnet_ids`, `security_group_id`)</dd>
 </dl>

43-57: Consider adding example output formats.

The examples show different output types but could be more helpful with sample outputs:

 components:
   terraform:
     my_lambda_component:
       vars:
         vpc_config:
           # Output of type string
-          security_group_id: !terraform.output security-group/lambda {{ .stack }} id
+          # Returns: "sg-1234567890abcdef0"
+          security_group_id: !terraform.output security-group/lambda {{ .stack }} id
           # Output of type list
-          subnet_ids: !terraform.output vpc {{ .stack }} private_subnet_ids
+          # Returns: ["subnet-123...", "subnet-456..."]
+          subnet_ids: !terraform.output vpc {{ .stack }} private_subnet_ids
           # Output of type map
-          config_map: !terraform.output config {{ .stack }} config_map
+          # Returns: {"key1": "value1", "key2": "value2"}
+          config_map: !terraform.output config {{ .stack }} config_map

61-63: Consider adding a note about stack name validation.

It would be helpful to mention how Atmos validates the stack names and what happens if an invalid or non-existent stack is specified.

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 5a4b2b3 and d03a3c1.

📒 Files selected for processing (1)
  • website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx (1 hunks)
🧰 Additional context used
📓 Learnings (1)
website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx (2)
Learnt from: aknysh
PR: cloudposse/atmos#810
File: website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx:0-0
Timestamp: 2024-12-03T04:01:16.446Z
Learning: In the `terraform.output.mdx` documentation file (`website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx`), the cache invalidation and cache scope behavior for the `!terraform.output` function are already described.
Learnt from: aknysh
PR: cloudposse/atmos#810
File: website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx:104-110
Timestamp: 2024-12-03T03:49:30.395Z
Learning: In the documentation for `!terraform.output`, warnings about template variable availability are already covered in other sections, so no need to suggest adding them here.
🪛 LanguageTool
website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx

[typographical] ~133-~133: Consider using a typographic opening quote here.
Context: ... ``` :::tip Important By using the printf "%s-%s-%s" function, you are constructin...

(EN_QUOTES)


[style] ~178-~178: Using many exclamation marks might seem excessive (in this case: 11 exclamation marks for a text that’s 4082 characters long)
Context: ...e stacks or components. - When using !terraform.output with [`atmos describe ...

(EN_EXCESSIVE_EXCLAMATION)

🔇 Additional comments (4)
website/docs/core-concepts/stacks/yaml-functions/terraform.output.mdx (4)

1-13: LGTM! Clear and concise introduction.

The metadata and introduction effectively communicate the purpose of the !terraform.output function.


35-39: LGTM! Clear explanation of template processing order.

The tip effectively explains how template processing interacts with the !terraform.output function.


140-173: LGTM! Comprehensive caching explanation.

The caching behavior is well-documented with clear examples demonstrating the benefits.


174-185: LGTM! Thorough coverage of important considerations.

The considerations section effectively addresses security, performance, and operational aspects that users should be aware of.

🧰 Tools
🪛 LanguageTool

[style] ~178-~178: Using many exclamation marks might seem excessive (in this case: 11 exclamation marks for a text that’s 4082 characters long)
Context: ...e stacks or components. - When using !terraform.output with [`atmos describe ...

(EN_EXCESSIVE_EXCLAMATION)

@aknysh aknysh merged commit 08d650d into main Dec 4, 2024
29 checks passed
@aknysh aknysh deleted the yaml-explicit-types-1 branch December 4, 2024 15:06
Copy link

github-actions bot commented Dec 4, 2024

These changes were released in v1.111.0.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
minor New features that do not break anything
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

3 participants