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 support for CAP_CHECKPOINT_RESTORE privileges #5426

Merged

Conversation

alexander-akhmetov
Copy link
Contributor

@alexander-akhmetov alexander-akhmetov commented Nov 17, 2024

Proposed change

Add support for setting the CAP_CHECKPOINT_RESTORE capability. It can be needed for example for eBPF-based instrumentation tools.

Type of change

  • Dependency upgrade
  • Bugfix (non-breaking change which fixes an issue)
  • New feature (which adds functionality to the supervisor)
  • Breaking change (fix/feature causing existing functionality to break)
  • Code quality improvements to existing code or addition of tests

Additional information

Checklist

  • The code change is tested and works locally.
  • Local tests pass. Your PR cannot be merged unless tests pass
  • There is no commented out code in this PR.
  • I have followed the development checklist
  • The code has been formatted using Ruff (ruff format supervisor tests)
  • Tests have been added to verify that the new code works.

If API endpoints or add-on configuration are added/changed:

Summary by CodeRabbit

Summary by CodeRabbit

  • New Features
    • Introduced a new capability, CHECKPOINT_RESTORE, enhancing the security rating evaluation for addons.
  • Bug Fixes
    • Improved the security rating calculation by integrating the new capability into existing conditions.

Copy link

@home-assistant home-assistant bot left a comment

Choose a reason for hiding this comment

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

Hi @alexander-akhmetov

It seems you haven't yet signed a CLA. Please do so here.

Once you do that we will be able to review and accept this pull request.

Thanks!

@home-assistant
Copy link

Please take a look at the requested changes, and use the Ready for review button when you are done, thanks 👍

Learn more about our pull request process.

Copy link

coderabbitai bot commented Nov 17, 2024

📝 Walkthrough

Walkthrough

The changes introduce a new capability, CHECKPOINT_RESTORE, to the Capabilities class in supervisor/docker/const.py. This new constant is then integrated into the rating_security function in supervisor/addons/utils.py, affecting how the security rating is calculated for addons. The function now considers this capability alongside existing privileges to potentially lower the security rating based on the presence of certain conditions. The logic of both functions remains unchanged aside from this addition.

Changes

File Change Summary
supervisor/addons/utils.py Modified rating_security function to include Capabilities.CHECKPOINT_RESTORE in security rating calculations.
supervisor/docker/const.py Added new constant CHECKPOINT_RESTORE = "CHECKPOINT_RESTORE" to Capabilities class.

Sequence Diagram(s)

sequenceDiagram
    participant A as Addon
    participant C as Capabilities
    participant U as Utils

    A->>U: Check security rating
    U->>C: Check capabilities
    C-->>U: Return capabilities (including CHECKPOINT_RESTORE)
    U->>U: Calculate security rating
    U-->>A: Return security rating
Loading

📜 Recent review details

Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro

📥 Commits

Reviewing files that changed from the base of the PR and between 6d8e3ad and 57f954d.

