Document Management
This example models a simplified version of Google Docs style permission system where users can be granted direct access to a document, or access via organizations and nested groups.
Schema | Open in playground
Breakdown of the Model
User
Represents a user who can be granted permission to access a documents directly, or through their membership in a group or organization.
Document
Represents a document that users can be granted permission to access. The document entity has two relationships:
Relations
org: Represents organization that document belongs to.
manager: A relationship between users who are authorized to manage the document. This relationship is defined by the @user
annotation on both ends, and by the @group#member
and @group#manager
annotations on the ends corresponding to the group member and manager relations.
viewer: A relationship between users who are authorized to view the document. This relationship is defined by the @user
annotation on one end and the @group#member
and @group#manager
annotations on the other end corresponding to the group entity member and manager relations.
The document entity has two actions defined:
Actions
manage:: An action that can be performed by users who are authorized to manage the document, as determined by the manager relationship.
view: An action that can be performed by users who are authorized to view the document, as determined by the viewer and manager relationships.
Group
Represents a group of users who can be granted permission to access a document. The group entity has two relationships:
Relations
manager: A relationship between users who are authorized to manage the group. This relationship is defined by the @user
annotation on both ends, and by the @group#member
and @group#manager
annotations on the ends corresponding to the group entity member and manager.
direct_member: A relationship between users who are members of the group. This relationship is defined by the @user
annotation on one end and the @group#member
and @group#manager
annotations on the other end corresponding to the group entity member and manager.
The group entity has one action defined:
Organization
Represents an organization that can contain groups, users, and documents. The organization entity has several relationships:
Relations
group: A relationship between the organization and its groups. This relationship is defined by the @group
annotation on the end corresponding to the group entity.
document: A relationship between the organization and its document. This relationship is defined by the @document
annotation on the end corresponding to the group entity.
administrator: A relationship between users who are authorized to manage the organization. This relationship is defined by the @user
annotation on both ends, and by the @group#member
and @group#manager
annotations on the ends corresponding to the group entity member and manager.
direct_member: A relationship between users who are directly members of the organization. This relationship is defined by the @user
annotation on the end corresponding to the user entity.
The organization entity has two permissions defined:
Permissions
admin: An permission that can be performed by users who are authorized to manage the organization, as determined by the administrator relationship.
member: An permission that can be performed by users who are directly members of the organization, or who have administrator relationship, or who are members of groups that are part of the organization.
Relationships
Based on our schema, let’s create some sample relationships to test both our schema and our authorization logic.
Test & Validation
Finally, let’s check some permissions and test our authorization logic.
Let’s test these access checks in our local with using permify validator. We’ll use the below schema for the schema validation file.
Using Schema Validator in Local
After cloning Permify, open up a new file and copy the schema yaml file content inside. Then, build and run Permify instance using the command make serve
.
Then run permify validate {path of your schema validation file}
to start the test process.
The validation result according to our example schema validation file:
Need any help ?
This is the end of modeling Google Docs style permission system. To install and implement this see the Set Up Permify section.
If you need any kind of help, our team is happy to help you get started with Permify. If you’d like to learn more about using Permify in your app or have any questions about it, schedule a call with one of our Permify engineer.