001/* 002 * Copyright 2025 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.plugins.mobileapp.action; 017 018import java.util.HashMap; 019import java.util.Map; 020 021import org.apache.avalon.framework.parameters.Parameters; 022import org.apache.avalon.framework.service.ServiceException; 023import org.apache.avalon.framework.service.ServiceManager; 024import org.apache.avalon.framework.thread.ThreadSafe; 025import org.apache.cocoon.acting.ServiceableAction; 026import org.apache.cocoon.environment.ObjectModelHelper; 027import org.apache.cocoon.environment.Redirector; 028import org.apache.cocoon.environment.Request; 029import org.apache.cocoon.environment.SourceResolver; 030 031import org.ametys.core.authentication.token.AuthenticationTokenManager; 032import org.ametys.core.cocoon.JSonReader; 033import org.ametys.core.user.CurrentUserProvider; 034 035/** 036 * Returns the token for a user (only to be used by the mobile app on one site) 037 */ 038public class GenerateTokenAction extends ServiceableAction implements ThreadSafe 039{ 040 private AuthenticationTokenManager _authenticationTokenManager; 041 private CurrentUserProvider _currentUserProvider; 042 043 @Override 044 public void service(ServiceManager smanager) throws ServiceException 045 { 046 super.service(smanager); 047 048 _authenticationTokenManager = (AuthenticationTokenManager) smanager.lookup(AuthenticationTokenManager.ROLE); 049 _currentUserProvider = (CurrentUserProvider) smanager.lookup(CurrentUserProvider.ROLE); 050 } 051 052 public Map act(Redirector redirector, SourceResolver resolver, Map objectModel, String source, Parameters parameters) throws Exception 053 { 054 Map<String, Object> result = new HashMap<>(); 055 Request request = ObjectModelHelper.getRequest(objectModel); 056 057 if (_currentUserProvider.getUser() != null) 058 { 059 String generateToken = _authenticationTokenManager.generateToken(0, "mobileapp", "Token for the mobile app"); 060 061 result.put("code", 200); 062 result.put("token", generateToken); 063 } 064 065 request.setAttribute(JSonReader.OBJECT_TO_READ, result); 066 return EMPTY_MAP; 067 } 068}