org.bonitasoft.engine.api.PlatformLoginAPI Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bonita-common Show documentation
Show all versions of bonita-common Show documentation
Bonita Common is the useful layer common to bonita-client and bonita-server
/**
* Copyright (C) 2019 Bonitasoft S.A.
* Bonitasoft, 32 rue Gustave Eiffel - 38000 Grenoble
* This library is free software; you can redistribute it and/or modify it under the terms
* of the GNU Lesser General Public License as published by the Free Software Foundation
* version 2.1 of the License.
* This library 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 Lesser General Public License for more details.
* You should have received a copy of the GNU Lesser General Public License along with this
* program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
* Floor, Boston, MA 02110-1301, USA.
**/
package org.bonitasoft.engine.api;
import org.bonitasoft.engine.platform.InvalidPlatformCredentialsException;
import org.bonitasoft.engine.platform.PlatformLoginException;
import org.bonitasoft.engine.platform.PlatformLogoutException;
import org.bonitasoft.engine.session.PlatformSession;
import org.bonitasoft.engine.session.SessionNotFoundException;
/**
* Manage the login on the platform.
*
* Using this API you can obtain a {@link PlatformSession} that can be used to retreive a PlatformAPIAccessor.
*
* PlatformSession
gives access to platform APIs only:
*
* - {@link PlatformAPI}
* - {@link PlatformCommandAPI}
*
*
* @author Matthieu Chaffotte
* @author Baptiste Mesta
* @author Emmanuel Duchastenier
*/
@NoSessionRequired
public interface PlatformLoginAPI {
/**
* Login with username and password of the platform administrator defined in {@code bonita-platform.properties}
*
* @param userName
* the platform administrator name
* @param password
* the platform administrator password
* @return
* the session created for you, can be used to retrieve platform APIs
* @throws PlatformLoginException
* occurs when an exception is thrown during login the platform
* @throws InvalidPlatformCredentialsException
* occurs when thr username or password is not valid
*/
PlatformSession login(String userName, String password)
throws PlatformLoginException, InvalidPlatformCredentialsException;
/**
* Logout from a platform.
*
* @param session
* the platform session to logout from.
* @throws PlatformLogoutException
* occurs when an exception is thrown during logout the platform
* @throws SessionNotFoundException
* if the session is not found on the server side. This may occurs when the session has expired.
*/
void logout(PlatformSession session) throws PlatformLogoutException, SessionNotFoundException;
}