Roles and Permission Policies
In this document, you will learn the concept of roles and permission policies, an advanced and exclusive feature in API7 Enterprise.
Overview
- Roles: Define user groups with specific access levels. You can create custom roles to categorize users with similar permission needs. A single role can be associated with multiple permission policies.
- Permission Policies: These act as blueprints, outlining the allowed actions (permissions) for specific resources within API7 Enterprise (e.g., gateway groups, published services). A single permission policy can be shared and applied to multiple roles, promoting efficiency and consistency.
By associating permission policies with roles, you can efficiently assign appropriate access levels to different user groups. This simplifies access control management and ensures users only have the permissions they need to perform their tasks.
How Roles and Permission Policies Work
Consider a scenario where you have created a custom role called Gateway Group Manager and attached it to a permission policy named Gateway Group Basics Actions.
This permission policy grants the GetGatewayGroups action to all gateway group resources(resource scope is *), allowing users with the Gateway Group Manager role to view gateway group list on the Dashboard, and retrieve gateway group list directly using the Get all gateway groups API or leverage API7 tools like the ADC and API7 Ingress Controller.
Key Points:
- Roles are used to categorize users based on their shared permission requirements. Changes to the attached permission policy of a role will propagate to all users within that role.
- Permission policies specifying authorized actions for designated resources within API7 Enterprise(including API7 Gateway and API7 Portal).
- Attaching a permission policy to multiple roles grants the associated permissions to all users within those roles.
- Permission policies can be as detailed or broad as needed. Start with a base set and refine them as your access control requirements evolve.
Use Cases
Built-in Super Admin Role
API7 Enterprise starts with a single, pre-defined role named Super Admin for initial system setup. This role is associated with the built-in super-admin-permission-policy granting full access to all actions and resources within API7 Enterprise. Both the pre-defined role and policy are non-editable to ensure core system security.
The initial admin account is permanently tied to the Super Admin role, and its role cannot be changed. This reinforces the principle of least privilege and prevents accidental permission escalations.
Expanding Access Control with Custom Roles
While the built-in role and policy offer full access, API7 Enterprise empowers you to create custom roles with granular permissions. You can even attach the super-admin-permission-policy to your custom roles for scenarios requiring extensive access.
Here is an example scenario: Isolating Environments and Tailoring Security
By associating permission policies with specific gateway groups, you can define granular security controls for each environment. This allows you to enforce stricter access limitations in environments like Production, compared to more relaxed settings in development environments like Test or UAT.
- Define Granular Permission Policies
Create specific permission policies for each gateway group, such as test-gateway-group-full-access, uat-gateway-group-full-access, and production-gateway-group-full-access. These policies will define the allowed actions and resources within each environment.
- Assign Roles with Controlled Access
Create custom roles to categorize users with similar access needs. Attach the appropriate permission policies to each role:
- Development Team Member: Grant access to the test-gateway-group-full-accesspolicy, allowing them to make changes solely in the test environment.
- Development Team Leader: Assign access to both test-gateway-group-full-accessanduat-gateway-group-full-accesspolicies. This enables them to work in both test and UAT environments, potentially including the ability to synchronize stable configurations from test to UAT.
- Testing Engineer: Attach uat-gateway-group-full-accessandproduction-gateway-group-full-accesspolicies. This restricts their access to UAT and Production environments, focusing on new API testing and publishing tasks.
How to Configure Permission Policies
API7 Enterprise currently stores permission policies as JSON documents. Creating and editing these policies involves using a JSON editor to define the details and then manually copying the edited JSON code back into API7 Enterprise for configuration.
Future versions of API7 Enterprise are planned to include a visual editor for permission policies. Please stay tuned for updates.
JSON Policy Document Structure
As illustrated in the following example, a JSON policy document includes these elements:
// PermissionPolicy demo
{
    "statement": [
        {
            "resources": [
                "arn:gatewaygroup:<[^:]*>"
            ],
            "actions": [
                "GatewayGroup:DeleteGatewayGroup"
            ],
    
            "conditions": {
                "gateway_group_label": {
                    "type": "MatchLabel",
                    "options": [
                        {
                            "key": "env",
                            "operator": "exact_match",
                            "value": "prod"
                        }
                    ]
                }
            },
            "effect": "allow" 
        }
    ]
}
- A single permission policy in API7 Enterprise can contain multiple statements, which may overlap in terms of the resources or actions they govern. Generally, statements within a policy function with an OR relationship. If any single statement grants permission (using "allow") for a user, they are authorized to perform the action on the specified resource.
- One statement define allowed actions and resources, effect can be allow or deny. API7 Enterprise enforces a principle of "deny overrides allow" for permission policies. Within a user, regardless of the specific role and attached permission policy, "deny" statements always override "allow" statements for the same action and resource.
- Optional conditions allows targeting flexible groups of resources sharing a specific label, simplifying policy management, improving scalability, and enhancing maintainability.
Example
In this example, assume there are three gateway groups:
- Name: Test gateway group, with label test,department A
- Name: Blue gateway group, with label prod,department B
- Name: Green gateway group, with label prod,department A
Consider a user assigned to a role with the above example permission policy. This user can delete Blue gateway groupand Green gateway group through the Dashboard or API7 tools, but not Test gateway group.
However, if the Test gateway group 's label is changed to prod, the user can then delete it due to the matching label. Similarly, a newly created Black gateway group with the prod label would also be deleted by this user.
About Using Labels in Permission Policy Condition
Using labels in permission policy condition instead of using resource ID can have the following advantages and disadvantages:
Advantages
- Dynamic Access Control: Labels are adaptable and can be updated independently of resource IDs. This allows for modifying access control policies without affecting resource identification.
- Scalability: A single label can be applied to multiple resources, simplifying policy management for growing resources. Using label can avoid the following situation:A user creates a new resource (e.g., a gateway group) but cannot access it because the permission policies referencing the old resource ID do not include the new one.
- Maintainability: Policies referencing labels are less likely to break due to changes in resource IDs.
Disadvantages
- Reduced Clarity: Labels introduce an abstraction layer, potentially making it harder to understand which specific resources a policy applies to at a glance.
- Misconfiguration Risks: Inconsistent or inaccurate labeling can lead to unintended access grants or denials.
- Dynamic Access Control Leading to Unexpected Behavior: While labels offer flexibility, they can introduce dynamic access control. This means a user's ability to access a specific resource might change based on updates to the resource labels, potentially leading to less predictable access behavior compared to using static resource IDs.
Finding the Right Balance:
- Labels for Broader Categories: Use labels for broader access control categories (e.g., "production", "test"). Resource IDs for Granular Control: Use resource IDs for specific resources requiring fine-grained control (e.g., a unique ID for a critical API endpoint).
- Clear Labeling Practices: Ensure consistent and well-defined labeling conventions throughout your API environment.
By understanding these trade-offs and implementing best practices, you can leverage labels effectively to enhance the security and manageability of your API7 Enterprise permission policies.
Useful Tips
Grant Least Privilege
Granting users only the minimum permissions needed for their designated tasks within the API environment. To achieve this, first clearly define user and role needs. Then, craft permission policies with a restricted set of actions and resources. Finally, add more permissions only when absolutely necessary, ensuring a balance between efficiency and strong access control.
Benefits:
- Reduced Attack Surface: Limiting permissions minimizes the potential impact of compromised accounts.
- Enhanced Accountability: Clear user access limitations promote better ownership and responsibility.
- Simplified Management: Maintaining least privilege simplifies permission management and reduces the risk of accidental oversights.
Configure the Permissions of Roles and Permission Policies
As with other resources in API7 Enterprise, roles and permission policies themselves require well-defined access control. Here are two common approaches:
- Consolidated Permissions: Specified users can update the role itself and modify all its attached permission policies. This streamlines their workflow by managing both aspects together. All permission policies only attached to a single role can help simplify the design in this scenario. 
- Separate Access Control: Manage access control for roles and permission policies independently. This allows for frequently changing users within roles while maintaining stable policy content. 
The optimal approach depends on your specific needs. Consider factors like:
- Frequency of role membership changes
- Importance of maintaining stable policy content
Additional Resources
- Getting Started
- Best Practice
- Reference