mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-08-14 17:58:59 +00:00
127562 jkaabimofrad: Merged API-STRIKES-BACK (5.2.0) to HEAD (5.2) 125748 jkaabimofrad: RA-933, RA-934, RA-972: Modified the logout and validate ticket API to support only "-me-" (dummy parameter) in the URL path rather than ticket id. Also, renamed the JSON attributes. git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/BRANCHES/DEV/5.2.N/root@127656 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
89 lines
3.3 KiB
Java
89 lines
3.3 KiB
Java
/*
|
|
* Copyright (C) 2005-2016 Alfresco Software Limited.
|
|
*
|
|
* This file is part of Alfresco
|
|
*
|
|
* Alfresco 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, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* Alfresco 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 Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
package org.alfresco.rest.api.authentications;
|
|
|
|
import org.alfresco.rest.api.Authentications;
|
|
import org.alfresco.rest.api.model.LoginTicket;
|
|
import org.alfresco.rest.framework.WebApiDescription;
|
|
import org.alfresco.rest.framework.WebApiNoAuth;
|
|
import org.alfresco.rest.framework.core.exceptions.InvalidArgumentException;
|
|
import org.alfresco.rest.framework.resource.EntityResource;
|
|
import org.alfresco.rest.framework.resource.actions.interfaces.EntityResourceAction;
|
|
import org.alfresco.rest.framework.resource.parameters.Parameters;
|
|
import org.alfresco.rest.framework.webscripts.WithResponse;
|
|
import org.alfresco.util.PropertyCheck;
|
|
import org.springframework.beans.factory.InitializingBean;
|
|
|
|
import java.util.Collections;
|
|
import java.util.List;
|
|
|
|
/**
|
|
* @author Jamal Kaabi-Mofrad
|
|
*/
|
|
@EntityResource(name = "tickets", title = "Authentication tickets")
|
|
public class AuthenticationTicketsEntityResource implements EntityResourceAction.Create<LoginTicket>,
|
|
EntityResourceAction.ReadByIdWithResponse<LoginTicket>,
|
|
EntityResourceAction.DeleteWithResponse,
|
|
InitializingBean
|
|
{
|
|
// tickets => @EntityResource(name = "tickets" ...
|
|
public static final String COLLECTION_RESOURCE_NAME = "tickets";
|
|
|
|
private Authentications authentications;
|
|
|
|
public void setAuthentications(Authentications authentications)
|
|
{
|
|
this.authentications = authentications;
|
|
}
|
|
|
|
@Override
|
|
public void afterPropertiesSet() throws Exception
|
|
{
|
|
PropertyCheck.mandatory(this, "authentications", authentications);
|
|
}
|
|
|
|
@WebApiDescription(title = "Login", description = "Login.")
|
|
@WebApiNoAuth
|
|
@Override
|
|
public List<LoginTicket> create(List<LoginTicket> entity, Parameters parameters)
|
|
{
|
|
if (entity == null || entity.size() != 1)
|
|
{
|
|
throw new InvalidArgumentException("Please specify one login request only.");
|
|
}
|
|
LoginTicket result = authentications.createTicket(entity.get(0), parameters);
|
|
return Collections.singletonList(result);
|
|
}
|
|
|
|
@WebApiDescription(title = "Validate login ticket", description = "Validate login ticket.")
|
|
@Override
|
|
public LoginTicket readById(String me, Parameters parameters, WithResponse withResponse)
|
|
{
|
|
return authentications.validateTicket(me, parameters, withResponse);
|
|
}
|
|
|
|
@WebApiDescription(title = "Logout", description = "Logout.")
|
|
@Override
|
|
public void delete(String me, Parameters parameters, WithResponse withResponse)
|
|
{
|
|
authentications.deleteTicket(me, parameters, withResponse);
|
|
}
|
|
}
|