CampaignRest.java

/*
 * Copyright (c) 2002-2020, City of Paris
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 *  1. Redistributions of source code must retain the above copyright notice
 *     and the following disclaimer.
 *
 *  2. Redistributions in binary form must reproduce the above copyright notice
 *     and the following disclaimer in the documentation and/or other materials
 *     provided with the distribution.
 *
 *  3. Neither the name of 'Mairie de Paris' nor 'Lutece' nor the names of its
 *     contributors may be used to endorse or promote products derived from
 *     this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 *
 * License 1.0
 */
/*
 /*
 * Copyright (c) 2002-2017, Mairie de Paris
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 *  1. Redistributions of source code must retain the above copyright notice
 *     and the following disclaimer.
 *
 *  2. Redistributions in binary form must reproduce the above copyright notice
 *     and the following disclaimer in the documentation and/or other materials
 *     provided with the distribution.
 *
 *  3. Neither the name of 'Mairie de Paris' nor 'Lutece' nor the names of its
 *     contributors may be used to endorse or promote products derived from
 *     this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 *
 * License 1.0
 */
package fr.paris.lutece.plugins.participatorybudget.web.rs;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.PathParam;
import javax.ws.rs.Produces;
import javax.ws.rs.core.Context;
import javax.ws.rs.core.MediaType;

import fr.paris.lutece.plugins.participatorybudget.business.campaign.CampaignHome;
import fr.paris.lutece.plugins.participatorybudget.service.NoSuchPhaseException;
import fr.paris.lutece.plugins.participatorybudget.service.campaign.CampaignService;
import fr.paris.lutece.plugins.rest.service.RestConstants;
import fr.paris.lutece.portal.service.util.AppLogService;

@Path( RestConstants.BASE_PATH + "campaign" )
public class CampaignRest extends AbstractServiceRest
{

    private static final String LOG_UNAUTHENTICATED_REQUEST = "Calling Campaign rest API with unauthenticated request";

    // *********************************************************************************************
    // * CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN *
    // * CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN CAMPAIGN *
    // *********************************************************************************************

