Skip to content

Commit

Permalink
Rework openldap::server::database interface for the limits parameter
Browse files Browse the repository at this point in the history
Similar to the work on the `syncrepl` parameter, adjust the interface to
use a well-defined Puppet structure to help writing manifests easier to
read.
  • Loading branch information
smortex committed Mar 30, 2024
1 parent c630df5 commit 215e21b
Show file tree
Hide file tree
Showing 4 changed files with 60 additions and 9 deletions.
33 changes: 31 additions & 2 deletions REFERENCE.md
Original file line number Diff line number Diff line change
Expand Up @@ -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::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

## Classes
Expand Down Expand Up @@ -1015,11 +1016,11 @@ Default value: `undef`

##### <a name="-openldap--server--database--limits"></a>`limits`

Data type: `Array[String[1]]`
Data type: `Openldap::Limits`



Default value: `[]`
Default value: `{}`

##### <a name="-openldap--server--database--dboptions"></a>`dboptions`

Expand Down Expand Up @@ -1800,6 +1801,34 @@ Variant[Hash[
], Openldap::Attribute]
```

### <a name="Openldap--Limits"></a>`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']],
},
]]
```

### <a name="Openldap--Tls_moznss_compatibility"></a>`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 existing declaration).
Expand Down
4 changes: 2 additions & 2 deletions manifests/server/database.pp
Original file line number Diff line number Diff line change
Expand Up @@ -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,
Expand Down Expand Up @@ -88,7 +88,7 @@
multiprovider => $multiprovider,
syncusesubentry => $syncusesubentry,
syncrepl => $syncrepl,
limits => $limits,
limits => $limits.map |$selector, $limits| { "${selector} ${limits.map |$k, $v| { "${k}=${v}" }.join(' ')}" },
security => $security,
}
}
10 changes: 5 additions & 5 deletions spec/defines/openldap_server_database_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -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: 100000 },

Check failure on line 41 in spec/defines/openldap_server_database_spec.rb

View workflow job for this annotation

GitHub Actions / Puppet / Static validations

Style/NumericLiterals: Use underscores(_) as thousands separator and separate every 3 digits with them. (https://rubystyle.guide#underscores-in-numerics)
'dn.exact="cn=personnel,dc=example,dc=org"' => { size: 'unlimited' },
'dn.exact="cn=dirsync,dc=example,dc=org"' => { size: 100000 }

Check failure on line 43 in spec/defines/openldap_server_database_spec.rb

View workflow job for this annotation

GitHub Actions / Puppet / Static validations

Style/NumericLiterals: Use underscores(_) as thousands separator and separate every 3 digits with them. (https://rubystyle.guide#underscores-in-numerics)
},
dboptions: {
config: [
'set_cachesize 0 10485760 0',
Expand Down
22 changes: 22 additions & 0 deletions types/limits.pp
Original file line number Diff line number Diff line change
@@ -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']],
},
],
]

0 comments on commit 215e21b

Please sign in to comment.