Aiven-Open/karapace

Karapace Schema Registry: separate permissions for WriteCompatibility operation for subjects

hollowowl opened this issue · 0 comments

What is currently missing?

In Karapace Schema Schema Registry permissions can be configured only for schema_registry_read and schema_registry_write operations on subject level. Problem there that user with schema_registry_write permissions can also edit related subjects' compatibility settings, meaning in order to allow one to add a new schema version to the subject we're always forced to permit this user to change compatibility settings (and omit global settings) for the given subject, which can be considered as security issue.

How could this be improved?

One option is to make it the same way like in Confluent Schema Registry - there Write and WriteCompatibility are separate operations, so user can have permissions to update subject but not its compatibility settings.

In terms of Karapace it could be that new operation is added (let's name it schema_registry_manage), so operation permissions will affect resources in the given way:

Operation Config: Subject:subject_name
schema_registry_read Read global compatibility settings Read subject compatibility settings and schemas
schema_registry_write Read and write global compatibility settings Read subject compatibility settings and read and write schemas
schema_registry_manage Read and write global compatibility settings (same as schema_registry_write) Read and write subject compatibility settings and schemas

Is this a feature you would work on yourself?

  • I plan to open a pull request for this feature