SearchParameterDAO.java

  1. /*
  2.  * Copyright (c) 2002-2022, City of Paris
  3.  * All rights reserved.
  4.  *
  5.  * Redistribution and use in source and binary forms, with or without
  6.  * modification, are permitted provided that the following conditions
  7.  * are met:
  8.  *
  9.  *  1. Redistributions of source code must retain the above copyright notice
  10.  *     and the following disclaimer.
  11.  *
  12.  *  2. Redistributions in binary form must reproduce the above copyright notice
  13.  *     and the following disclaimer in the documentation and/or other materials
  14.  *     provided with the distribution.
  15.  *
  16.  *  3. Neither the name of 'Mairie de Paris' nor 'Lutece' nor the names of its
  17.  *     contributors may be used to endorse or promote products derived from
  18.  *     this software without specific prior written permission.
  19.  *
  20.  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
  21.  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  22.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  23.  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
  24.  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  25.  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  26.  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  27.  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  28.  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  29.  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  30.  * POSSIBILITY OF SUCH DAMAGE.
  31.  *
  32.  * License 1.0
  33.  */
  34. package fr.paris.lutece.portal.business.search;

  35. import fr.paris.lutece.util.ReferenceItem;
  36. import fr.paris.lutece.util.ReferenceList;
  37. import fr.paris.lutece.util.sql.DAOUtil;

  38. import java.util.HashMap;
  39. import java.util.Map;

  40. /**
  41.  *
  42.  * class SearchParameterDAO Provides data access to search parameters in MySQL database
  43.  *
  44.  */
  45. public class SearchParameterDAO implements ISearchParameterDAO
  46. {
  47.     private static final String SQL_QUERY_SELECT = " SELECT parameter_value FROM core_search_parameter WHERE parameter_key = ? ";
  48.     private static final String SQL_QUERY_UPDATE = " UPDATE core_search_parameter SET parameter_value = ? WHERE parameter_key = ? ";
  49.     private static final String SQL_QUERY_SELECT_ALL = " SELECT parameter_key, parameter_value FROM core_search_parameter ORDER BY parameter_key ";

  50.     /** {@inheritDoc} */
  51.     public ReferenceItem load( String strParameterKey )
  52.     {
  53.         ReferenceItem param = null;
  54.         try ( DAOUtil daoUtil = new DAOUtil( SQL_QUERY_SELECT ) )
  55.         {
  56.             daoUtil.setString( 1, strParameterKey );
  57.             daoUtil.executeQuery( );

  58.             if ( daoUtil.next( ) )
  59.             {
  60.                 param = new ReferenceItem( );
  61.                 param.setCode( strParameterKey );
  62.                 param.setName( daoUtil.getString( 1 ) );
  63.             }

  64.         }

  65.         return param;
  66.     }

  67.     /** {@inheritDoc} */
  68.     public void store( ReferenceItem param )
  69.     {
  70.         try ( DAOUtil daoUtil = new DAOUtil( SQL_QUERY_UPDATE ) )
  71.         {
  72.             daoUtil.setString( 1, param.getName( ) );
  73.             daoUtil.setString( 2, param.getCode( ) );
  74.             daoUtil.executeUpdate( );
  75.         }
  76.     }

  77.     /** {@inheritDoc} */
  78.     public Map<String, String> findAll( )
  79.     {
  80.         Map<String, String> parametersList = new HashMap<>( );

  81.         try ( DAOUtil daoUtil = new DAOUtil( SQL_QUERY_SELECT_ALL ) )
  82.         {
  83.             daoUtil.executeQuery( );

  84.             while ( daoUtil.next( ) )
  85.             {
  86.                 parametersList.put( daoUtil.getString( 1 ), daoUtil.getString( 2 ) );
  87.             }

  88.         }

  89.         return parametersList;
  90.     }

  91.     /** {@inheritDoc} */
  92.     public ReferenceList selectParametersList( )
  93.     {
  94.         ReferenceList parametersList = new ReferenceList( );

  95.         try ( DAOUtil daoUtil = new DAOUtil( SQL_QUERY_SELECT_ALL ) )
  96.         {
  97.             daoUtil.executeQuery( );

  98.             while ( daoUtil.next( ) )
  99.             {
  100.                 parametersList.addItem( daoUtil.getString( 1 ), daoUtil.getString( 2 ) );
  101.             }

  102.         }

  103.         return parametersList;
  104.     }
  105. }