Expand my Community achievements bar.

Permission for files and folder level in 6.5.19

Avatar

Level 2

Hi team,

 

We get a new requirement from our customer.

 

we usually apply permission only in folder(root) level based on the security groups and it will be applicable to files(sub pages) as well 

 

but now, we have to apply permission for folders and different permission for files as well.

 

so we are not sure, how to apply different level permission for folders and files. 

 

Can I get some guidance on this.

 

AEM version - 6.5.19

10 Replies

Avatar

Level 3

Which tool or method are you using to apply permissions?

Avatar

Level 2

Hi,

 

we are using ACS AEM Commons method for applying permission. 

Avatar

Level 3

I recommend using netcentric ac tool for the same. You will have to apply read permissions on folder level and for the children, you can give the necessary permissions needed.

https://github.com/Netcentric/accesscontroltool

 

Avatar

Community Advisor

Hi @AnushaAt 

AEM OOTB provides the capability to set permissions on both folders and files.

What seems to be the blocker in this case? The tool or the way use set permissions.



Arun Patidar

Avatar

Level 2

Hi,

 

we usually apply permission to folders, so it will be applicable to files as well.

 

but whether can we provide different permission for folders and different level set of permission for files under folder?

 

we have more than 100 files, if we have to give specific permission for files and folders. we have to give permission for each files right?

 

Regards,

Anusha

  

Avatar

Community Advisor

In JCR, the effective permissions are aggregated, meaning they are a combination of those inherited from the parent and those directly applied to a file, folder, or resource.



Arun Patidar

Avatar

Level 4

Hi @AnushaAt,

 

If i understood correctly, you want to set ACLs in more granular level.

You shall consider AC tool/Yaml file approach.

for more details:

https://shinesolutions.com/2018/10/02/managing-user-permissions-in-aem/

https://taradevko.com/aem/aem-ac-tool-manage-groups-users/

with this you shall create separate groups for different levels of content access.

 

Thanks,

Raju.

Avatar

Community Advisor

Hi, 


You can do this out-of-the-box without any additional tools. Keep in mind that using regex with ACLs can help avoid going through each file individually. Please refer to these threads to learn more about ACLs inheritance and evaluation:

 

https://jackrabbit.apache.org/oak/docs/security/authorization/restriction.html#rep-glob-details-and-... 

https://techrevel.blog/2024/03/04/aem-user-permissions-tips-for-effortless-control/

https://experienceleague.adobe.com/en/docs/experience-manager-65/content/security/security#access-co...

https://danklco.com/posts/2022-12-3-simple-rules-for-success-with-aem-acls/ 

 

Hope this helps



Esteban Bustamante

Avatar

Community Advisor

Hi @AnushaAt 
I believe to address the requirement of setting different permissions for folders and files (sub-pages) in AEM 6.5.19, we need a targeted approach that leverages granular Access Control List (ACL) configurations without compromising performance or maintainability. Here's how you can achieve this:

1. Separate User Groups for Folder and File Permissions

  • Create separate security groups for folder and file access.
    • Folder Group: Users who need access to folders only.
    • File Group: Users who need access to files/sub-pages.
  • Example:
    • folder-editors: Permissions for folders.
    • file-editors: Permissions for files/sub-pages.

2. Apply Folder-Level Permissions

  • Navigate to the folder in AEM.

  • In the Permissions tab of the User Admin console (http://<hostname>:4502/useradmin

    • Select the folder-editors group.
    • Grant permissions (Read, Modify, etc.) at the folder level only.
    • Use restrictions (e.g., rep:glob) to exclude sub-pages/files.

    Example:

    • Restriction: rep:glob = /* (only applies to folder-level content).

3. Apply File-Level Permissions

  • Navigate to a representative file under the folder.

  • For the file-editors group:

    • Grant permissions for all files under the folder.
    • Use rep:glob restrictions to exclude the root folder itself.

    Example:

    • Restriction: rep:glob = /*/* (applies to files only).

4. Use JCR API or ACS Commons Bulk Permission Tool (Optional for Scalability)

If you have many folders and files, manually configuring ACLs may be inefficient. Use programmatic or automated approaches:

  • JCR API Example:
    • Create a service or script to set permissions programmatically using the JCR Session API.
    • // Example for setting folder permissions
      session.getAccessControlManager().setPolicy(
          "/content/my-folder",
          accessControlPolicyForFolder
      );
      // Example for setting file permissions
      session.getAccessControlManager().setPolicy(
          "/content/my-folder/my-file",
          accessControlPolicyForFiles
      );
      
      • ACS Commons Bulk Permissions Tool:
        • Install the ACS Commons package.
        • Use the Bulk Permissions tool to configure folder and file-level ACLs efficiently.

      5. Validate Inheritance and Overrides

      • Ensure that inheritance is disabled for files where permissions differ from the folder.
      • Use the AEM Security Console (http://<hostname>:4502/security) to verify effective permissions.

      6. Test the Permissions

      • Use test accounts to validate that:
        • Folder permissions are applied correctly.
        • File permissions are overridden as expected.

    By leveraging rep:glob restrictions, permissions can be fine-tuned for folders and files independently

    Thanks 
    Please let me know if you face any challenge in this
  • Partyush. 



Avatar

Administrator

@AnushaAt Did you find the suggestions helpful? Please let us know if you require more information. Otherwise, please mark the answer as correct for posterity. If you've discovered a solution yourself, we would appreciate it if you could share it with the community. Thank you!



Kautuk Sahni