This project has retired. For details please refer to its Attic page.
AbstractUpdatePolicy xref
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.archiva.repository.storage.StorageAsset;
24  import org.apache.commons.lang3.StringUtils;
25  import org.slf4j.Logger;
26  import org.slf4j.LoggerFactory;
27  
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      extends AbstractPolicy implements PreDownloadPolicy
40  {
41      private Logger log = LoggerFactory.getLogger( AbstractUpdatePolicy.class );
42  
43      /**
44       * The ALWAYS policy setting means that the artifact is always updated from the remote repo.
45       */
46      public static final PolicyOption ALWAYS = UpdateOption.ALWAYS;
47  
48      /**
49       * The NEVER policy setting means that the artifact is never updated from the remote repo.
50       */
51      public static final PolicyOption NEVER = UpdateOption.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 UpdateOption DAILY = UpdateOption.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 UpdateOption HOURLY = UpdateOption.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 retrieval can only
80       * occur once.
81       */
82      public static final UpdateOption ONCE = UpdateOption.ONCE;
83  
84      private List<PolicyOption> options = new ArrayList<>( 5 );
85  
86      public AbstractUpdatePolicy()
87      {
88          super();
89          super.setOptionPrefix("update.option.");
90          options.add( ALWAYS );
91          options.add( HOURLY );
92          options.add( DAILY );
93          options.add( ONCE );
94          options.add( NEVER );
95      }
96  
97      protected abstract boolean isSnapshotPolicy();
98  
99      protected abstract String getUpdateMode();
100 
101     @Override
102     public List<PolicyOption> getOptions()
103     {
104         return options;
105     }
106 
107     @Override
108     public void applyPolicy( PolicyOption policySetting, Properties request, StorageAsset localFile )
109         throws PolicyViolationException, PolicyConfigurationException
110     {
111         if ( !StringUtils.equals( request.getProperty( "filetype" ), "artifact" ) )
112         {
113             // Only process artifact file types.
114             return;
115         }
116 
117         String version = request.getProperty( "version", "" );
118         boolean isSnapshotVersion = false;
119 
120         if ( StringUtils.isNotBlank( version ) )
121         {
122             isSnapshotVersion = VersionUtil.isSnapshot( version );
123         }
124 
125         if ( !options.contains( policySetting ) )
126         {
127             // Not a valid code. 
128             throw new PolicyConfigurationException(
129                 "Unknown " + getUpdateMode() + " policy setting [" + policySetting + "], valid settings are ["
130                     + StringUtils.join( options.iterator(), "," ) + "]" );
131         }
132 
133         if ( ALWAYS.equals( policySetting ) )
134         {
135             // Skip means ok to update.
136             log.debug( "OK to update, {} policy set to ALWAYS.", getUpdateMode() );
137             return;
138         }
139 
140         // Test for mismatches.
141         if ( !isSnapshotVersion && isSnapshotPolicy() )
142         {
143             log.debug( "OK to update, snapshot policy does not apply for non-snapshot versions." );
144             return;
145         }
146 
147         if ( isSnapshotVersion && !isSnapshotPolicy() )
148         {
149             log.debug( "OK to update, release policy does not apply for snapshot versions." );
150             return;
151         }
152 
153         if ( NEVER.equals( policySetting ) )
154         {
155             // Reject means no.
156             throw new PolicyViolationException( "NO to update, " + getUpdateMode() + " policy set to NEVER." );
157         }
158 
159         if ( !localFile.exists() )
160         {
161             // No file means it's ok.
162             log.debug( "OK to update {}, local file does not exist.", getUpdateMode() );
163             return;
164         }
165 
166         if ( ONCE.equals( policySetting ) )
167         {
168             // File exists, but policy is once.
169             throw new PolicyViolationException(
170                 "NO to update " + getUpdateMode() + ", policy is ONCE, and local file exist." );
171         }
172 
173         if ( DAILY.equals( policySetting ) )
174         {
175             Calendar cal = Calendar.getInstance();
176             cal.add( Calendar.DAY_OF_MONTH, -1 );
177             Calendar fileCal = Calendar.getInstance();
178             fileCal.setTimeInMillis( localFile.getModificationTime().toEpochMilli() );
179 
180             if ( cal.after( fileCal ) )
181             {
182                 // Its ok.
183                 return;
184             }
185             else
186             {
187                 throw new PolicyViolationException( "NO to update " + getUpdateMode()
188                                                         + ", policy is DAILY, local file exist, and has been updated within the last day." );
189             }
190         }
191 
192         if ( HOURLY.equals( policySetting ) )
193         {
194             Calendar cal = Calendar.getInstance();
195             cal.add( Calendar.HOUR, -1 );
196             Calendar fileCal = Calendar.getInstance();
197             fileCal.setTimeInMillis( localFile.getModificationTime().toEpochMilli());
198 
199             if ( cal.after( fileCal ) )
200             {
201                 // Its ok.
202                 return;
203             }
204             else
205             {
206                 throw new PolicyViolationException( "NO to update " + getUpdateMode()
207                                                         + ", policy is HOURLY, local file exist, and has been updated within the last hour." );
208             }
209         }
210 
211         throw new PolicyConfigurationException(
212             "Unable to process " + getUpdateMode() + " policy of [" + policySetting + "], please file a bug report." );
213     }
214 }