import { ProvisioningConfigDto } from '@n8n/api-types';
import { Logger } from '@n8n/backend-common';
import { GlobalConfig } from '@n8n/config';
import { RoleRepository, RoleMappingRuleRepository, SettingsRepository, User, UserRepository, ProjectRepository } from '@n8n/db';
import { InstanceSettings } from 'n8n-core';
import { EventService } from '../../events/event.service';
import { Publisher } from '../../scaling/pubsub/publisher.service';
import { ProjectService } from '../../services/project.service.ee';
import { UserService } from '../../services/user.service';
import { RoleMappingRuleService } from './role-mapping-rule.service.ee';
import type { RoleResolverContext } from './role-resolver-types';
import { RoleResolverService } from './role-resolver.service.ee';
export declare class ProvisioningService {
    private readonly eventService;
    private readonly globalConfig;
    private readonly settingsRepository;
    private readonly projectRepository;
    private readonly projectService;
    private readonly roleRepository;
    private readonly userRepository;
    private readonly userService;
    private readonly logger;
    private readonly publisher;
    private readonly instanceSettings;
    private readonly roleMappingRuleRepository;
    private readonly roleResolverService;
    private readonly roleMappingRuleService;
    private provisioningConfig;
    constructor(eventService: EventService, globalConfig: GlobalConfig, settingsRepository: SettingsRepository, projectRepository: ProjectRepository, projectService: ProjectService, roleRepository: RoleRepository, userRepository: UserRepository, userService: UserService, logger: Logger, publisher: Publisher, instanceSettings: InstanceSettings, roleMappingRuleRepository: RoleMappingRuleRepository, roleResolverService: RoleResolverService, roleMappingRuleService: RoleMappingRuleService);
    init(): Promise<void>;
    getConfig(): Promise<ProvisioningConfigDto>;
    provisionInstanceRoleForUser(user: User, roleSlug: unknown): Promise<void>;
    provisionProjectRolesForUser(userId: string, projectIdToRoles: unknown): Promise<void>;
    patchConfig(rawConfig: unknown): Promise<ProvisioningConfigDto>;
    handleReloadSsoProvisioningConfiguration(): Promise<void>;
    loadConfigurationFromDatabase(): Promise<ProvisioningConfigDto | undefined>;
    loadConfig(): Promise<ProvisioningConfigDto>;
    getInstanceRoleClaimName(): Promise<string | null>;
    getProjectsRolesClaimName(): Promise<string | null>;
    isProvisioningEnabled(): Promise<boolean>;
    private isInstanceRoleProvisioningEnabled;
    private isProjectRolesProvisioningEnabled;
    isExpressionMappingEnabled(): Promise<boolean>;
    isInstanceRoleManaged(): Promise<boolean>;
    isProjectRoleManaged(): Promise<boolean>;
    private buildRoleMappingConfig;
    private applyExpressionMappedRoles;
    private getPreviousProjectRoles;
    private applyExpressionMappedInstanceRole;
    private applyExpressionMappedProjectRoles;
    provisionExpressionMappedRolesForUser(user: User, context: RoleResolverContext): Promise<void>;
}
