Para finalmente responder à pergunta do título: É (uma configuração do lado do cliente) em (projeto, perfil ou configurações)
[plugin]?[r|R]epository/[releases|snapshots]/updatePolicy
... tag.
Os (atualmente, maven: 3.6.0, mas suponho que sejam compatíveis "muito atrás") os possíveis valores são:
/**
* 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";
A avaliação atual (maven 3.6.0) dessa tag é implementada da seguinte maneira:
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;
}
..com:
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;
}
... onde lastModified
está o (arquivo local) "carimbo de data / hora modificado" de um / cada artefato subjacente.
Em particular para a interval:x
configuração:
- o cólon
:
não é tão rigoroso - qualquer caractere "não vazio" poderia fazer isso ( =
,
...).
- valores negativos
x < 0
devem render para "nunca".
interval:0
Eu assumiria um intervalo "minucioso" (0-59 segundos ou mais ...).
- as exceções de formato numérico resultam em
24 * 60
minutos (~ "diariamente").
..see: DefaultUpdatePolicyAnalyzer , DefaultMetadataResolver # resolveMetadata () e RepositoryPolicy