View Javadoc
1   /*
2    * Copyright (c) 2002-2020, 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.plugins.appcenter.modules.fastdeployapplication.service;
35  
36  import com.fasterxml.jackson.core.JsonProcessingException;
37  import com.fasterxml.jackson.databind.ObjectMapper;
38  import fr.paris.lutece.plugins.appcenter.business.User;
39  import fr.paris.lutece.plugins.appcenter.modules.fastdeployapplication.business.FastDeployApplicationData;
40  import fr.paris.lutece.plugins.appcenter.modules.fastdeployapplication.business.FastDeployEnvironment;
41  import fr.paris.lutece.plugins.appcenter.modules.fastdeployapplication.business.ServerApplicationInstance;
42  import fr.paris.lutece.plugins.appcenter.modules.fastdeployapplication.business.context.AbstractWorkflowDeployContext;
43  import java.util.Locale;
44  import fr.paris.lutece.plugins.appcenter.modules.fastdeployapplication.business.fastaction.ActionHistory;
45  import fr.paris.lutece.plugins.appcenter.modules.fastdeployapplication.business.fastaction.ActionHistoryHome;
46  import fr.paris.lutece.plugins.appcenter.modules.fastdeployapplication.business.fastaction.ActionParameter;
47  import fr.paris.lutece.plugins.appcenter.modules.fastdeployapplication.business.fastaction.IAction;
48  import fr.paris.lutece.plugins.appcenter.modules.fastdeployapplication.util.ConstanteUtils;
49  import fr.paris.lutece.portal.service.spring.SpringContextService;
50  import fr.paris.lutece.portal.service.util.AppLogService;
51  import java.sql.Timestamp;
52  import java.util.GregorianCalendar;
53  import java.util.HashMap;
54  import java.util.Map;
55  import java.util.logging.Level;
56  import java.util.logging.Logger;
57  import org.bouncycastle.jcajce.provider.digest.GOST3411;
58  
59  public class ActionHistoryService
60  {
61  
62      public static void saveActionHistory( IAction action, int nIdApplication, String strApplicationType, ServerApplicationInstance serverApplicationInstance,
63              User user, ActionParameter [ ] actionParamterArray, boolean bResult )
64      {
65          ActionHistoryter/modules/fastdeployapplication/business/fastaction/ActionHistory.html#ActionHistory">ActionHistory actionHistory = new ActionHistory( );
66          actionHistory.setIdUserFront( user.getId( ) );
67          actionHistory.setCode( action.getCode( ) );
68          actionHistory.setI18nKeyName( action.getI18nKeyName( ) );
69          actionHistory.setServerType( serverApplicationInstance.getType( ) );
70          actionHistory.setServerCode( serverApplicationInstance.getCode( ) );
71          actionHistory.setServerName( serverApplicationInstance.getName( ) );
72          actionHistory.setIdApplication( nIdApplication );
73  
74          FastDeployEnvironment environment = DeploymentFactory.getInstance( ).getEnvironmentService( strApplicationType )
75                  .getEnvironment( serverApplicationInstance.getCodeEnvironment( ), new Locale( "", "", "" ) );
76  
77          actionHistory.setCodeEnvironment( environment.getEnvType( ) );
78          actionHistory.setActionData( saveActionData( actionParamterArray ) );
79          actionHistory.setCreationDate( new Timestamp( GregorianCalendar.getInstance( ).getTimeInMillis( ) ) );
80          actionHistory.setStatus( bResult );
81  
82          ActionHistoryHome.create( actionHistory );
83      }
84  
85      private static String saveActionData( ActionParameter [ ] actionParamterArray )
86      {
87          String actionData = null;
88  
89          if ( actionParamterArray != null && actionParamterArray.length > 0 )
90          {
91              Map<String, String> actionParameterMap = new HashMap<String, String>( );
92              for ( int i = 0; i < actionParamterArray.length; i++ )
93              {
94                  ActionParameter actionParameter = actionParamterArray [i];
95                  actionParameterMap.put( actionParameter.getName( ), actionParameter.getValue( ) );
96              }
97  
98              try
99              {
100                 actionData = new ObjectMapper( ).writeValueAsString( actionParameterMap );
101             }
102             catch( JsonProcessingException e )
103             {
104                 AppLogService.error( "Unable to convert action parameters to JSON", e );
105             }
106         }
107 
108         return actionData;
109     }
110 }