    /**
     * Returns the list of campaigns
     * 
     * @return the List of campaigns
     * @throws ServletException
     */
    @GET
    @Path( "campaigns" )
    @Produces( MediaType.APPLICATION_JSON )
    public String getCampaigns( @Context HttpServletRequest request ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignHome.getCampaignsList( ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    // *********************************************************************************************
    // * PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE *
    // * PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE PHASE *
    // *********************************************************************************************

    /**
     * get isBeforeBeginning of a phase of a campaign
     * 
     * @return the response of the request isBeforeBeginning for a phase of a campaign
     * @throws ServletException
     */
    @GET
    @Path( "{campaign}/{phase}/before-beginning" )
    @Produces( MediaType.APPLICATION_JSON )
    public String isBeforeBeginning( @Context HttpServletRequest request, @PathParam( "campaign" ) String campaign, @PathParam( "phase" ) String phase )
            throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).isBeforeBeginning( campaign, phase ),
                    CampaignService.getInstance( ).start( campaign, phase ) + " ==> " + CampaignService.getInstance( ).end( campaign, phase ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get isBeforeBeginning of a phase of last campaign
     * 
     * @return the response of the request isBeforeBeginning for a phase of the last campaign
     * @throws ServletException
     */
    @GET
    @Path( "{phase}/before-beginning" )
    @Produces( MediaType.APPLICATION_JSON )
    public String isBeforeBeginningLastCampaign( @Context HttpServletRequest request, @PathParam( "phase" ) String phase ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).isBeforeBeginning( phase ),
                    CampaignService.getInstance( ).start( phase ) + " ==> " + CampaignService.getInstance( ).end( phase ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get isAfterBeginning of a phase of a campaign
     * 
     * @return the response of the request isAfterBeginning for a phase of a campaign
     * @throws ServletException
     */
    @GET
    @Path( "{campaign}/{phase}/after-beginning" )
    @Produces( MediaType.APPLICATION_JSON )
    public String isAfterBeginning( @Context HttpServletRequest request, @PathParam( "campaign" ) String campaign, @PathParam( "phase" ) String phase )
            throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).isAfterBeginning( campaign, phase ),
                    CampaignService.getInstance( ).start( campaign, phase ) + " ==> " + CampaignService.getInstance( ).end( campaign, phase ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get isAfterBeginning of a phase of last campaign
     * 
     * @return the response of the request isAfterBeginning for a phase of the last campaign
     * @throws ServletException
     */
    @GET
    @Path( "{phase}/after-beginning" )
    @Produces( MediaType.APPLICATION_JSON )
    public String isAfterBeginning( @Context HttpServletRequest request, @PathParam( "phase" ) String phase ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).isAfterBeginning( phase ),
                    CampaignService.getInstance( ).start( phase ) + " ==> " + CampaignService.getInstance( ).end( phase ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get isDuring of a phase of a campaign
     * 
     * @return the response of the request isDuring for a phase of a campaign
     * @throws ServletException
     */
    @GET
    @Path( "{campaign}/{phase}/during" )
    @Produces( MediaType.APPLICATION_JSON )
    public String isDuring( @Context HttpServletRequest request, @PathParam( "campaign" ) String campaign, @PathParam( "phase" ) String phase )
            throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).isDuring( campaign, phase ),
                    CampaignService.getInstance( ).start( campaign, phase ) + " ==> " + CampaignService.getInstance( ).end( campaign, phase ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get isDuring of a phase of last campaign
     * 
     * @return the response of the request isDuring for a phase of last campaign
     * @throws ServletException
     */
    @GET
    @Path( "{phase}/during" )
    @Produces( MediaType.APPLICATION_JSON )
    public String isDuring( @Context HttpServletRequest request, @PathParam( "phase" ) String phase ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).isDuring( phase ),
                    CampaignService.getInstance( ).start( phase ) + " ==> " + CampaignService.getInstance( ).end( phase ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get isBeforeEnd of a phase of a campaign
     * 
     * @return the response of the request isBeforeEnd for a phase of a campaign
     * @throws ServletException
     */
    @GET
    @Path( "{campaign}/{phase}/before-end" )
    @Produces( MediaType.APPLICATION_JSON )
    public String isBeforeEnd( @Context HttpServletRequest request, @PathParam( "campaign" ) String campaign, @PathParam( "phase" ) String phase )
            throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).isBeforeEnd( campaign, phase ),
                    CampaignService.getInstance( ).start( campaign, phase ) + " ==> " + CampaignService.getInstance( ).end( campaign, phase ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get isBeforeEnd of a phase of last campaign
     * 
     * @return the response of the request isBeforeEnd for a phase of the last campaign
     * @throws ServletException
     */
    @GET
    @Path( "{phase}/before-end" )
    @Produces( MediaType.APPLICATION_JSON )
    public String isBeforeEnd( @Context HttpServletRequest request, @PathParam( "phase" ) String phase ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).isBeforeEnd( phase ),
                    CampaignService.getInstance( ).start( phase ) + " ==> " + CampaignService.getInstance( ).end( phase ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get isAfterEnd of a phase of a campaign
     * 
     * @return the response of the request isAfterEnd for a phase of a campaign
     * @throws ServletException
     */
    @GET
    @Path( "{campaign}/{phase}/after-end" )
    @Produces( MediaType.APPLICATION_JSON )
    public String isAfterEnd( @Context HttpServletRequest request, @PathParam( "campaign" ) String campaign, @PathParam( "phase" ) String phase )
            throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).isAfterEnd( campaign, phase ),
                    CampaignService.getInstance( ).start( campaign, phase ) + " ==> " + CampaignService.getInstance( ).end( campaign, phase ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get isAfterEnd of a phase of last campaign
     * 
     * @return the response of the request isAfterEnd for a phase of the last campaign
     * @throws ServletException
     */
    @GET
    @Path( "{phase}/after-end" )
    @Produces( MediaType.APPLICATION_JSON )
    public String isAfterEnd( @Context HttpServletRequest request, @PathParam( "phase" ) String phase ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).isAfterEnd( phase ),
                    CampaignService.getInstance( ).start( phase ) + " ==> " + CampaignService.getInstance( ).end( phase ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    // *********************************************************************************************
    // * AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA *
    // * AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA AREA *
    // *********************************************************************************************

    /**
     * get all areas of a campaign
     *
     * @return the response of the request getAllAreas for a campaign
     * @throws ServletException
     */
    @GET
    @Path( "{campaign}/all-areas" )
    @Produces( MediaType.APPLICATION_JSON )
    public String getCampaignAllAreas( @Context HttpServletRequest request, @PathParam( "campaign" ) String campaign ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).getAllAreas( campaign ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get localized areas of last campaign
     *
     * @return the response of the request getAllAreas for the last campaign
     * @throws ServletException
     */
    @GET
    @Path( "all-areas" )
    @Produces( MediaType.APPLICATION_JSON )
    public String getLastCampaignAllAreas( @Context HttpServletRequest request ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).getAllAreas( ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get localized areas of a campaign
     *
     * @return the response of the request getLocalizedAreas for a campaign
     * @throws ServletException
     */
    @GET
    @Path( "{campaign}/localized-areas" )
    @Produces( MediaType.APPLICATION_JSON )
    public String getCampaignLocalizedAreas( @Context HttpServletRequest request, @PathParam( "campaign" ) String campaign ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).getLocalizedAreas( campaign ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get localized areas of last campaign
     *
     * @return the response of the request getLocalizedAreas for the last campaign
     * @throws ServletException
     */
    @GET
    @Path( "localized-areas" )
    @Produces( MediaType.APPLICATION_JSON )
    public String getLastCampaignLocalizedAreas( @Context HttpServletRequest request ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).getLocalizedAreas( ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get area whole of a campaign
     *
     * @return the response of the request getAreas for a campaign
     * @throws ServletException
     */
    @GET
    @Path( "{campaign}/whole-area" )
    @Produces( MediaType.APPLICATION_JSON )
    public String getCampaignWholeArea( @Context HttpServletRequest request, @PathParam( "campaign" ) String campaign ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).getWholeArea( campaign ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get areas of last campaign
     *
     * @return the response of the request getAreas for the last campaign
     * @throws ServletException
     */
    @GET
    @Path( "whole-area" )
    @Produces( MediaType.APPLICATION_JSON )
    public String getLastCampaignWholeArea( @Context HttpServletRequest request ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            String result = CampaignService.getInstance( ).getWholeArea( );
            if ( result.equals( "" ) )
            {
                return formatJson( "KO", result );
            }
            return formatJson( "OK", result );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    // *********************************************************************************************
    // * THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME *
    // * THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME THEME *
    // *********************************************************************************************

    /**
     * get themes of a campaign
     *
     * @return the response of the request getThemes for a campaign
     * @throws ServletException
     */
    @GET
    @Path( "{campaign}/themes" )
    @Produces( MediaType.APPLICATION_JSON )
    public String getCampaignThemes( @Context HttpServletRequest request, @PathParam( "campaign" ) String campaign ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).getThemes( campaign ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get themes of last campaign
     *
     * @return the response of the request getThemes for the last campaign
     * @throws ServletException
     */
    @GET
    @Path( "themes" )
    @Produces( MediaType.APPLICATION_JSON )
    public String getCampaignThemes( @Context HttpServletRequest request ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).getThemes( ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

    /**
     * get themes front rgb of a campaign
     *
     * @return the response of the request getThemes for a campaign
     * @throws ServletException
     */
    @GET
    @Path( "{campaign}/themes-front-rgb" )
    @Produces( MediaType.APPLICATION_JSON )
    public String getCampaignThemesFrontRgb( @Context HttpServletRequest request, @PathParam( "campaign" ) String campaign ) throws ServletException
    {
        if ( !isRequestAuthenticated( request ) )
        {
            AppLogService.error( LOG_UNAUTHENTICATED_REQUEST );
            throw new ServletException( LOG_UNAUTHENTICATED_REQUEST );
        }
        try
        {
            return formatJson( "OK", CampaignService.getInstance( ).getThemesFrontRgb( campaign ) );
        }
        catch( NoSuchPhaseException e )
        {
            AppLogService.error( e );
            return formatJson( "KO", false );
        }
    }

}