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

Decoupling Consul's Role-Based Access Control (RBAC) from the core system. #4276

Open
wants to merge 5 commits into
base: main
Choose a base branch
from

Conversation

payalsu
Copy link

@payalsu payalsu commented Aug 30, 2024

Changes proposed in this PR

The goal of this requirement is to enhance the security architecture by decoupling Consul's Role-Based Access Control (RBAC) from the core system. This change is aimed at allowing Consul RBAC to be installed and configured as a prerequisite, ensuring that the permissions required to install the application and the cluster level RBAC can be managed independently. By implementing this solution, we will improve access management, reduce security risks, and streamline RBAC architecture.
Goals:

  • Decoupling RBAC: Implement a mechanism that allows Consul RBAC to function independently of the Consul cluster, promoting a modular architecture.

  • Minimizing Permissions: Ensure that users responsible for installing the RBAC and application operate with the least privilege principle, mitigating the risk posed by overly broad permissions.

  • Improving Security Posture: Enhance the overall security of applications by limiting the attack surface exposed to potential threats.

Benefits:

  • Enhanced Security: Reducing cluster-wide permissions decreases the risk of unauthorized access and potential vulnerabilities.

  • Easier Compliance: By enabling granular access controls, organizations can more easily comply with security standards and regulations.

  • Operational Efficiency: Streamlined RBAC permissions management leads to a more efficient development and deployment process, reducing friction between teams.

How I've tested this PR

  • Built the chart and deployed and tested with our Organization's product.
  • Deployed Consul-RBAC as a separate chart maintained by us
  • Tested new RBAC components to validate individual functions and logic. This included consul chart deployment along with other applications and ensuring normal functioning without any unexpected behaviors.

How I expect reviewers to test this PR

  • Deploy/Verify manifest of the consul chart with --set global.rbac.create=false value and ensure that this will not create any RBAC resources
  • Deploy with --set global.rbac.create=true value and ensure successful consul deployment along with RBAC resource creation.

Checklist

@payalsu payalsu requested a review from a team as a code owner August 30, 2024 10:52
Copy link

hashicorp-cla-app bot commented Aug 30, 2024

CLA assistant check
All committers have signed the CLA.

@boruszak boruszak closed this Sep 4, 2024
@boruszak boruszak reopened this Sep 4, 2024
@boruszak
Copy link
Contributor

boruszak commented Sep 4, 2024

This pull request appears to be targeted spam.

@boruszak boruszak closed this Sep 4, 2024
@payalsu
Copy link
Author

payalsu commented Sep 5, 2024

Hi @boruszak
May I know the reason for considering this PR as SPAM and closing it ?

This is a valid requirement from our organization. I have added enough explanation about the requirement. Is need more information or details, will be happy to answer .
Can you please RE-OPEN the PR ?
Thanks !!

@blake
Copy link
Contributor

blake commented Sep 5, 2024

@payalsu Can you provide a little more detail as to why your organization needs to manage the RBAC permissions separately from the Helm chart? How do you plan to keep your external RBAC definitions up-to-date with changes to the Helm chart that require changes to K8s RBAC configs?

@boruszak
Copy link
Contributor

boruszak commented Sep 5, 2024

@payalsu I closed the PR for security reasons. 1) This PR makes what appear to be substantial changes to the software's security operations, but the GitHub account is a month old, 2) there are no other contributions or indications of organization affinity on the GitHub account, and 3) the review request was targeted at the documentation review alias, despite the fact that the changes are not documentation changes.

Please respond to the questions from @blake, who can evaluate the pull request and decide whether to reopen it.

@payalsu
Copy link
Author

payalsu commented Sep 6, 2024

Hi @blake
Our company is deploying Consul as part of a solution that runs on our customers Kubernetes environment. The customer manages the setup of the Kubernetes environment, including the creation of sensitive resources, such as RBAC. Our company is responsible for installing the application in that environment, but we don't have permission to install the RBAC.

As a result, we want the ability to add a feature flag to disable the RBAC installation and manage that using a separate RBAC specific helm chart. We will maintain that chart as we upgrade Consul to newer versions. I believe this use case is valid and it enhances security by allowing cluster administrators with higher levels of permissions to manage the sensitive RBAC resources, while restricting other users with less permissions to install the application itself.

If you require further clarification on this use case, I would be happy to provide more information.

@payalsu
Copy link
Author

payalsu commented Sep 9, 2024

Hi @blake @boruszak

If everything looks ok , can this PR be re-opened ?

Thanks !!

@boruszak boruszak reopened this Sep 9, 2024
@payalsu
Copy link
Author

payalsu commented Sep 30, 2024

Hi
Can this PR be reviewed by the team please ?

@payalsu
Copy link
Author

payalsu commented Nov 15, 2024

Hi
Can this changes be reviewed?

@payalsu
Copy link
Author

payalsu commented Nov 28, 2024

Could you please review the pull request (PR) I submitted? This PR implements the rbac.create flag in our Helm chart, allowing users to choose whether or not to install RBAC resources.

To help illustrate this approach, I've compiled a list of couple of other charts that have implemented similar mechanisms:

Nginx Ingress Controller: RBAC Flag
Prometheus: RBAC Flag
Grafana: RBAC Flag
Jenkins: RBAC Flag

Your feedback would be invaluable, and I look forward to your thoughts.

Thank you !!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants