mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-02-25 18:55:28 -06:00
vault: add permissions and administrator privilege
https://fedorahosted.org/freeipa/ticket/5250 Reviewed-By: Petr Vobornik <pvoborni@redhat.com>
This commit is contained in:
committed by
Petr Vobornik
parent
d3503043c4
commit
0dfcf1d9db
22
ACI.txt
22
ACI.txt
@@ -338,6 +338,28 @@ dn: cn=users,cn=accounts,dc=ipa,dc=example
|
|||||||
aci: (targetfilter = "(objectclass=posixaccount)")(version 3.0;acl "permission:System: Remove Users";allow (delete) groupdn = "ldap:///cn=System: Remove Users,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
aci: (targetfilter = "(objectclass=posixaccount)")(version 3.0;acl "permission:System: Remove Users";allow (delete) groupdn = "ldap:///cn=System: Remove Users,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
dn: cn=users,cn=accounts,dc=ipa,dc=example
|
dn: cn=users,cn=accounts,dc=ipa,dc=example
|
||||||
aci: (targetattr = "krblastadminunlock || krbloginfailedcount || nsaccountlock")(targetfilter = "(objectclass=posixaccount)")(version 3.0;acl "permission:System: Unlock User";allow (write) groupdn = "ldap:///cn=System: Unlock User,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
aci: (targetattr = "krblastadminunlock || krbloginfailedcount || nsaccountlock")(targetfilter = "(objectclass=posixaccount)")(version 3.0;acl "permission:System: Unlock User";allow (write) groupdn = "ldap:///cn=System: Unlock User,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
|
dn: dc=ipa,dc=example
|
||||||
|
aci: (target = "ldap:///cn=vaults,cn=kra,dc=ipa,dc=example")(targetfilter = "(objectclass=ipaVault)")(version 3.0;acl "permission:System: Add Vaults";allow (add) groupdn = "ldap:///cn=System: Add Vaults,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
|
dn: dc=ipa,dc=example
|
||||||
|
aci: (target = "ldap:///cn=vaults,cn=kra,dc=ipa,dc=example")(targetfilter = "(objectclass=ipaVault)")(version 3.0;acl "permission:System: Delete Vaults";allow (delete) groupdn = "ldap:///cn=System: Delete Vaults,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
|
dn: dc=ipa,dc=example
|
||||||
|
aci: (targetattr = "member")(target = "ldap:///cn=vaults,cn=kra,dc=ipa,dc=example")(targetfilter = "(objectclass=ipaVault)")(version 3.0;acl "permission:System: Manage Vault Membership";allow (write) groupdn = "ldap:///cn=System: Manage Vault Membership,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
|
dn: dc=ipa,dc=example
|
||||||
|
aci: (targetattr = "owner")(target = "ldap:///cn=vaults,cn=kra,dc=ipa,dc=example")(targetfilter = "(objectclass=ipaVault)")(version 3.0;acl "permission:System: Manage Vault Ownership";allow (write) groupdn = "ldap:///cn=System: Manage Vault Ownership,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
|
dn: dc=ipa,dc=example
|
||||||
|
aci: (targetattr = "cn || description || ipavaultpublickey || ipavaultsalt || ipavaulttype || objectclass")(target = "ldap:///cn=vaults,cn=kra,dc=ipa,dc=example")(targetfilter = "(objectclass=ipaVault)")(version 3.0;acl "permission:System: Modify Vaults";allow (write) groupdn = "ldap:///cn=System: Modify Vaults,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
|
dn: dc=ipa,dc=example
|
||||||
|
aci: (targetattr = "cn || createtimestamp || description || entryusn || ipavaultpublickey || ipavaultsalt || ipavaulttype || member || memberhost || memberuser || modifytimestamp || objectclass || owner")(target = "ldap:///cn=vaults,cn=kra,dc=ipa,dc=example")(targetfilter = "(objectclass=ipaVault)")(version 3.0;acl "permission:System: Read Vaults";allow (compare,read,search) groupdn = "ldap:///cn=System: Read Vaults,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
|
dn: dc=ipa,dc=example
|
||||||
|
aci: (target = "ldap:///cn=vaults,cn=kra,dc=ipa,dc=example")(targetfilter = "(objectclass=ipaVaultContainer)")(version 3.0;acl "permission:System: Add Vault Containers";allow (add) groupdn = "ldap:///cn=System: Add Vault Containers,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
|
dn: dc=ipa,dc=example
|
||||||
|
aci: (target = "ldap:///cn=vaults,cn=kra,dc=ipa,dc=example")(targetfilter = "(objectclass=ipaVaultContainer)")(version 3.0;acl "permission:System: Delete Vault Containers";allow (delete) groupdn = "ldap:///cn=System: Delete Vault Containers,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
|
dn: dc=ipa,dc=example
|
||||||
|
aci: (targetattr = "owner")(target = "ldap:///cn=vaults,cn=kra,dc=ipa,dc=example")(targetfilter = "(objectclass=ipaVaultContainer)")(version 3.0;acl "permission:System: Manage Vault Container Ownership";allow (write) groupdn = "ldap:///cn=System: Manage Vault Container Ownership,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
|
dn: dc=ipa,dc=example
|
||||||
|
aci: (targetattr = "cn || description || objectclass")(target = "ldap:///cn=vaults,cn=kra,dc=ipa,dc=example")(targetfilter = "(objectclass=ipaVaultContainer)")(version 3.0;acl "permission:System: Modify Vault Containers";allow (write) groupdn = "ldap:///cn=System: Modify Vault Containers,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
|
dn: dc=ipa,dc=example
|
||||||
|
aci: (targetattr = "cn || createtimestamp || description || entryusn || modifytimestamp || objectclass || owner")(target = "ldap:///cn=vaults,cn=kra,dc=ipa,dc=example")(targetfilter = "(objectclass=ipaVaultContainer)")(version 3.0;acl "permission:System: Read Vault Containers";allow (compare,read,search) groupdn = "ldap:///cn=System: Read Vault Containers,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
dn: cn=ca_renewal,cn=ipa,cn=etc,dc=ipa,dc=example
|
dn: cn=ca_renewal,cn=ipa,cn=etc,dc=ipa,dc=example
|
||||||
aci: (target = "ldap:///cn=caSigningCert cert-pki-ca,cn=ca_renewal,cn=ipa,cn=etc,dc=ipa,dc=example")(targetfilter = "(objectclass=pkiuser)")(version 3.0;acl "permission:System: Add CA Certificate For Renewal";allow (add) groupdn = "ldap:///cn=System: Add CA Certificate For Renewal,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
aci: (target = "ldap:///cn=caSigningCert cert-pki-ca,cn=ca_renewal,cn=ipa,cn=etc,dc=ipa,dc=example")(targetfilter = "(objectclass=pkiuser)")(version 3.0;acl "permission:System: Add CA Certificate For Renewal";allow (add) groupdn = "ldap:///cn=System: Add CA Certificate For Renewal,cn=permissions,cn=pbac,dc=ipa,dc=example";)
|
||||||
dn: cn=certificates,cn=ipa,cn=etc,dc=ipa,dc=example
|
dn: cn=certificates,cn=ipa,cn=etc,dc=ipa,dc=example
|
||||||
|
|||||||
@@ -260,3 +260,11 @@ default:objectClass: groupofnames
|
|||||||
default:objectClass: top
|
default:objectClass: top
|
||||||
default:cn: CA Administrator
|
default:cn: CA Administrator
|
||||||
default:description: CA Administrator
|
default:description: CA Administrator
|
||||||
|
|
||||||
|
# Vault Administrators
|
||||||
|
dn: cn=Vault Administrators,cn=privileges,cn=pbac,$SUFFIX
|
||||||
|
default:objectClass: nestedgroup
|
||||||
|
default:objectClass: groupofnames
|
||||||
|
default:objectClass: top
|
||||||
|
default:cn: Vault Administrators
|
||||||
|
default:description: Vault Administrators
|
||||||
|
|||||||
@@ -290,6 +290,7 @@ class vaultcontainer(LDAPObject):
|
|||||||
object_name = _('vaultcontainer')
|
object_name = _('vaultcontainer')
|
||||||
object_name_plural = _('vaultcontainers')
|
object_name_plural = _('vaultcontainers')
|
||||||
object_class = ['ipaVaultContainer']
|
object_class = ['ipaVaultContainer']
|
||||||
|
permission_filter_objectclasses = ['ipaVaultContainer']
|
||||||
|
|
||||||
attribute_members = {
|
attribute_members = {
|
||||||
'owner': ['user', 'group', 'service'],
|
'owner': ['user', 'group', 'service'],
|
||||||
@@ -298,6 +299,48 @@ class vaultcontainer(LDAPObject):
|
|||||||
label = _('Vault Containers')
|
label = _('Vault Containers')
|
||||||
label_singular = _('Vault Container')
|
label_singular = _('Vault Container')
|
||||||
|
|
||||||
|
managed_permissions = {
|
||||||
|
'System: Read Vault Containers': {
|
||||||
|
'ipapermlocation': api.env.basedn,
|
||||||
|
'ipapermtarget': DN(api.env.container_vault, api.env.basedn),
|
||||||
|
'ipapermright': {'read', 'search', 'compare'},
|
||||||
|
'ipapermdefaultattr': {
|
||||||
|
'objectclass', 'cn', 'description', 'owner',
|
||||||
|
},
|
||||||
|
'default_privileges': {'Vault Administrators'},
|
||||||
|
},
|
||||||
|
'System: Add Vault Containers': {
|
||||||
|
'ipapermlocation': api.env.basedn,
|
||||||
|
'ipapermtarget': DN(api.env.container_vault, api.env.basedn),
|
||||||
|
'ipapermright': {'add'},
|
||||||
|
'default_privileges': {'Vault Administrators'},
|
||||||
|
},
|
||||||
|
'System: Delete Vault Containers': {
|
||||||
|
'ipapermlocation': api.env.basedn,
|
||||||
|
'ipapermtarget': DN(api.env.container_vault, api.env.basedn),
|
||||||
|
'ipapermright': {'delete'},
|
||||||
|
'default_privileges': {'Vault Administrators'},
|
||||||
|
},
|
||||||
|
'System: Modify Vault Containers': {
|
||||||
|
'ipapermlocation': api.env.basedn,
|
||||||
|
'ipapermtarget': DN(api.env.container_vault, api.env.basedn),
|
||||||
|
'ipapermright': {'write'},
|
||||||
|
'ipapermdefaultattr': {
|
||||||
|
'objectclass', 'cn', 'description',
|
||||||
|
},
|
||||||
|
'default_privileges': {'Vault Administrators'},
|
||||||
|
},
|
||||||
|
'System: Manage Vault Container Ownership': {
|
||||||
|
'ipapermlocation': api.env.basedn,
|
||||||
|
'ipapermtarget': DN(api.env.container_vault, api.env.basedn),
|
||||||
|
'ipapermright': {'write'},
|
||||||
|
'ipapermdefaultattr': {
|
||||||
|
'owner',
|
||||||
|
},
|
||||||
|
'default_privileges': {'Vault Administrators'},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
takes_params = (
|
takes_params = (
|
||||||
Str(
|
Str(
|
||||||
'owner_user?',
|
'owner_user?',
|
||||||
@@ -492,6 +535,7 @@ class vault(LDAPObject):
|
|||||||
object_name_plural = _('vaults')
|
object_name_plural = _('vaults')
|
||||||
|
|
||||||
object_class = ['ipaVault']
|
object_class = ['ipaVault']
|
||||||
|
permission_filter_objectclasses = ['ipaVault']
|
||||||
default_attributes = [
|
default_attributes = [
|
||||||
'cn',
|
'cn',
|
||||||
'description',
|
'description',
|
||||||
@@ -514,6 +558,60 @@ class vault(LDAPObject):
|
|||||||
label = _('Vaults')
|
label = _('Vaults')
|
||||||
label_singular = _('Vault')
|
label_singular = _('Vault')
|
||||||
|
|
||||||
|
managed_permissions = {
|
||||||
|
'System: Read Vaults': {
|
||||||
|
'ipapermlocation': api.env.basedn,
|
||||||
|
'ipapermtarget': DN(api.env.container_vault, api.env.basedn),
|
||||||
|
'ipapermright': {'read', 'search', 'compare'},
|
||||||
|
'ipapermdefaultattr': {
|
||||||
|
'objectclass', 'cn', 'description', 'ipavaulttype',
|
||||||
|
'ipavaultsalt', 'ipavaultpublickey', 'owner', 'member',
|
||||||
|
'memberuser', 'memberhost',
|
||||||
|
},
|
||||||
|
'default_privileges': {'Vault Administrators'},
|
||||||
|
},
|
||||||
|
'System: Add Vaults': {
|
||||||
|
'ipapermlocation': api.env.basedn,
|
||||||
|
'ipapermtarget': DN(api.env.container_vault, api.env.basedn),
|
||||||
|
'ipapermright': {'add'},
|
||||||
|
'default_privileges': {'Vault Administrators'},
|
||||||
|
},
|
||||||
|
'System: Delete Vaults': {
|
||||||
|
'ipapermlocation': api.env.basedn,
|
||||||
|
'ipapermtarget': DN(api.env.container_vault, api.env.basedn),
|
||||||
|
'ipapermright': {'delete'},
|
||||||
|
'default_privileges': {'Vault Administrators'},
|
||||||
|
},
|
||||||
|
'System: Modify Vaults': {
|
||||||
|
'ipapermlocation': api.env.basedn,
|
||||||
|
'ipapermtarget': DN(api.env.container_vault, api.env.basedn),
|
||||||
|
'ipapermright': {'write'},
|
||||||
|
'ipapermdefaultattr': {
|
||||||
|
'objectclass', 'cn', 'description', 'ipavaulttype',
|
||||||
|
'ipavaultsalt', 'ipavaultpublickey',
|
||||||
|
},
|
||||||
|
'default_privileges': {'Vault Administrators'},
|
||||||
|
},
|
||||||
|
'System: Manage Vault Ownership': {
|
||||||
|
'ipapermlocation': api.env.basedn,
|
||||||
|
'ipapermtarget': DN(api.env.container_vault, api.env.basedn),
|
||||||
|
'ipapermright': {'write'},
|
||||||
|
'ipapermdefaultattr': {
|
||||||
|
'owner',
|
||||||
|
},
|
||||||
|
'default_privileges': {'Vault Administrators'},
|
||||||
|
},
|
||||||
|
'System: Manage Vault Membership': {
|
||||||
|
'ipapermlocation': api.env.basedn,
|
||||||
|
'ipapermtarget': DN(api.env.container_vault, api.env.basedn),
|
||||||
|
'ipapermright': {'write'},
|
||||||
|
'ipapermdefaultattr': {
|
||||||
|
'member',
|
||||||
|
},
|
||||||
|
'default_privileges': {'Vault Administrators'},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
takes_params = (
|
takes_params = (
|
||||||
Str(
|
Str(
|
||||||
'cn',
|
'cn',
|
||||||
|
|||||||
Reference in New Issue
Block a user