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

add terraform clean --everything and terraform clean --force to delete terraform.tfstate.d folder #727

Merged
merged 86 commits into from
Dec 5, 2024

Conversation

haitham911
Copy link
Collaborator

@haitham911 haitham911 commented Oct 15, 2024

What

  • Added a new option to terraform clean called --everything and terraform clean called --force
    to clean state files. This option deletes the Terraform-related folder and files, including:
    • backend.tf.json
    • .terraform
    • terraform.tfstate.d
    • .terraform.lock.hcl

The following scenarios are covered:

  1. If no component is specified:
    cmd atmos terraform clean --everything delete with confim message yes/no
    cmd atmos terraform clean --force .delete force
    Cleans the state files for all components.

  2. If a specific component is specified:

    atmos terraform station clean --everything
    

    Cleans the state files for the specified component.

  3. If both a component and a stack are specified:

    atmos terraform clean --stack dev --everything
    

    Cleans the state files for the specified component and stack.

  • Fixed a bug where the component name was being incorrectly parsed from the arguments. Previously, when the component was not provided in the command, it would incorrectly assign additional arguments as the component name (e.g., in terraform clean --everything, the component name was mistakenly set to --everything).
    image (6)
    image (7)
    image (8)
    image (9)

Why

Cleaning state files is useful when running tests, but it should not be the default behavior to avoid unintended data loss.

References

Summary by CodeRabbit

Summary by CodeRabbit

  • New Features

    • Enhanced help messages for the atmos terraform clean command, detailing the new --everything and --force flags.
    • Introduced functionality for managing Terraform-related directories and files, including user confirmation for deletions.
    • Added new flags and options for various atmos terraform commands to improve usability, including --skip-init, --from-plan, and --planfile.
    • Updated documentation with examples and warnings regarding the new flags to ensure users understand their impact.
  • Bug Fixes

    • Improved error handling and argument parsing in command-line interface functions.
  • Chores

    • Updated dependencies in the project to include new libraries and versions.

@haitham911 haitham911 requested review from a team as code owners October 15, 2024 23:07
Copy link
Contributor

coderabbitai bot commented Oct 15, 2024

📝 Walkthrough
📝 Walkthrough

Walkthrough

This pull request introduces several changes to the CLI functionality of the atmos tool. Key enhancements include improved help messages for the terraform clean command, new constants for handling command flags, and modifications to the ExecuteTerraform function to better manage command-line arguments and flags. Additionally, several dependencies in the go.mod file have been added or updated to support these changes.

Changes

File Path Change Summary
internal/exec/help.go Enhanced help messages for atmos terraform clean, detailing --everything and --force options.
internal/exec/path_utils.go Replaced path package with filepath for improved file path handling.
internal/exec/terraform.go Introduced constants everythingFlag and forceFlag, modified ExecuteTerraform to handle new command logic.
internal/exec/utils.go Updated ProcessStacks and processArgsAndFlags for improved error handling and argument processing.
internal/exec/terraform_clean.go Introduced functionality for managing Terraform-related directories and files, including search and deletion logic.
go.mod Added new indirect dependencies and updated existing ones, including github.com/charmbracelet/huh and github.com/mitchellh/hashstructure/v2.

Assessment against linked issues

Objective Addressed Explanation
atmos terraform clean --everything should clean statefiles (DEV-346)

Possibly related PRs

Suggested reviewers

  • osterman
  • gberenice

📜 Recent review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 5e0c92f and d7cfbbf.

