As development teams regularly roll out new features or API endpoints, features each addition often necessitates corresponding updates to the Permify schema.

To streamline this process, we have published an endpoint allows authorized users to make partial updates to the schema by adding or modifying actions within individual entities.

gRPC: https://buf.build/permifyco/permify/docs/main:base.v1#base.v1.Schema.PartialWrite

Endpoint Definition

/v1/{tenant_id}/schemas/partial-write

This endpoint allows authorized users to make partial updates to the schema by adding or modifying actions within individual entities.

Request Payload Structure

PATCH /v1/{tenant_id}/schemas/partial-write
Content-Type: application/json

body:

{
  "metadata": {
    "schema_version": ""
  },
  "entities": {
		"<entity-name>": {
			"write": [],
			"delete": [],
			"update": []
		}
  }
}

Behavior Description

When the schema_version in the request metadata is left empty, the system will default to using the latest(head) schema version as the base for updates.

  • name (string): The name of the entity to be changed.
  • write (string array): Conditions to be added. If a relation or permission/action already exists, it should return an error.
  • delete (string array): Names (permissions/actions) to be deleted. If the relation/permission/action name does not exist, it should return an error. Note: specifying the name is enough as relation/permission/action names should be unique.
  • update (string array): Conditions to be updated.

If schema_version is specified, the endpoint will perform the same update process on the given version and generate a new version thereafter.

Partial Schema Endpoint Example Usage

Existing Schema

entity user {}

entity organization {
    relation admin @user
    relation member @user
}

entity team {
    relation owner @user
    relation org @organization

    permission edit = org.admin or owner
    permission delete = org.admin or owner
}

The code block above outlines the existing schema definitions for the user, organization, and team entities. This includes their respective relationships and permissions within the schema.

Partial Schema Update Request

To update the team entity by introducing new permissions, the following PATCH request with the accompanying payload is sent:

{
  "metadata": {
    "schema_version": ""
  },
  "entities": {
		"team": {
		  "write": [
		    "relation member @user",
		    "permission invite = org.admin and (owner or member)",
		    "permission remove_user = owner"
		  ],
		  "delete": [
		    "edit"
		  ],
		  "update": [
		    "permission delete = member"
		  ]
		}
	}
}

By leaving the schema_version empty string, it signals the system to take the latest(head) schema version as a base for applying updates.

Resulting Schema After Update

After the request is processed, the system outputs a new schema version where the team entity is revised to include the new permissions as illustrated below:

entity user {}

entity organization {
    relation admin @user
    relation member @user
}

entity team {
    relation owner @user
    relation member @user
    relation org @organization

    permission delete = member
    permission invite = org.admin and (owner or member)
    permission remove_user = owner
}

invite and remove_user permissions have been added, a member relation has been included, the edit permission has been deleted, and the delete permission has been updated.