use of org.platformlayer.ops.filesystem.ManagedFilesystemItem in project platformlayer by platformlayer.
the class LdapDomainController method addChildren.
@Override
protected void addChildren() throws OpsException {
LdapDomain ldapDomain = OpsContext.get().getInstance(LdapDomain.class);
String hostName = ldapDomain.organizationName;
LdapDN ldapBase = LdapServerUtilities.createBaseDN(hostName);
File dataRoot = new File("/var/ldap/data");
File dataDir = new File(dataRoot, hostName);
String ldapBaseOrganization = hostName;
ManagedFilesystemItem directory = ManagedDirectory.build(dataDir, "0700").setGroup("openldap").setOwner("openldap");
addChild(directory);
HdbDatabaseEntry db = buildDatabase(ldapBase, dataDir, hostName);
addChild(db);
OrganizationLdapEntry organization = buildOrganization(ldapBase, ldapBaseOrganization);
organization.setTop(true);
addChild(organization);
String ldapAdminPassword = LdapPasswords.getLdapPasswordEncoded(ldapDomain.adminPassword.plaintext());
OrganizationalRoleLdapEntry organizationalRole = buildOrganizationalRole(ldapBase, LdapAttributes.MANAGER_CN, "LDAP Administrator", ldapAdminPassword);
addChild(organizationalRole);
OrganizationalUnitLdapEntry users = buildOrganizationUnit(ldapBase, LdapAttributes.LDAP_USERS_CONTAINER_OU, "Users");
addChild(users);
OrganizationalUnitLdapEntry groups = buildOrganizationUnit(ldapBase, LdapAttributes.LDAP_GROUPS_CONTAINER_OU, "Groups");
addChild(groups);
}
use of org.platformlayer.ops.filesystem.ManagedFilesystemItem in project platformlayer by platformlayer.
the class PersistIptablesScripts method addChildren.
@Override
protected void addChildren() throws OpsException {
addChild(ManagedDirectory.build(BASE_DIR, "0644"));
addChild(SimpleFile.build(getClass(), new File("/etc/network/if-pre-up.d/iptables-lockdown")).setFileMode("755").setUpdateAction(new FilesystemAction() {
@Override
public void execute(OpsTarget target, ManagedFilesystemItem managedFilesystemItem) throws OpsException {
if (managedFilesystemItem.getNewFileWasCreated()) {
// Set the parameters the ifup sets
CommandEnvironment env = new CommandEnvironment();
env.put("MODE", "start");
env.put("IFACE", "--all");
env.put("ADDRFAM", "meta");
Command runLockdown = Command.build("/etc/network/if-pre-up.d/iptables-lockdown");
runLockdown.setEnvironment(env);
target.executeCommand(runLockdown);
}
}
}));
addChild(SimpleFile.build(getClass(), new File("/etc/network/if-up.d/iptables-ifup")).setFileMode("755"));
}
Aggregations