View Javadoc

1   package org.apache.archiva.policies;
2   
3   /*
4    * Licensed to the Apache Software Foundation (ASF) under one
5    * or more contributor license agreements.  See the NOTICE file
6    * distributed with this work for additional information
7    * regarding copyright ownership.  The ASF licenses this file
8    * to you under the Apache License, Version 2.0 (the
9    * "License"); you may not use this file except in compliance
10   * with the License.  You may obtain a copy of the License at
11   *
12   *  http://www.apache.org/licenses/LICENSE-2.0
13   *
14   * Unless required by applicable law or agreed to in writing,
15   * software distributed under the License is distributed on an
16   * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
17   * KIND, either express or implied.  See the License for the
18   * specific language governing permissions and limitations
19   * under the License.
20   */
21  
22  import org.apache.archiva.common.utils.VersionUtil;
23  import org.apache.commons.lang.StringUtils;
24  import org.slf4j.Logger;
25  import org.slf4j.LoggerFactory;
26  
27  import java.io.File;
28  import java.util.ArrayList;
29  import java.util.Calendar;
30  import java.util.List;
31  import java.util.Properties;
32  
33  /**
34   * AbstractUpdatePolicy
35   *
36   *
37   */
38  public abstract class AbstractUpdatePolicy
39      implements PreDownloadPolicy
40  {
41      private Logger log = LoggerFactory.getLogger( AbstractUpdatePolicy.class );
42  
43      /**
44       * The ALWAYS policy setting means that the artifact is always uipdated from the remote repo.
45       */
46      public static final String ALWAYS = "always";
47  
48      /**
49       * The NEVER policy setting means that the artifact is never updated from the remote repo.
50       */
51      public static final String NEVER = "never";
52  
53      /**
54       * <p>
55       * The DAILY policy means that the artifact retrieval occurs only if one of
56       * the following conditions are met...
57       * </p>
58       * <ul>
59       * <li>The local artifact is not present.</li>
60       * <li>The local artifact has a last modified timestamp older than (now - 1 day).</li>
61       * </ul>
62       */
63      public static final String DAILY = "daily";
64  
65      /**
66       * <p>
67       * The HOURLY policy means that the artifact retrieval occurs only if one of
68       * the following conditions are met...
69       * </p>
70       * <ul>
71       * <li>The local artifact is not present.</li>
72       * <li>The local artifact has a last modified timestamp older than (now - 1 hour).</li>
73       * </ul>
74       */
75      public static final String HOURLY = "hourly";
76  
77      /**
78       * The ONCE policy means that the artifact retrieval occurs only if the
79       * local artifact is not present.  This means that the retreival can only
80       * occur once.
81       */
82      public static final String ONCE = "once";
83  
84      private List<String> options = new ArrayList<String>( 5 );
85  
86      public AbstractUpdatePolicy()
87      {
88          options.add( ALWAYS );
89          options.add( HOURLY );
90          options.add( DAILY );
91          options.add( ONCE );
92          options.add( NEVER );
93      }
94  
95      protected abstract boolean isSnapshotPolicy();
96  
97      protected abstract String getUpdateMode();
98  
99      public List<String> getOptions()
100     {
101         return options;
102     }
103 
104     public void applyPolicy( String policySetting, Properties request, File localFile )
105         throws PolicyViolationException, PolicyConfigurationException
106     {
107         if ( !StringUtils.equals( request.getProperty( "filetype" ), "artifact" ) )
108         {
109             // Only process artifact file types.
110             return;
111         }
112 
113         String version = request.getProperty( "version", "" );
114         boolean isSnapshotVersion = false;
115 
116         if ( StringUtils.isNotBlank( version ) )
117         {
118             isSnapshotVersion = VersionUtil.isSnapshot( version );
119         }
120 
121         if ( !options.contains( policySetting ) )
122         {
123             // Not a valid code. 
124             throw new PolicyConfigurationException(
125                 "Unknown " + getUpdateMode() + " policy setting [" + policySetting + "], valid settings are ["
126                     + StringUtils.join( options.iterator(), "," ) + "]" );
127         }
128 
129         if ( ALWAYS.equals( policySetting ) )
130         {
131             // Skip means ok to update.
132             log.debug( "OK to update, {} policy set to ALWAYS.", getUpdateMode() );
133             return;
134         }
135 
136         // Test for mismatches.
137         if ( !isSnapshotVersion && isSnapshotPolicy() )
138         {
139             log.debug( "OK to update, snapshot policy does not apply for non-snapshot versions." );
140             return;
141         }
142 
143         if ( isSnapshotVersion && !isSnapshotPolicy() )
144         {
145             log.debug( "OK to update, release policy does not apply for snapshot versions." );
146             return;
147         }
148 
149         if ( NEVER.equals( policySetting ) )
150         {
151             // Reject means no.
152             throw new PolicyViolationException( "NO to update, " + getUpdateMode() + " policy set to NEVER." );
153         }
154 
155         if ( !localFile.exists() )
156         {
157             // No file means it's ok.
158             log.debug( "OK to update {}, local file does not exist.", getUpdateMode() );
159             return;
160         }
161 
162         if ( ONCE.equals( policySetting ) )
163         {
164             // File exists, but policy is once.
165             throw new PolicyViolationException(
166                 "NO to update " + getUpdateMode() + ", policy is ONCE, and local file exist." );
167         }
168 
169         if ( DAILY.equals( policySetting ) )
170         {
171             Calendar cal = Calendar.getInstance();
172             cal.add( Calendar.DAY_OF_MONTH, -1 );
173             Calendar fileCal = Calendar.getInstance();
174             fileCal.setTimeInMillis( localFile.lastModified() );
175 
176             if ( cal.after( fileCal ) )
177             {
178                 // Its ok.
179                 return;
180             }
181             else
182             {
183                 throw new PolicyViolationException( "NO to update " + getUpdateMode()
184                                                         + ", policy is DAILY, local file exist, and has been updated within the last day." );
185             }
186         }
187 
188         if ( HOURLY.equals( policySetting ) )
189         {
190             Calendar cal = Calendar.getInstance();
191             cal.add( Calendar.HOUR, -1 );
192             Calendar fileCal = Calendar.getInstance();
193             fileCal.setTimeInMillis( localFile.lastModified() );
194 
195             if ( cal.after( fileCal ) )
196             {
197                 // Its ok.
198                 return;
199             }
200             else
201             {
202                 throw new PolicyViolationException( "NO to update " + getUpdateMode()
203                                                         + ", policy is HOURLY, local file exist, and has been updated within the last hour." );
204             }
205         }
206 
207         throw new PolicyConfigurationException(
208             "Unable to process " + getUpdateMode() + " policy of [" + policySetting + "], please file a bug report." );
209     }
210 }