Para finalmente responder la pregunta del título: Es (una configuración del lado del cliente) en (proyecto, perfil o configuración)
[plugin]?[r|R]epository/[releases|snapshots]/updatePolicy
... etiqueta.
Los valores posibles (actualmente, maven: 3.6.0, pero supongo que son compatibles con "versiones anteriores") son:
/**
* Never update locally cached data.
*/
public static final String UPDATE_POLICY_NEVER = "never";
/**
* Always update locally cached data.
*/
public static final String UPDATE_POLICY_ALWAYS = "always";
/**
* Update locally cached data once a day.
*/
public static final String UPDATE_POLICY_DAILY = "daily";
/**
* Update locally cached data **every X minutes** as given by "interval:X".
*/
public static final String UPDATE_POLICY_INTERVAL = "interval";
La evaluación actual (maven 3.6.0) de esta etiqueta se implementa de la siguiente manera:
public boolean isUpdatedRequired( RepositorySystemSession session, long lastModified, String policy )
{
boolean checkForUpdates;
if ( policy == null )
{
policy = "";
}
if ( RepositoryPolicy.UPDATE_POLICY_ALWAYS.equals( policy ) )
{
checkForUpdates = true;
}
else if ( RepositoryPolicy.UPDATE_POLICY_DAILY.equals( policy ) )
{
Calendar cal = Calendar.getInstance();
cal.set( Calendar.HOUR_OF_DAY, 0 );
cal.set( Calendar.MINUTE, 0 );
cal.set( Calendar.SECOND, 0 );
cal.set( Calendar.MILLISECOND, 0 );
checkForUpdates = cal.getTimeInMillis() > lastModified;
}
else if ( policy.startsWith( RepositoryPolicy.UPDATE_POLICY_INTERVAL ) )
{
int minutes = getMinutes( policy );
Calendar cal = Calendar.getInstance();
cal.add( Calendar.MINUTE, -minutes );
checkForUpdates = cal.getTimeInMillis() > lastModified;
}
else
{
// assume "never"
checkForUpdates = false;
if ( !RepositoryPolicy.UPDATE_POLICY_NEVER.equals( policy ) )
{
LOGGER.warn( "Unknown repository update policy '{}', assuming '{}'",
policy, RepositoryPolicy.UPDATE_POLICY_NEVER );
}
}
return checkForUpdates;
}
..con:
private int getMinutes( String policy )
{
int minutes;
try
{
String s = policy.substring( RepositoryPolicy.UPDATE_POLICY_INTERVAL.length() + 1 );
minutes = Integer.valueOf( s );
}
catch ( RuntimeException e )
{
minutes = 24 * 60;
LOGGER.warn( "Non-parseable repository update policy '{}', assuming '{}:1440'",
policy, RepositoryPolicy.UPDATE_POLICY_INTERVAL );
}
return minutes;
}
... donde lastModified
está la "marca de tiempo modificada" (archivo local) de un / cada artefacto subyacente.
En particular para el interval:x
entorno:
- los dos puntos
:
no son tan estrictos: cualquier personaje "no vacío" podría hacerlo ( =
,
, ...).
- valores negativos
x < 0
deberían ceder a "nunca".
interval:0
Asumiría un intervalo "minucioso" (0-59 segundos o más ...).
- las excepciones de formato de número dan como resultado
24 * 60
minutos (~ "diario").
..ver: DefaultUpdatePolicyAnalyzer , DefaultMetadataResolver # resolveMetadata () y RepositoryPolicy