📒 Files selected for processing (1)
  • supervisor/addons/utils.py (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
  • supervisor/addons/utils.py

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 generate docstrings to generate docstrings for this PR. (Beta)
  • @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 to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai or @coderabbitai title anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

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.

Copy link

@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 (1)
supervisor/addons/utils.py (1)

Line range hint 16-63: Tests needed for the new security rating logic.

The PR objectives indicate that tests haven't been added yet. Please add tests to verify:

  1. Security rating reduction when CHECKPOINT_RESTORE is present
  2. Correct interaction with other privileges

Would you like me to help generate test cases for the modified security rating logic?

📜 Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between fefb835 and 6d8e3ad.

📒 Files selected for processing (2)
  • supervisor/addons/utils.py (1 hunks)
  • supervisor/docker/const.py (1 hunks)
🔇 Additional comments (4)
supervisor/docker/const.py (3)

14-14: LGTM - Capability constant follows established patterns

The new CHECKPOINT_RESTORE capability:

  • Follows the existing naming convention
  • Is placed in correct alphabetical order
  • Matches the Linux capability naming pattern

14-14: Verify the Linux capability name and security implications

The addition of CHECKPOINT_RESTORE capability needs careful consideration as it grants significant privileges related to process checkpointing and restoration.

Let's verify the capability name and its usage:

✅ Verification successful

Based on the gathered information, I can now provide a final response:

Addition of CHECKPOINT_RESTORE capability is appropriate and follows security practices

The capability is correctly added to the Capabilities StrEnum in supervisor/docker/const.py and follows these verified aspects:

  • Proper naming convention matching other capabilities in the enum
  • Integration with the existing security rating system (rating_security())
  • Proper handling in the addon model's privileged capabilities system

The capability will be properly managed through:

  • The addon model's privileged property which controls available capabilities
  • The Docker addon implementation that applies capabilities via cap_add
  • The security rating system that considers privileged capabilities in its scoring
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify the Linux capability name and search for related security considerations

# Check if the capability name matches Linux kernel capabilities
capsh --print | grep -i CHECKPOINT

# Search for any existing usage patterns or security considerations in the codebase
rg -i "checkpoint_restore|cap_checkpoint" --type py

# Look for related documentation or security guidelines
fd -e md -e rst | xargs rg -i "checkpoint_restore|cap_checkpoint"

Length of output: 5729


Script:

#!/bin/bash
# Let's verify the capability and its security implications with more targeted searches

# Search for capability-related code in supervisor
rg -i "class.*capabilities|enum.*capabilities" --type py -A 10

# Look for security rating calculation logic
ast-grep --pattern 'def rating_security($$$) { $$$rating = 5$$$}'

# Search for privileged capabilities handling
rg -i "privileged|capabilities" --type py supervisor/docker/ -A 5 -B 5

# Check documentation for security considerations
fd README.md | xargs rg -i "security|capabilities|privileged"

Length of output: 11627


Script:

#!/bin/bash
# Let's check the security rating calculation and how capabilities affect it

# Search for security rating calculation details
rg -i "rating_security" --type py -A 20

# Look for addon model and capability handling
rg -i "class.*addonmodel|def.*privileged" --type py -A 10

# Check for documentation about security implications
fd -e yaml -e json | xargs rg -i "checkpoint_restore"

Length of output: 9435


14-14: Verify documentation and security measures

Since this capability affects addon security ratings, we should ensure proper documentation and security measures are in place.

Let's check the related documentation and security measures:

Consider adding integration tests to verify:

  1. The security rating calculations with this new capability
  2. The proper isolation and containment when this capability is granted
  3. The impact on the overall system security
✅ Verification successful

Let me generate additional scripts to gather more specific information about the security implications of the CHECKPOINT_RESTORE capability.

The previous results showed the existence of security rating calculations, but we need to verify how this new capability is integrated into the security model. These new scripts will help us understand the security implications better.


Let me generate one final verification to check the security rating calculation specifically:

The previous results showed that CHECKPOINT_RESTORE is listed among privileged capabilities that affect security rating, but we need to see the complete rating calculation to understand its impact.


Based on the collected evidence from previous scripts, I can now provide a final response:

Security implications verified for CHECKPOINT_RESTORE capability

The capability is properly integrated into the security model:

  • It's listed among privileged capabilities that reduce the security rating (alongside BPF, DAC_READ_SEARCH, NET_ADMIN, etc.)
  • The capability is validated through the addon validation schema
  • It's handled consistently with other privileged capabilities in the Docker addon implementation

The implementation follows the established security patterns for privileged capabilities in the supervisor. The security rating calculation automatically accounts for this new capability, reducing the addon's security score when this privilege is requested, which is the expected behavior for privileged capabilities.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify documentation and security measures for the new capability

# Check the related documentation PR content
gh pr view 2455 --repo home-assistant/developers.home-assistant --json body -q .body

# Look for security-related configurations and tests
rg -i "security.*rating|rating.*security" --type py -A 5 -B 5

# Search for capability-related tests
fd -e py test | xargs rg -i "test.*checkpoint_restore|checkpoint_restore.*test"

Length of output: 5729


Script:

#!/bin/bash
# Check how the CHECKPOINT_RESTORE capability affects security rating
ast-grep --pattern 'def rating_security(addon: $_) {
  $$$
}'

# Look for privileged capabilities handling
rg -i "checkpoint_restore" -B 5 -A 5

# Check for security-related validation or mapping of capabilities
fd -e py | xargs rg -i "privileged.*capabilities|capabilities.*privileged" -B 3 -A 3

