MOON
Server: Apache
System: Linux nserver.cafsindia.com 4.18.0-553.104.1.lve.el8.x86_64 #1 SMP Tue Feb 10 20:07:30 UTC 2026 x86_64
User: cafsindia (1002)
PHP: 8.2.30
Disabled: NONE
Upload Files
File: /home/cafsindia/lead_cafsinfotech_in/core/backend/Security/Saml/AppSamlUserFactory.php
<?php
/**
 * SuiteCRM is a customer relationship management program developed by SalesAgility Ltd.
 * Copyright (C) 2022 SalesAgility Ltd.
 *
 * This program is free software; you can redistribute it and/or modify it under
 * the terms of the GNU Affero General Public License version 3 as published by the
 * Free Software Foundation with the addition of the following permission added
 * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
 * IN WHICH THE COPYRIGHT IS OWNED BY SALESAGILITY, SALESAGILITY DISCLAIMS THE
 * WARRANTY OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
 * details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see http://www.gnu.org/licenses.
 *
 * In accordance with Section 7(b) of the GNU Affero General Public License
 * version 3, these Appropriate Legal Notices must retain the display of the
 * "Supercharged by SuiteCRM" logo. If the display of the logos is not reasonably
 * feasible for technical reasons, the Appropriate Legal Notices must display
 * the words "Supercharged by SuiteCRM".
 */

namespace App\Security\Saml;

use App\Authentication\LegacyHandler\UserHandler;
use App\Logging\Services\AppLoggingTrait;
use Nbgrp\OneloginSamlBundle\Security\User\SamlUserFactoryInterface;
use Psr\Log\LoggerInterface;
use RuntimeException;
use Symfony\Component\Security\Core\User\UserInterface;


class AppSamlUserFactory implements SamlUserFactoryInterface
{
    use AppLoggingTrait;

    /**
     * @var UserHandler
     */
    protected $userHandler;

    /**
     * @var array|null
     */
    protected $samlAutoCreateAttributesMap;

    /**
     * @var LoggerInterface
     */
    protected $authLogger;

    /**
     * @param UserHandler $userHandler
     * @param array|null $samlAutoCreateAttributesMap
     * @param LoggerInterface $authLogger
     */
    public function __construct(
        UserHandler $userHandler,
        ?array $samlAutoCreateAttributesMap,
        LoggerInterface $authLogger
    ) {
        $this->userHandler = $userHandler;
        $this->samlAutoCreateAttributesMap = $samlAutoCreateAttributesMap;
        $this->authLogger = $authLogger;
    }

    /**
     * @inheritDoc
     */
    public function createUser(string $identifier, array $attributes): UserInterface
    {
        $this->log('createUser identifier: ' . $identifier);
        $this->logArray('createUser attributes', $attributes);

        $userInfo = $this->mapAttributes($attributes);


        $legacyUser = $this->userHandler->createExternalAuthUser($identifier, $userInfo);
        if ($legacyUser === null) {
            $this->log('createUser - Not able to create user');
            throw new RuntimeException('Not able to create user');
        }

        return $this->userHandler->mapUser($legacyUser);
    }


    /**
     * @param array $attributes
     * @return array
     */
    protected function mapAttributes(array $attributes): array
    {
        $userInfo = $attributes;
        if (empty($attributes) || empty($this->samlAutoCreateAttributesMap)) {
            return $userInfo;
        }

        $userInfo = [];
        foreach ($this->samlAutoCreateAttributesMap as $attributeKey => $fieldKey) {
            if (isset($attributes[$attributeKey][0])) {
                $userInfo[$fieldKey] = $attributes[$attributeKey][0];
            }
        }

        return $userInfo;
    }

    /**
     * @return LoggerInterface
     */
    public function getLogger(): LoggerInterface
    {
        return $this->authLogger;
    }
}