2024-12-10 19:26:33 +00:00
|
|
|
import ./make-test-python.nix (
|
|
|
|
{ pkgs, ... }:
|
|
|
|
let
|
|
|
|
dbContents = ''
|
|
|
|
dn: dc=example
|
|
|
|
objectClass: domain
|
|
|
|
dc: example
|
2018-03-03 18:53:16 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
dn: ou=users,dc=example
|
|
|
|
objectClass: organizationalUnit
|
|
|
|
ou: users
|
|
|
|
'';
|
2022-06-05 12:47:24 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
ldifConfig = ''
|
|
|
|
dn: cn=config
|
|
|
|
cn: config
|
|
|
|
objectClass: olcGlobal
|
|
|
|
olcLogLevel: stats
|
2022-06-05 12:47:24 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
dn: cn=schema,cn=config
|
|
|
|
cn: schema
|
|
|
|
objectClass: olcSchemaConfig
|
2022-06-05 12:47:24 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
include: file://${pkgs.openldap}/etc/schema/core.ldif
|
|
|
|
include: file://${pkgs.openldap}/etc/schema/cosine.ldif
|
|
|
|
include: file://${pkgs.openldap}/etc/schema/inetorgperson.ldif
|
2022-06-05 12:47:24 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
dn: olcDatabase={0}config,cn=config
|
|
|
|
olcDatabase: {0}config
|
|
|
|
objectClass: olcDatabaseConfig
|
|
|
|
olcRootDN: cn=root,cn=config
|
|
|
|
olcRootPW: configpassword
|
2022-06-05 12:47:24 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
dn: olcDatabase={1}mdb,cn=config
|
|
|
|
objectClass: olcDatabaseConfig
|
|
|
|
objectClass: olcMdbConfig
|
|
|
|
olcDatabase: {1}mdb
|
|
|
|
olcDbDirectory: /var/db/openldap
|
|
|
|
olcDbIndex: objectClass eq
|
|
|
|
olcSuffix: dc=example
|
|
|
|
olcRootDN: cn=root,dc=example
|
|
|
|
olcRootPW: notapassword
|
|
|
|
'';
|
2022-07-19 12:31:11 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
ldapClientConfig = {
|
|
|
|
enable = true;
|
|
|
|
loginPam = false;
|
|
|
|
nsswitch = false;
|
|
|
|
server = "ldap://";
|
|
|
|
base = "dc=example";
|
|
|
|
};
|
2022-07-19 12:31:11 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
in
|
|
|
|
{
|
|
|
|
name = "openldap";
|
2020-08-02 22:52:37 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
nodes.machine =
|
|
|
|
{ pkgs, ... }:
|
|
|
|
{
|
|
|
|
environment.etc."openldap/root_password".text = "notapassword";
|
2022-07-19 12:31:11 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
users.ldap = ldapClientConfig;
|
2022-07-19 12:31:11 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
services.openldap = {
|
|
|
|
enable = true;
|
|
|
|
urlList = [
|
|
|
|
"ldapi:///"
|
|
|
|
"ldap://"
|
2022-06-05 12:47:24 +00:00
|
|
|
];
|
2024-12-10 19:26:33 +00:00
|
|
|
settings = {
|
|
|
|
children = {
|
|
|
|
"cn=schema".includes = [
|
|
|
|
"${pkgs.openldap}/etc/schema/core.ldif"
|
|
|
|
"${pkgs.openldap}/etc/schema/cosine.ldif"
|
|
|
|
"${pkgs.openldap}/etc/schema/inetorgperson.ldif"
|
|
|
|
"${pkgs.openldap}/etc/schema/nis.ldif"
|
|
|
|
];
|
|
|
|
"olcDatabase={0}config" = {
|
|
|
|
attrs = {
|
|
|
|
objectClass = [ "olcDatabaseConfig" ];
|
|
|
|
olcDatabase = "{0}config";
|
|
|
|
olcRootDN = "cn=root,cn=config";
|
|
|
|
olcRootPW = "configpassword";
|
|
|
|
};
|
2022-06-05 12:47:24 +00:00
|
|
|
};
|
2024-12-10 19:26:33 +00:00
|
|
|
"olcDatabase={1}mdb" = {
|
|
|
|
# This tests string, base64 and path values, as well as lists of string values
|
|
|
|
attrs = {
|
|
|
|
objectClass = [
|
|
|
|
"olcDatabaseConfig"
|
|
|
|
"olcMdbConfig"
|
|
|
|
];
|
|
|
|
olcDatabase = "{1}mdb";
|
|
|
|
olcDbDirectory = "/var/lib/openldap/db";
|
|
|
|
olcSuffix = "dc=example";
|
|
|
|
olcRootDN = {
|
|
|
|
# cn=root,dc=example
|
|
|
|
base64 = "Y249cm9vdCxkYz1leGFtcGxl";
|
|
|
|
};
|
|
|
|
olcRootPW = {
|
|
|
|
path = "/etc/openldap/root_password";
|
|
|
|
};
|
|
|
|
};
|
2020-08-02 22:52:37 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
specialisation = {
|
|
|
|
declarativeContents.configuration =
|
|
|
|
{ ... }:
|
|
|
|
{
|
|
|
|
services.openldap.declarativeContents."dc=example" = dbContents;
|
|
|
|
};
|
|
|
|
mutableConfig.configuration =
|
|
|
|
{ ... }:
|
|
|
|
{
|
|
|
|
services.openldap = {
|
|
|
|
declarativeContents."dc=example" = dbContents;
|
|
|
|
mutableConfig = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
manualConfigDir = {
|
|
|
|
inheritParentConfig = false;
|
|
|
|
configuration =
|
|
|
|
{ ... }:
|
|
|
|
{
|
|
|
|
users.ldap = ldapClientConfig;
|
|
|
|
services.openldap = {
|
|
|
|
enable = true;
|
|
|
|
configDir = "/var/db/slapd.d";
|
|
|
|
};
|
|
|
|
};
|
2022-06-05 12:47:24 +00:00
|
|
|
};
|
|
|
|
};
|
2020-08-02 22:52:37 +00:00
|
|
|
};
|
2024-12-10 19:26:33 +00:00
|
|
|
testScript =
|
|
|
|
{ nodes, ... }:
|
|
|
|
let
|
|
|
|
specializations = "${nodes.machine.system.build.toplevel}/specialisation";
|
|
|
|
changeRootPw = ''
|
|
|
|
dn: olcDatabase={1}mdb,cn=config
|
|
|
|
changetype: modify
|
|
|
|
replace: olcRootPW
|
|
|
|
olcRootPW: foobar
|
|
|
|
'';
|
|
|
|
in
|
|
|
|
''
|
|
|
|
# Test startup with empty DB
|
|
|
|
machine.wait_for_unit("openldap.service")
|
2022-06-05 19:03:46 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
with subtest("declarative contents"):
|
|
|
|
machine.succeed('${specializations}/declarativeContents/bin/switch-to-configuration test')
|
|
|
|
machine.wait_for_unit("openldap.service")
|
|
|
|
machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w notapassword')
|
|
|
|
machine.fail('ldapmodify -D cn=root,cn=config -w configpassword -f ${pkgs.writeText "rootpw.ldif" changeRootPw}')
|
2022-06-05 17:07:51 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
with subtest("mutable config"):
|
|
|
|
machine.succeed('${specializations}/mutableConfig/bin/switch-to-configuration test')
|
|
|
|
machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w notapassword')
|
|
|
|
machine.succeed('ldapmodify -D cn=root,cn=config -w configpassword -f ${pkgs.writeText "rootpw.ldif" changeRootPw}')
|
|
|
|
machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w foobar')
|
2020-08-02 22:52:37 +00:00
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
with subtest("manual config dir"):
|
|
|
|
machine.succeed(
|
|
|
|
'mkdir /var/db/slapd.d /var/db/openldap',
|
|
|
|
'slapadd -F /var/db/slapd.d -n0 -l ${pkgs.writeText "config.ldif" ldifConfig}',
|
|
|
|
'slapadd -F /var/db/slapd.d -n1 -l ${pkgs.writeText "contents.ldif" dbContents}',
|
|
|
|
'chown -R openldap:openldap /var/db/slapd.d /var/db/openldap',
|
|
|
|
'${specializations}/manualConfigDir/bin/switch-to-configuration test',
|
|
|
|
)
|
|
|
|
machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w notapassword')
|
|
|
|
machine.succeed('ldapmodify -D cn=root,cn=config -w configpassword -f ${pkgs.writeText "rootpw.ldif" changeRootPw}')
|
|
|
|
machine.succeed('ldapsearch -LLL -D "cn=root,dc=example" -w foobar')
|
|
|
|
'';
|
|
|
|
}
|
|
|
|
)
|