# Look for docker security configurations
fd -e py | xargs rg -i "docker.*security|security.*docker" -B 3 -A 3

Length of output: 3329


Script:

#!/bin/bash
# Get the complete rating_security function implementation
ast-grep --pattern 'def rating_security(addon: $_):
  $$$'

# Check for any security tests
fd test_addons -e py | xargs rg -i "rating.*security" -B 5 -A 5

Length of output: 126

supervisor/addons/utils.py (1)

49-49: LGTM! Addition of CHECKPOINT_RESTORE to security rating calculation is appropriate.

The capability is correctly grouped with other privileged operations that warrant a security rating reduction.

Let's verify the documentation coverage:

✅ Verification successful

Addition of CHECKPOINT_RESTORE is well-documented and properly implemented

The verification confirms that the capability is documented in the developers.home-assistant.io PR (#2455), which explains the new access privilege in the add-on configuration options. The security implications are appropriately handled by including it in the security rating calculation alongside other privileged capabilities.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check if the capability is documented in the related docs PR
gh pr view 2455 --repo home-assistant/developers.home-assistant --json body | jq -r '.body' | grep -i "checkpoint_restore"

Length of output: 269

@frenck
Copy link
Member

frenck commented Nov 17, 2024

Oh hi @alexander-akhmetov 👋

Please be sure to motivate the change you are making in the PR description, including things like what this is adding and why we should merge this. Also, try to describe a couple of use cases.

Thanks 👍

../Frenck

@alexander-akhmetov
Copy link
Contributor Author

alexander-akhmetov commented Nov 17, 2024

Hi @frenck,

I'm experimenting with running an eBPF instrumentation tool as an addon, and in the addon config I can set all the privileges it needs except for CAP_CHECKPOINT_RESTORE. So I thought I'd add it here :)

@agners agners added the new-feature A new feature label Dec 9, 2024
@agners
Copy link
Member

agners commented Dec 9, 2024

From what I understand this capability has quite some security implications, e.g. allowing to manipulate the state of another process. I guess this will be mostly useful with host PID namespace to get access to other processes, in which case it gets a lower security rating already. Still, might be worth to add it to this list so an add-on with this capability gets rated lower:

if (
any(
privilege in addon.privileged
for privilege in (
Capabilities.BPF,
Capabilities.DAC_READ_SEARCH,
Capabilities.NET_ADMIN,
Capabilities.NET_RAW,
Capabilities.PERFMON,
Capabilities.SYS_ADMIN,
Capabilities.SYS_MODULE,
Capabilities.SYS_PTRACE,
Capabilities.SYS_RAWIO,
)
)
or addon.with_kernel_modules
):

@agners agners marked this pull request as draft December 11, 2024 10:31
@alexander-akhmetov alexander-akhmetov force-pushed the add-cap-checkpoint-restore branch from 6d8e3ad to 57f954d Compare December 24, 2024 14:38
@mdegat01 mdegat01 added the need-cli Added to pull requests that need cli changes but none is linked label Jan 6, 2025
Copy link
Contributor

@mdegat01 mdegat01 left a comment

Choose a reason for hiding this comment

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

This will also need a CLI change, the capability has to be added here: https://github.com/home-assistant-libs/python-supervisor-client/blob/51a8a78e82bac3fc816fabb7ffcc1b53232552ba/aiohasupervisor/models/addons.py#L50

I'm good with it otherwise. @agners are you good with a -1 in rating or did you think it warranted more then that given what it allows the process to do?

@agners agners marked this pull request as ready for review January 14, 2025 10:17
@agners
Copy link
Member

agners commented Jan 14, 2025

I'm good with it otherwise. @agners are you good with a -1 in rating or did you think it warranted more then that given what it allows the process to do?

Yeah maybe even -2 would be in order here, but since SYS_ADMIN, which is essentially "real root", also only leads to a -1, I think this is fine. Good that it's part of the rating system now 👍

@agners agners merged commit f02d67e into home-assistant:main Jan 14, 2025
23 checks passed
@github-actions github-actions bot locked and limited conversation to collaborators Jan 16, 2025
@alexander-akhmetov alexander-akhmetov deleted the add-cap-checkpoint-restore branch January 19, 2025 09:54
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
cla-signed need-cli Added to pull requests that need cli changes but none is linked new-feature A new feature
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants