001/*
002 *  Copyright 2026 Anyware Services
003 *
004 *  Licensed under the Apache License, Version 2.0 (the "License");
005 *  you may not use this file except in compliance with the License.
006 *  You may obtain a copy of the License at
007 *
008 *      http://www.apache.org/licenses/LICENSE-2.0
009 *
010 *  Unless required by applicable law or agreed to in writing, software
011 *  distributed under the License is distributed on an "AS IS" BASIS,
012 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 *  See the License for the specific language governing permissions and
014 *  limitations under the License.
015 */
016package org.ametys.web.site;
017
018import java.util.Map;
019
020import org.apache.avalon.framework.parameters.Parameters;
021import org.apache.avalon.framework.service.ServiceException;
022import org.apache.avalon.framework.service.ServiceManager;
023import org.apache.cocoon.acting.ServiceableAction;
024import org.apache.cocoon.environment.ObjectModelHelper;
025import org.apache.cocoon.environment.Redirector;
026import org.apache.cocoon.environment.Request;
027import org.apache.cocoon.environment.SourceResolver;
028
029import org.ametys.core.cocoon.ActionResultGenerator;
030import org.ametys.core.user.UserIdentity;
031import org.ametys.plugins.core.authentication.MultifactorAuthenticationManager;
032
033/**
034 * Action sending the multifactor authentication code coming from sites front-office
035 * The code is sent by back-office in order to use the mail template of the skin
036 */
037public class SendMFACodeFromFrontOfficeAction extends ServiceableAction
038{
039    /** The multifactor authentication manager */
040    protected MultifactorAuthenticationManager _multifactorAuthenticationManager;
041    
042    @Override
043    public void service(ServiceManager smanager) throws ServiceException
044    {
045        _multifactorAuthenticationManager = (MultifactorAuthenticationManager) smanager.lookup(MultifactorAuthenticationManager.ROLE);
046    }
047
048    public Map act(Redirector redirector, SourceResolver resolver, Map objectModel, String source, Parameters parameters) throws Exception
049    {
050        Request request = ObjectModelHelper.getRequest(objectModel);
051        String multifactorAuthenticationCode = request.getParameter("code");
052        
053        String login = request.getParameter("login");
054        String populationId = request.getParameter("populationId");
055        
056        _multifactorAuthenticationManager.sendMultifactorAuthenticationCodeByMail(request, new UserIdentity(login, populationId), multifactorAuthenticationCode);
057
058        request.getSession().setAttribute(ActionResultGenerator.MAP_REQUEST_ATTR, Map.of("success", true));
059
060        return EMPTY_MAP;
061    }
062
063}