Skip to content

Commit

Permalink
Merge branch 'main' into SPSH-856
Browse files Browse the repository at this point in the history
  • Loading branch information
AlexanderUngefug committed Sep 9, 2024
2 parents 823df17 + 4bf3c8c commit 8475b11
Show file tree
Hide file tree
Showing 48 changed files with 861 additions and 783 deletions.
10 changes: 10 additions & 0 deletions migrations/.snapshot-dbildungs-iam-server.json
Original file line number Diff line number Diff line change
Expand Up @@ -2418,6 +2418,16 @@
"nullable": false,
"default": "'1'",
"mappedType": "string"
},
"befristung": {
"name": "befristung",
"type": "timestamptz",
"unsigned": false,
"autoincrement": false,
"primary": false,
"nullable": true,
"length": 6,
"mappedType": "datetime"
}
},
"name": "personenkontext",
Expand Down
11 changes: 11 additions & 0 deletions migrations/Migration20240829100726.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import { Migration } from '@mikro-orm/migrations';

export class Migration20240829100726 extends Migration {
public up(): void {
this.addSql('alter table "personenkontext" add column "befristung" timestamptz null;');
}

public override down(): void {
this.addSql('alter table "personenkontext" drop column "befristung";');
}
}
12 changes: 12 additions & 0 deletions seeding/dev/01/03_service-provider.json
Original file line number Diff line number Diff line change
Expand Up @@ -143,6 +143,18 @@
"providedOnSchulstrukturknoten": 0,
"keycloakGroup": "Psychosoziales Beratungsangebot-service",
"keycloakRole": "Psychosoziales Beratungsangebot-user"
},
{
"id": 12,
"name": "LeOniE.SH",
"target": "URL",
"url": "https://www.leonie-sh.de/",
"kategorie": "HINWEISE",
"logoMimeType": "image/png",
"logoBase64": "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",
"providedOnSchulstrukturknoten": 0,
"keycloakGroup": "LeOniE-service",
"keycloakRole": "LeOniE-user"
}
]
}
9 changes: 6 additions & 3 deletions seeding/dev/01/04_rolle.json
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,8 @@
8,
9,
10,
11
11,
12
]
},
{
Expand Down Expand Up @@ -61,7 +62,8 @@
8,
9,
10,
11
11,
12
]
},
{
Expand All @@ -85,7 +87,8 @@
8,
9,
10,
11
11,
12
]
},
{
Expand Down
30 changes: 27 additions & 3 deletions src/core/ldap/domain/ldap-client.service.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ import { createMock, DeepMocked } from '@golevelup/ts-jest';
import { LdapClient } from './ldap-client.js';
import { Client, Entry, SearchResult } from 'ldapts';
import { KennungRequiredForSchuleError } from '../../../modules/organisation/specification/error/kennung-required-for-schule.error.js';
import { PersonID } from '../../../shared/types/aggregate-ids.types.js';

describe('LDAP Client Service', () => {
let app: INestApplication;
Expand Down Expand Up @@ -199,6 +200,29 @@ describe('LDAP Client Service', () => {
expect(result.ok).toBeTruthy();
});

it('when called with extra entryUUID should return truthy result', async () => {
ldapClientMock.getClient.mockImplementation(() => {
clientMock.bind.mockResolvedValue();
clientMock.add.mockResolvedValueOnce();
clientMock.search.mockResolvedValueOnce(
createMock<SearchResult>({ searchEntries: [createMock<Entry>()] }),
); //mock existsSchule
clientMock.search.mockResolvedValueOnce(createMock<SearchResult>()); //mock existsLehrer

return clientMock;
});
const testLehrer: PersonData = {
id: faker.string.uuid(),
vorname: faker.person.firstName(),
familienname: faker.person.lastName(),
referrer: faker.lorem.word(),
ldapEntryUUID: faker.string.uuid(),
};
const result: Result<PersonData> = await ldapClientService.createLehrer(testLehrer, organisation);

expect(result.ok).toBeTruthy();
});

it('when called with valid person and an organisation without kennung should return error result', async () => {
ldapClientMock.getClient.mockImplementation(() => {
clientMock.bind.mockResolvedValue();
Expand Down Expand Up @@ -337,7 +361,7 @@ describe('LDAP Client Service', () => {
return clientMock;
});

const result: Result<PersonData> = await ldapClientService.deleteLehrerByPersonId(person);
const result: Result<PersonID> = await ldapClientService.deleteLehrerByPersonId(person.id);

expect(result.ok).toBeTruthy();
});
Expand All @@ -354,7 +378,7 @@ describe('LDAP Client Service', () => {
return clientMock;
});

const result: Result<PersonData> = await ldapClientService.deleteLehrerByPersonId(person);
const result: Result<PersonID> = await ldapClientService.deleteLehrerByPersonId(person.id);

expect(result.ok).toBeFalsy();
});
Expand All @@ -365,7 +389,7 @@ describe('LDAP Client Service', () => {
clientMock.add.mockResolvedValueOnce();
return clientMock;
});
const result: Result<PersonData> = await ldapClientService.deleteLehrerByPersonId(person);
const result: Result<PersonID> = await ldapClientService.deleteLehrerByPersonId(person.id);

expect(result.ok).toBeFalsy();
});
Expand Down
22 changes: 16 additions & 6 deletions src/core/ldap/domain/ldap-client.service.ts
Original file line number Diff line number Diff line change
@@ -1,19 +1,21 @@
import { Injectable } from '@nestjs/common';
import { ClassLogger } from '../../logging/class-logger.js';
import { Client, SearchResult } from 'ldapts';
import { Client, Control, SearchResult } from 'ldapts';
import { LdapEntityType, LdapOrganisationEntry, LdapPersonEntry, LdapRoleEntry } from './ldap.types.js';
import { KennungRequiredForSchuleError } from '../../../modules/organisation/specification/error/kennung-required-for-schule.error.js';
import { LdapClient } from './ldap-client.js';
import { LdapInstanceConfig } from '../ldap-instance-config.js';
import { UsernameRequiredError } from '../../../modules/person/domain/username-required.error.js';
import { Mutex } from 'async-mutex';
import { LdapSearchError } from '../error/ldap-search.error.js';
import { PersonID } from '../../../shared/types/aggregate-ids.types.js';

export type PersonData = {
vorname: string;
familienname: string;
id: string;
referrer?: string;
ldapEntryUUID?: string;
};

type OrganisationData = {
Expand Down Expand Up @@ -153,7 +155,15 @@ export class LdapClientService {
mail: [`${person.referrer}@schule-sh.de`],
objectclass: ['inetOrgPerson'],
};
await client.add(lehrerUid, entry);

const controls: Control[] = [];
if (person.ldapEntryUUID) {
const relaxRulesControlOID: string = '1.3.6.1.4.1.4203.666.5.12';
entry.entryUUID = person.ldapEntryUUID;
controls.push(new Control(relaxRulesControlOID));
}

await client.add(lehrerUid, entry, controls);
this.logger.info(`LDAP: Successfully created lehrer ${lehrerUid}`);

return { ok: true, value: person };
Expand All @@ -164,7 +174,7 @@ export class LdapClientService {
return `uid=${referrer},cn=lehrer,ou=${orgaKennung},ou=oeffentlicheSchulen,dc=schule-sh,dc=de`;
}

public async deleteLehrerByPersonId(person: PersonData): Promise<Result<PersonData>> {
public async deleteLehrerByPersonId(personId: PersonID): Promise<Result<PersonID>> {
return this.mutex.runExclusive(async () => {
this.logger.info('LDAP: deleteLehrer');
const client: Client = this.ldapClient.getClient();
Expand All @@ -173,7 +183,7 @@ export class LdapClientService {

const searchResultLehrer: SearchResult = await client.search(`ou=oeffentlicheSchulen,dc=schule-sh,dc=de`, {
scope: 'sub',
filter: `(employeeNumber=${person.id})`,
filter: `(employeeNumber=${personId})`,
});
if (!searchResultLehrer.searchEntries[0]) {
return {
Expand All @@ -182,9 +192,9 @@ export class LdapClientService {
};
}
await client.del(searchResultLehrer.searchEntries[0].dn);
this.logger.info(`LDAP: Successfully deleted lehrer by personId:${person.id}`);
this.logger.info(`LDAP: Successfully deleted lehrer by personId:${personId}`);

return { ok: true, value: person };
return { ok: true, value: personId };
});
}

Expand Down
Loading

0 comments on commit 8475b11

Please sign in to comment.