]> source.dussan.org Git - archiva.git/blob
424c1f5d64d7780c3075c1ee4976b7b0664826f0
[archiva.git] /
1 package org.apache.archiva.rest.services;
2 /*
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  */
20
21 import org.apache.archiva.redback.components.scheduler.CronExpressionValidator;
22 import org.apache.archiva.redback.rest.api.services.RedbackServiceException;
23 import org.apache.archiva.redback.rest.api.services.UtilServices;
24 import org.apache.archiva.rest.api.services.ArchivaRestServiceException;
25 import org.apache.archiva.rest.api.services.CommonServices;
26 import org.apache.commons.io.IOUtils;
27 import org.apache.commons.lang.StringUtils;
28 import org.slf4j.Logger;
29 import org.slf4j.LoggerFactory;
30 import org.springframework.stereotype.Service;
31
32 import javax.annotation.PostConstruct;
33 import javax.inject.Inject;
34 import javax.ws.rs.core.Response;
35 import java.io.ByteArrayInputStream;
36 import java.io.IOException;
37 import java.io.InputStream;
38 import java.util.Map;
39 import java.util.Properties;
40 import java.util.concurrent.ConcurrentHashMap;
41
42 /**
43  * @author Olivier Lamy
44  */
45 @Service( "commonServices#rest" )
46 public class DefaultCommonServices
47     implements CommonServices
48 {
49
50     private static final String RESOURCE_NAME = "org/apache/archiva/i18n/default";
51
52     private Logger log = LoggerFactory.getLogger( getClass() );
53
54     @Inject
55     private UtilServices utilServices;
56
57     private Map<String, String> cachei18n = new ConcurrentHashMap<String, String>();
58
59     @Inject
60     protected CronExpressionValidator cronExpressionValidator;
61
62     @PostConstruct
63     public void init()
64         throws ArchivaRestServiceException
65     {
66
67         // preload i18n en and fr
68         getAllI18nResources( "en" );
69         getAllI18nResources( "fr" );
70     }
71
72     public String getI18nResources( String locale )
73         throws ArchivaRestServiceException
74     {
75         Properties properties = new Properties();
76
77         StringBuilder resourceName = new StringBuilder( RESOURCE_NAME );
78         try
79         {
80
81             loadResource( properties, resourceName, locale );
82
83         }
84         catch ( IOException e )
85         {
86             log.warn( "skip error loading properties {}", resourceName.toString() );
87         }
88
89         return fromProperties( properties );
90     }
91
92     private void loadResource( Properties properties, StringBuilder resourceName, String locale )
93         throws IOException
94     {
95         // load default
96         loadResource( properties, new StringBuilder( resourceName ).append( ".properties" ).toString(), locale );
97         // if locale override with locale content
98         if ( StringUtils.isNotEmpty( locale ) )
99         {
100             loadResource( properties,
101                           new StringBuilder( resourceName ).append( "_" + locale ).append( ".properties" ).toString(),
102                           locale );
103         }
104
105     }
106
107     private String fromProperties( final Properties properties )
108     {
109         StringBuilder output = new StringBuilder();
110
111         for ( Map.Entry<Object, Object> entry : properties.entrySet() )
112         {
113             output.append( (String) entry.getKey() ).append( '=' ).append( (String) entry.getValue() );
114             output.append( '\n' );
115         }
116
117         return output.toString();
118     }
119
120     private void loadResource( final Properties finalProperties, String resourceName, String locale )
121         throws IOException
122     {
123         InputStream is = null;
124         Properties properties = new Properties();
125         try
126         {
127             is = Thread.currentThread().getContextClassLoader().getResourceAsStream( resourceName.toString() );
128             if ( is != null )
129             {
130                 properties.load( is );
131                 finalProperties.putAll( properties );
132             }
133             else
134             {
135                 if ( !StringUtils.equalsIgnoreCase( locale, "en" ) )
136                 {
137                     log.info( "cannot load resource {}", resourceName );
138                 }
139             }
140         }
141         finally
142         {
143             IOUtils.closeQuietly( is );
144         }
145     }
146
147     public String getAllI18nResources( String locale )
148         throws ArchivaRestServiceException
149     {
150
151         String cachedi18n = cachei18n.get( StringUtils.isEmpty( locale ) ? "en" : StringUtils.lowerCase( locale ) );
152         if ( cachedi18n != null )
153         {
154             return cachedi18n;
155         }
156
157         try
158         {
159
160             Properties all = utilServices.getI18nProperties( locale );
161             StringBuilder resourceName = new StringBuilder( RESOURCE_NAME );
162             loadResource( all, resourceName, locale );
163
164             String i18n = fromProperties( all );
165             cachei18n.put( StringUtils.isEmpty( locale ) ? "en" : StringUtils.lowerCase( locale ), i18n );
166             return i18n;
167         }
168         catch ( IOException e )
169         {
170             throw new ArchivaRestServiceException( e.getMessage(),
171                                                    Response.Status.INTERNAL_SERVER_ERROR.getStatusCode(), e );
172         }
173         catch ( RedbackServiceException e )
174         {
175             throw new ArchivaRestServiceException( e.getMessage(), e.getHttpErrorCode(), e );
176         }
177     }
178
179     private void loadFromString( String propsStr, Properties properties )
180         throws ArchivaRestServiceException
181     {
182         InputStream inputStream = null;
183         try
184         {
185             inputStream = new ByteArrayInputStream( propsStr.getBytes() );
186             properties.load( inputStream );
187         }
188         catch ( IOException e )
189         {
190             throw new ArchivaRestServiceException( e.getMessage(),
191                                                    Response.Status.INTERNAL_SERVER_ERROR.getStatusCode(), e );
192         }
193         finally
194         {
195             IOUtils.closeQuietly( inputStream );
196         }
197     }
198
199
200     public Boolean validateCronExpression( String cronExpression )
201         throws ArchivaRestServiceException
202     {
203         return cronExpressionValidator.validate( cronExpression );
204     }
205 }