diff --git a/REFERENCE.md b/REFERENCE.md
index c082212f..bc2f3f03 100644
--- a/REFERENCE.md
+++ b/REFERENCE.md
@@ -51,6 +51,7 @@
* [`Openldap::Access_title`](#Openldap--Access_title): A valid title for an openldap::server::access resource
* [`Openldap::Attribute`](#Openldap--Attribute): An LDAP attribute in the form "key: value"
* [`Openldap::Attributes`](#Openldap--Attributes): A set of LDAP attributes
+* [`Openldap::Limits`](#Openldap--Limits): Limits for clients
* [`Openldap::Syncrepl`](#Openldap--Syncrepl): Parameters for database replication consumers
* [`Openldap::Tls_moznss_compatibility`](#Openldap--Tls_moznss_compatibility): The list of possible values TLS_MOZNSS_COMPATIBILITY can have (based on the man page), and an 'absent' (a puppet directive to remove an exist
@@ -1016,11 +1017,11 @@ Default value: `undef`
##### `limits`
-Data type: `Array[String[1]]`
+Data type: `Openldap::Limits`
-Default value: `[]`
+Default value: `{}`
##### `dboptions`
@@ -1801,6 +1802,34 @@ Variant[Hash[
], Openldap::Attribute]
```
+### `Openldap::Limits`
+
+Limits for clients
+
+* **See also**
+ * https://www.openldap.org/doc/admin26/limits.html
+
+Alias of
+
+```puppet
+Hash[String[1], Struct[
+ {
+ # Specify time limits
+ Optional['time'] => Variant[Integer[0], Enum['unlimited']],
+ Optional['time.soft'] => Variant[Integer[0], Enum['unlimited']],
+ Optional['time.hard'] => Variant[Integer[0], Enum['unlimited']],
+ # Specifying size limits
+ Optional['size'] => Variant[Integer[0], Enum['unlimited']],
+ Optional['size.soft'] => Variant[Integer[0], Enum['unlimited']],
+ Optional['size.hard'] => Variant[Integer[0], Enum['unlimited']],
+ Optional['size.unchecked'] => Variant[Integer[0], Enum['disabled', 'unlimited']],
+ # Size limits and Paged Results
+ Optional['size.pr'] => Variant[Integer[0], Enum['noEstimate', 'unlimited']],
+ Optional['size.prtotal'] => Variant[Integer[0], Enum['disabled', 'unlimited']],
+ },
+ ]]
+```
+
### `Openldap::Syncrepl`
Parameters for database replication consumers
diff --git a/manifests/server/database.pp b/manifests/server/database.pp
index 64c4baf6..7939263d 100644
--- a/manifests/server/database.pp
+++ b/manifests/server/database.pp
@@ -13,7 +13,7 @@
Optional[String[1]] $dbmaxsize = undef,
Optional[String[1]] $timelimit = undef,
Optional[String[1]] $updateref = undef,
- Array[String[1]] $limits = [],
+ Openldap::Limits $limits = {},
# BDB/HDB options
Hash[String[1],Variant[String[1],Array[String[1]]]] $dboptions = {},
Optional[String[1]] $synctype = undef,
@@ -96,7 +96,7 @@
}
}.flatten.join(' ')
},
- limits => $limits,
+ limits => $limits.map |$selector, $limits| { "${selector} ${limits.map |$k, $v| { "${k}=${v}" }.join(' ')}" },
security => $security,
}
}
diff --git a/spec/defines/openldap_server_database_spec.rb b/spec/defines/openldap_server_database_spec.rb
index 2540b567..8e314115 100644
--- a/spec/defines/openldap_server_database_spec.rb
+++ b/spec/defines/openldap_server_database_spec.rb
@@ -37,11 +37,11 @@
dbmaxsize: '10000',
timelimit: '10000',
updateref: 'default_updateref',
- limits: [
- 'dn.exact="cn=anyuser,dc=example,dc=org" size=100000',
- 'dn.exact="cn=personnel,dc=example,dc=org" size=unlimited',
- 'dn.exact="cn=dirsync,dc=example,dc=org" size=100000'
- ],
+ limits: {
+ 'dn.exact="cn=anyuser,dc=example,dc=org"' => { size: 100_000 },
+ 'dn.exact="cn=personnel,dc=example,dc=org"' => { size: 'unlimited' },
+ 'dn.exact="cn=dirsync,dc=example,dc=org"' => { size: 100_000 }
+ },
dboptions: {
config: [
'set_cachesize 0 10485760 0',
diff --git a/types/limits.pp b/types/limits.pp
new file mode 100644
index 00000000..6537a343
--- /dev/null
+++ b/types/limits.pp
@@ -0,0 +1,22 @@
+# @summary Limits for clients
+#
+# @see https://www.openldap.org/doc/admin26/limits.html
+type Openldap::Limits = Hash[
+ String[1],
+ Struct[
+ {
+ # Specify time limits
+ Optional['time'] => Variant[Integer[0], Enum['unlimited']],
+ Optional['time.soft'] => Variant[Integer[0], Enum['unlimited']],
+ Optional['time.hard'] => Variant[Integer[0], Enum['unlimited']],
+ # Specifying size limits
+ Optional['size'] => Variant[Integer[0], Enum['unlimited']],
+ Optional['size.soft'] => Variant[Integer[0], Enum['unlimited']],
+ Optional['size.hard'] => Variant[Integer[0], Enum['unlimited']],
+ Optional['size.unchecked'] => Variant[Integer[0], Enum['disabled', 'unlimited']],
+ # Size limits and Paged Results
+ Optional['size.pr'] => Variant[Integer[0], Enum['noEstimate', 'unlimited']],
+ Optional['size.prtotal'] => Variant[Integer[0], Enum['disabled', 'unlimited']],
+ },
+ ],
+]