⛔ Files ignored due to path filters (1)
  • go.sum is excluded by !**/*.sum
📒 Files selected for processing (2)
  • go.mod (4 hunks)
  • internal/exec/utils.go (2 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
  • go.mod
🔇 Additional comments (2)
internal/exec/utils.go (2)

396-402: LGTM! The added condition improves flexibility.

The new condition allows the function to proceed without error when no stacks are found and checkStack is false. This enhancement supports operations like terraform clean that don't necessarily require a stack context.


1058-1071: LGTM! Enhanced argument validation improves robustness.

The added validation logic properly handles:

  1. Empty arguments
  2. Invalid option formats
  3. Differentiation between options and component names

This fixes the component name parsing bug mentioned in the PR objectives.

Let's verify the argument parsing behavior:


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary or @auto-summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai or @auto-title anywhere in the PR title to generate the title automatically.

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

@haitham911 haitham911 requested a review from aknysh October 15, 2024 23:10
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

📜 Review details

Configuration used: CodeRabbit UI
Review profile: ASSERTIVE

📥 Commits

Files that changed from the base of the PR and between cfa2f21 and 10f8570.

📒 Files selected for processing (1)
  • internal/exec/terraform.go (3 hunks)
🧰 Additional context used
🔇 Additional comments (2)
internal/exec/terraform.go (2)

24-24: LGTM: New constant for the --everything flag.

The new constant everything is well-named and consistent with other constant declarations in the file. It correctly represents the --everything flag mentioned in the PR objectives.


24-24: Summary: Successfully implemented the --everything flag for Terraform state cleaning.

The changes in this file successfully implement the new --everything flag for the atmos terraform clean command as described in the PR objectives. The implementation is well-integrated into the existing code structure and follows the established patterns in the codebase.

Key points:

  1. A new constant everything is added to represent the flag.
  2. The clean subcommand logic is extended to handle the new flag.
  3. When the flag is present, the code correctly targets and deletes the specific Terraform state folder for the component.

These changes enhance the Atmos tool's functionality by providing users with more control over cleaning Terraform state files, which can be beneficial in testing scenarios as mentioned in the PR description.

Also applies to: 107-114

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

📜 Review details

Configuration used: CodeRabbit UI
Review profile: ASSERTIVE

📥 Commits

Files that changed from the base of the PR and between 10f8570 and 594be52.

📒 Files selected for processing (1)
  • internal/exec/terraform.go (2 hunks)
🧰 Additional context used
🔇 Additional comments (2)
internal/exec/terraform.go (2)

24-24: LGTM: New constant for the --everything flag.

The addition of the everything constant with the value "--everything" is appropriate and aligns with the PR objectives.


Line range hint 1-669: Overall: Implementation meets PR objectives.

The changes successfully implement the --everything flag functionality for the clean subcommand as described in the PR objectives. The new constant and the modifications to the ExecuteTerraform function are correct and well-integrated into the existing code structure. With the minor suggestion for adding a comment addressed, this implementation is ready for merging.

internal/exec/terraform.go Outdated Show resolved Hide resolved
@osterman
Copy link
Member

Here's what we should aim to replicate with --everything

https://github.com/cloudposse/atmos/blob/main/demo/screengrabs/scripts/demo-stacks/.demo.rc#L17-L22

Of this, I think we're missing also the *.tfvar.json and *.tf.json files.

Also, if no component is passed, can we then process all components?

This would clean all components:

atmos terraform clean --everything

and this would clean the vpc component.

atmos terraform clean vpc --everything

Note, many stacks can share the same component.

Also, please make sure to update the related docs for atmos terraform clean

@aknysh aknysh added the no-release Do not create a new release (wait for additional code changes) label Oct 16, 2024
@aknysh
Copy link
Member

aknysh commented Oct 16, 2024

Here's what we should aim to replicate with --everything

https://github.com/cloudposse/atmos/blob/main/demo/screengrabs/scripts/demo-stacks/.demo.rc#L17-L22

Of this, I think we're missing also the *.tfvar.json and *.tf.json files.

Also, if no component is passed, can we then process all components?

This would clean all components:

atmos terraform clean --everything

and this would clean the vpc component.

atmos terraform clean vpc --everything

Note, many stacks can share the same component.

Also, please make sure to update the related docs for atmos terraform clean

The docs need to be updted.
As a general rule, any new feature or updates to the existing feature should be reflected in the docs - this way we keep the code and the docs in sync and will. ot spend timelater trying to remember what was done or explain to other peopke howmto use it

@haitham911 let me know if you need help on updating the docs

internal/exec/terraform.go Outdated Show resolved Hide resolved
internal/exec/terraform.go Outdated Show resolved Hide resolved
Copy link
Member

@aknysh aknysh left a comment

Choose a reason for hiding this comment

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

@haitham911 please see comments

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: 11

📜 Review details

Configuration used: CodeRabbit UI
Review profile: ASSERTIVE

📥 Commits

Files that changed from the base of the PR and between 594be52 and 447105b.

📒 Files selected for processing (3)
  • internal/exec/path_utils.go (2 hunks)
  • internal/exec/terraform.go (3 hunks)
  • internal/exec/utils.go (2 hunks)
🧰 Additional context used
🔇 Additional comments (5)
internal/exec/terraform.go (4)

24-24: LGTM: Addition of everythingFlag constant

The new constant everythingFlag is correctly defined and follows the existing naming convention for flags in this file. This addition improves code readability and maintainability by centralizing the flag definition.


76-83: LGTM: Updated ProcessStacks call and error handling

The changes to the ProcessStacks function call and the subsequent error handling are appropriate. The introduction of the CheckStack parameter allows for more flexible behavior when processing stacks, which aligns well with the new --everything flag functionality.


Line range hint 1-644: Overall assessment: Implementation aligns with PR objectives

The changes to internal/exec/terraform.go successfully implement the --everything flag functionality for the clean subcommand as described in the PR objectives. The code is well-structured and covers the required scenarios for cleaning Terraform state files.

Key points:

  1. The everythingFlag constant is correctly defined.
  2. The logic for handling the --everything flag is properly integrated into the ExecuteTerraform function.
  3. The implementation covers scenarios for cleaning all components, a specific component, or a specific component and stack.

Minor improvements suggested:

  1. Remove a debug print statement.
  2. Consider enhancing error handling in some cases.
  3. Verify the implementation of new helper functions used in the changes.

Overall, the changes appear to meet the requirements and improve the functionality of the Atmos tool for Terraform state file management.


110-144: LGTM: Implementation of --everything flag for clean subcommand

The implementation of the --everything flag for the clean subcommand is comprehensive and aligns well with the PR objectives. It correctly handles different scenarios such as cleaning all components, a specific component, or a specific component and stack.

A few points to consider:

  1. The functions deleteFilesAndFoldersRecursive and findFoldersNamesWithPrefix are used but not defined in this file. Could you provide information about where these functions are defined and their exact behavior?

  2. The current error handling only logs warnings without stopping execution. Consider whether some errors should halt the process instead of continuing.

To verify the implementation of the new functions, please run the following script:

This will help ensure that these functions are properly defined and available for use in this context.

✅ Verification successful

LGTM: Implementation of --everything flag for clean subcommand

The implementation of the --everything flag for the clean subcommand is comprehensive and aligns well with the PR objectives. It correctly handles different scenarios such as cleaning all components, a specific component, or a specific component and stack.

A few points to consider:

  • The functions deleteFilesAndFoldersRecursive and findFoldersNamesWithPrefix are defined in internal/exec/path_utils.go, ensuring their availability and correctness.
  • The current error handling only logs warnings without stopping execution. Consider whether some errors should halt the process instead of continuing to enhance reliability.

To further improve, you might want to evaluate the error handling strategy to determine if certain failures should prevent the continuation of the cleanup process.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for the definitions of the new functions
echo "Searching for deleteFilesAndFoldersRecursive function:"
rg --type go "func deleteFilesAndFoldersRecursive"

echo "Searching for findFoldersNamesWithPrefix function:"
rg --type go "func findFoldersNamesWithPrefix"

Length of output: 537

internal/exec/path_utils.go (1)

139-175: Avoid using filepath.Walk due to potential performance issues.

Using filepath.Walk can be inefficient for large directory structures. Since we only need to check immediate subdirectories, consider using os.ReadDir for better performance.

[performance]

Apply this change to improve efficiency:

subDirs, err := os.ReadDir(basePath)
if err != nil {
	return fmt.Errorf("error reading base path %s: %w", basePath, err)
}

for _, subDir := range subDirs {
	if subDir.IsDir() {
		subDirPath := filepath.Join(basePath, subDir.Name())
		for _, item := range items {
			fullPath := filepath.Join(subDirPath, item)
			// Proceed with deletion logic
		}
	}
}

This avoids recursively walking through the entire directory structure.

internal/exec/terraform.go Outdated Show resolved Hide resolved
internal/exec/utils.go Show resolved Hide resolved
internal/exec/utils.go Outdated Show resolved Hide resolved
internal/exec/path_utils.go Outdated Show resolved Hide resolved
internal/exec/path_utils.go Outdated Show resolved Hide resolved
internal/exec/path_utils.go Outdated Show resolved Hide resolved
internal/exec/path_utils.go Outdated Show resolved Hide resolved
internal/exec/path_utils.go Outdated Show resolved Hide resolved
internal/exec/path_utils.go Outdated Show resolved Hide resolved
@haitham911 haitham911 requested a review from aknysh October 17, 2024 13:45
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: 7

📜 Review details

Configuration used: CodeRabbit UI
Review profile: ASSERTIVE

📥 Commits

Files that changed from the base of the PR and between 447105b and ff42d22.

📒 Files selected for processing (2)
  • internal/exec/help.go (2 hunks)
  • internal/exec/path_utils.go (2 hunks)
🧰 Additional context used
🔇 Additional comments (3)
internal/exec/help.go (2)

77-78: Approved: Added information about deleting state files

The addition of information about deleting the 'terraform.tfstate.d' folder when using the --everything flag is consistent with the PR objectives and provides crucial information about the expanded functionality of the clean command.


Line range hint 33-84: Overall assessment: Significant improvement in help messages

The changes to the processHelp function in internal/exec/help.go have significantly enhanced the clarity and comprehensiveness of the help messages for the atmos terraform clean command. These improvements include:

  1. Detailed explanation of the --everything flag's functionality
  2. Introduction of the --skip-lock-file flag
  3. Clear description of the command's behavior when no component or stack is specified
  4. Addition of a link to the documentation for further details

These enhancements align perfectly with the PR objectives and will greatly improve the user experience by providing more accurate and detailed information about the command's capabilities and usage.

internal/exec/path_utils.go (1)

92-126: findFoldersNamesWithPrefix function implementation looks good

The function correctly finds folders with the specified prefix in both the root directory and its immediate subdirectories. Error handling and directory traversal are appropriately implemented.

internal/exec/help.go Outdated Show resolved Hide resolved
internal/exec/help.go Outdated Show resolved Hide resolved
internal/exec/path_utils.go Outdated Show resolved Hide resolved
internal/exec/path_utils.go Outdated Show resolved Hide resolved
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: 7

📜 Review details

Configuration used: CodeRabbit UI
Review profile: ASSERTIVE

📥 Commits

Files that changed from the base of the PR and between ff42d22 and 23b320a.

📒 Files selected for processing (3)
  • internal/exec/path_utils.go (2 hunks)
  • internal/exec/terraform.go (3 hunks)
  • internal/exec/utils.go (2 hunks)
🧰 Additional context used
🔇 Additional comments (5)
internal/exec/terraform.go (3)

24-24: LGTM: Addition of everythingFlag constant

The new constant everythingFlag is correctly defined and aligns with the PR objectives to introduce a comprehensive cleaning option.


Line range hint 144-193: LGTM: Preservation of existing cleaning logic

The existing cleaning logic for .terraform folder, .terraform.lock.hcl file, and other artifacts is preserved. This maintains backwards compatibility while the new --everything flag logic complements the existing process.


Line range hint 1-1000: Overall LGTM: Well-implemented --everything flag for Terraform clean

The implementation of the --everything flag for the Terraform clean subcommand is well-done and aligns closely with the PR objectives. The code is structured logically, follows existing patterns, and maintains backwards compatibility. Error handling and logging are appropriately implemented.

Minor suggestions for improvement:

  1. Use camelCase for local variables (needProcessStacks, checkStack).
  2. Rename listOfClear to filesToClear for better clarity.

These small changes would enhance readability and consistency with Go naming conventions.

internal/exec/utils.go (2)

394-397: LGTM!

The added condition correctly allows the function to proceed without error when checkStack is false and no stacks are found. This enhances the flexibility for operations that don't require a stack.


1003-1009: LGTM!

The updated argument parsing logic now properly differentiates between options and component names. This improves the robustness and clarity of the function.

internal/exec/terraform.go Outdated Show resolved Hide resolved
internal/exec/terraform.go Outdated Show resolved Hide resolved
internal/exec/path_utils.go Outdated Show resolved Hide resolved
internal/exec/path_utils.go Outdated Show resolved Hide resolved
internal/exec/path_utils.go Outdated Show resolved Hide resolved
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 (3)
internal/exec/terraform_clean.go (3)

285-291: Standardize error messages in confirmation handling

The error message "Mission aborted." is used here, while elsewhere we use more formal messages. Consider standardizing the message style across the codebase.

-u.LogWarning(cliConfig, "Mission aborted.")
+u.LogWarning(cliConfig, "Operation cancelled by user.")

453-474: Enhance user confirmation message clarity

The confirmation message could be more explicit about the destructive nature of the operation, especially when using the --everything flag.

Consider adding a warning about the irreversible nature of the operation:

-message = fmt.Sprintf("This will delete %v local terraform state files affecting all components", total)
+message = fmt.Sprintf("WARNING: This will permanently delete %v local terraform state files affecting all components", total)

369-384: Strengthen path validation in IsValidDataDir

While the function checks for root directory and parent directory traversal, it could benefit from additional safety checks.

Consider adding checks for:

  • Absolute path resolution
  • System-critical directories
  • Symbolic link detection
func IsValidDataDir(tfDataDir string) error {
    if tfDataDir == "" {
        return fmt.Errorf("ENV TF_DATA_DIR is empty")
    }
    absTFDataDir, err := filepath.Abs(tfDataDir)
    if err != nil {
        return fmt.Errorf("error resolving TF_DATA_DIR path: %v", err)
    }
+   // Check if path is a symlink
+   if info, err := os.Lstat(absTFDataDir); err == nil && info.Mode()&os.ModeSymlink != 0 {
+       return fmt.Errorf("refusing to process symbolic link: %s", tfDataDir)
+   }
    if absTFDataDir == "/" || absTFDataDir == filepath.Clean("/") {
        return fmt.Errorf("refusing to delete root directory '/'")
    }
    if strings.Contains(absTFDataDir, "..") {
        return fmt.Errorf("refusing to delete directory containing '..'")
    }
+   // Add checks for system-critical directories
+   criticalPaths := []string{"/etc", "/usr", "/var", "/bin"}
+   for _, path := range criticalPaths {
+       if strings.HasPrefix(absTFDataDir, path) {
+           return fmt.Errorf("refusing to delete system directory: %s", tfDataDir)
+       }
+   }
    return nil
}
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 813e9eb and f452447.

📒 Files selected for processing (1)
  • internal/exec/terraform_clean.go (1 hunks)
🧰 Additional context used
📓 Learnings (1)
internal/exec/terraform_clean.go (2)
Learnt from: haitham911
PR: cloudposse/atmos#727
File: internal/exec/terraform_clean.go:407-416
Timestamp: 2024-11-24T19:13:10.287Z
Learning: In `internal/exec/terraform_clean.go`, when `getStackTerraformStateFolder` returns an error in the `handleCleanSubCommand` function, the error is logged, and the process continues without returning the error.
Learnt from: osterman
PR: cloudposse/atmos#727
File: internal/exec/terraform_clean.go:233-235
Timestamp: 2024-11-12T05:52:05.088Z
Learning: When specifying color values in functions like `confirmDeleteTerraformLocal` in `internal/exec/terraform_clean.go`, avoid hardcoding color values. Instead, use predefined color constants or allow customization through configuration settings to improve accessibility and user experience across different terminals and themes.
🔇 Additional comments (2)
internal/exec/terraform_clean.go (2)

15-28: Well-structured data types for file system operations!

The ObjectInfo and Directory structs are well-designed with clear field names and appropriate types for representing file system objects.


342-346: 🛠️ Refactor suggestion

Enhance path handling for TF_DATA_DIR

When handling TF_DATA_DIR, the code should handle both absolute and relative paths correctly.

Consider this approach:

-if _, err := os.Stat(filepath.Join(componentPath, tfDataDir)); os.IsNotExist(err) {
+tfDataDirPath := tfDataDir
+if !filepath.IsAbs(tfDataDir) {
+    tfDataDirPath = filepath.Join(componentPath, tfDataDir)
+}
+if _, err := os.Stat(tfDataDirPath); os.IsNotExist(err) {
    u.LogWarning(cliConfig, fmt.Sprintf("TF_DATA_DIR '%s' does not exist", tfDataDir))
    return
}

Likely invalid or redundant comment.

internal/exec/terraform_clean.go Outdated Show resolved Hide resolved
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 (4)
internal/exec/terraform_clean.go (4)

15-28: Add documentation for type definitions

The ObjectInfo and Directory structs would benefit from documentation explaining their purpose and field usage. Consider adding comments in the standard Go documentation format.

+// ObjectInfo represents metadata about a file or directory in the filesystem
 type ObjectInfo struct {
+    // FullPath is the absolute path to the file
     FullPath     string
+    // RelativePath is the path relative to the base directory
     RelativePath string
+    // Name is the base name of the file
     Name         string
+    // IsDir indicates whether this is a directory
     IsDir        bool
 }

+// Directory represents a directory containing files to be processed
 type Directory struct {
+    // Name is the base name of the directory
     Name         string
+    // FullPath is the absolute path to the directory
     FullPath     string
+    // RelativePath is the path relative to the base directory
     RelativePath string
+    // Files contains the files and subdirectories within this directory
     Files        []ObjectInfo
 }

31-66: Consider additional validation in findFoldersNamesWithPrefix

While the function handles basic error cases, consider adding:

  1. Maximum depth validation to prevent excessive traversal
  2. Path sanitization to prevent path traversal attacks
  3. Size limits for the returned slice to prevent memory issues
 func findFoldersNamesWithPrefix(root, prefix string, cliConfig schema.CliConfiguration) ([]string, error) {
     var folderNames []string
+    const maxResults = 1000 // Prevent unbounded results
     if root == "" {
         return nil, fmt.Errorf("root path cannot be empty")
     }
+    // Sanitize and validate the root path
+    cleanRoot := filepath.Clean(root)
+    if strings.Contains(cleanRoot, "..") {
+        return nil, fmt.Errorf("invalid root path: contains parent directory reference")
+    }

256-279: Use consistent logging approach

The function uses direct fmt.Printf calls instead of the logging system used elsewhere in the codebase. Consider using the unified logging functions for consistency.

-    fmt.Printf("%s Cannot delete %s: path does not exist", xMark, objectName)
-    fmt.Println()
+    u.LogWarning(cliConfig, fmt.Sprintf("%s Cannot delete %s: path does not exist", xMark, objectName))

-    fmt.Printf("%s Error deleting %s", xMark, objectName)
-    fmt.Println()
+    u.LogError(cliConfig, fmt.Sprintf("%s Error deleting %s", xMark, objectName))

-    fmt.Printf("%s Deleted %s", checkMark, objectName)
-    fmt.Println()
+    u.LogInfo(cliConfig, fmt.Sprintf("%s Deleted %s", checkMark, objectName))

384-483: Enhance error handling in handleCleanSubCommand

Consider improving error handling in the following areas:

  1. Error from getStackTerraformStateFolder is logged but not propagated
  2. Errors during tfDataDirFolders collection are only logged
     if err != nil {
         errMsg := fmt.Errorf("error getting stack terraform state folders: %v", err)
         u.LogTrace(cliConfig, errMsg.Error())
+        if !force {
+            return errMsg
+        }
     }
📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 149f4c9 and 5e0c92f.

📒 Files selected for processing (1)
  • internal/exec/terraform_clean.go (1 hunks)
🧰 Additional context used
📓 Learnings (1)
internal/exec/terraform_clean.go (2)
Learnt from: haitham911
PR: cloudposse/atmos#727
File: internal/exec/terraform_clean.go:407-416
Timestamp: 2024-11-24T19:13:10.287Z
Learning: In `internal/exec/terraform_clean.go`, when `getStackTerraformStateFolder` returns an error in the `handleCleanSubCommand` function, the error is logged, and the process continues without returning the error.
Learnt from: osterman
PR: cloudposse/atmos#727
File: internal/exec/terraform_clean.go:233-235
Timestamp: 2024-11-12T05:52:05.088Z
Learning: When specifying color values in functions like `confirmDeleteTerraformLocal` in `internal/exec/terraform_clean.go`, avoid hardcoding color values. Instead, use predefined color constants or allow customization through configuration settings to improve accessibility and user experience across different terminals and themes.
🔇 Additional comments (1)
internal/exec/terraform_clean.go (1)

329-348: 🛠️ Refactor suggestion

Improve path handling for TF_DATA_DIR

When handling TF_DATA_DIR, the function should consider whether the path is absolute or relative before joining it with componentPath.

-    if _, err := os.Stat(filepath.Join(componentPath, tfDataDir)); os.IsNotExist(err) {
+    tfDataDirPath := tfDataDir
+    if !filepath.IsAbs(tfDataDir) {
+        tfDataDirPath = filepath.Join(componentPath, tfDataDir)
+    }
+    if _, err := os.Stat(tfDataDirPath); os.IsNotExist(err) {
         u.LogWarning(cliConfig, fmt.Sprintf("TF_DATA_DIR '%s' does not exist", tfDataDir))
         return
     }

Likely invalid or redundant comment.

@aknysh aknysh temporarily deployed to preview December 5, 2024 01:40 — with GitHub Actions Inactive
Copy link
Member

@aknysh aknysh left a comment

Choose a reason for hiding this comment

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

thanks @haitham911

@aknysh aknysh merged commit 382de94 into main Dec 5, 2024
29 checks passed
@aknysh aknysh deleted the DEV-346 branch December 5, 2024 01:50
Copy link

github-actions bot commented Dec 5, 2024

These changes were released in v1.114.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.

atmos clean all command
3 participants