org.geosdi.geoplatform.experimental.dropwizard.resources.secure.acl.GPSecureACLResource.java Source code

Java tutorial

Introduction

Here is the source code for org.geosdi.geoplatform.experimental.dropwizard.resources.secure.acl.GPSecureACLResource.java

Source

/*
 *  geo-platform
 *  Rich webgis framework
 *  http://geo-platform.org
 * ====================================================================
 *
 * Copyright (C) 2008-2014 geoSDI Group (CNR IMAA - Potenza - ITALY).
 *
 * This program is free software: you can redistribute it and/or modify it 
 * under the terms of the GNU General Public License as published by 
 * the Free Software Foundation, either version 3 of the License, or 
 * (at your option) any later version. 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 General Public License 
 * for more details. You should have received a copy of the GNU General 
 * Public License along with this program. If not, see http://www.gnu.org/licenses/ 
 *
 * ====================================================================
 *
 * Linking this library statically or dynamically with other modules is 
 * making a combined work based on this library. Thus, the terms and 
 * conditions of the GNU General Public License cover the whole combination. 
 * 
 * As a special exception, the copyright holders of this library give you permission 
 * to link this library with independent modules to produce an executable, regardless 
 * of the license terms of these independent modules, and to copy and distribute 
 * the resulting executable under terms of your choice, provided that you also meet, 
 * for each linked independent module, the terms and conditions of the license of 
 * that module. An independent module is a module which is not derived from or 
 * based on this library. If you modify this library, you may extend this exception 
 * to your version of the library, but you are not obligated to do so. If you do not 
 * wish to do so, delete this exception statement from your version. 
 *
 */
package org.geosdi.geoplatform.experimental.dropwizard.resources.secure.acl;

import io.dropwizard.auth.Auth;
import java.security.Principal;
import javax.ws.rs.GET;
import javax.ws.rs.POST;
import javax.ws.rs.PUT;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.QueryParam;
import javax.ws.rs.core.MediaType;
import org.geosdi.geoplatform.request.organization.WSPutRolePermissionRequest;
import org.geosdi.geoplatform.request.organization.WSSaveRoleRequest;
import org.geosdi.geoplatform.response.collection.GuiComponentsPermissionMapData;
import org.geosdi.geoplatform.response.role.WSGetRoleResponse;
import org.geosdi.geoplatform.services.rs.path.GPServiceRSPathConfig;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

/**
 *
 * @author Giuseppe La Scaleia - CNR IMAA geoSDI Group
 * @email giuseppe.lascaleia@geosdi.org
 */
@Path(value = GPServiceRSPathConfig.GP_SECURE_ACL_PATH)
@Produces(MediaType.APPLICATION_JSON)
@Component(value = "secureACLResource")
public class GPSecureACLResource extends BaseACLResource {

    private static final Logger logger = LoggerFactory.getLogger(GPSecureACLResource.class);

    @GET
    @Path(value = GPServiceRSPathConfig.GET_ALL_ROLES_PATH)
    @Override
    public WSGetRoleResponse getAllRoles(@Auth Principal principal,
            @PathParam(value = "organization") String organization) throws Exception {
        logger.debug("\n\n@@@@@@@@@@@@@@@@@Executing secure getAllRoles - " + "Principal : {}\n\n",
                principal.getName());
        return super.getAllRoles(organization);
    }

    @GET
    @Path(value = GPServiceRSPathConfig.GET_ACCOUNT_PERMISSIONS_PATH)
    @Override
    public GuiComponentsPermissionMapData getAccountPermission(@Auth Principal principal,
            @PathParam(value = "accountID") Long accountID) throws Exception {
        logger.debug("\n\n@@@@@@@@@@@@@@@Executing secure getAccountPermission" + " - Principal : {}\n\n",
                principal.getName());
        return super.getAccountPermission(accountID);
    }

    @GET
    @Path(value = GPServiceRSPathConfig.GET_ROLE_PERMISSION_PATH)
    @Override
    public GuiComponentsPermissionMapData getRolePermission(@Auth Principal principal,
            @QueryParam(value = "role") String role, @QueryParam(value = "organization") String organization)
            throws Exception {
        logger.debug("\n\n@@@@@@@@@@@@@@@Executing secure getRolePermission" + " - Principal : {}\n\n",
                principal.getName());
        return super.getRolePermission(role, organization);
    }

    @PUT
    @Path(value = GPServiceRSPathConfig.UPDATE_ROLE_PERMISSION_PATH)
    @Override
    public Boolean updateRolePermission(@Auth Principal principal, WSPutRolePermissionRequest putRolePermissionReq)
            throws Exception {
        logger.debug("\n\n@@@@@@@@@@@@@@@Executing secure updateRolePermission" + " - Principal : {}\n\n",
                principal.getName());
        return super.updateRolePermission(putRolePermissionReq);
    }

    @POST
    @Path(value = GPServiceRSPathConfig.SAVE_ROLE_PATH)
    @Override
    public Boolean saveRole(@Auth Principal principal, WSSaveRoleRequest saveRoleReq) throws Exception {
        logger.debug("\n\n@@@@@@@@@@@@@@@Executing secure saveRole" + " - Principal : {}\n\n", principal.getName());
        return super.saveRole(saveRoleReq);
    }

}