All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.aether.internal.impl.EnhancedLocalRepositoryManager Maven / Gradle / Ivy

The newest version!
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package org.eclipse.aether.internal.impl;

import java.nio.file.Files;
import java.nio.file.Path;
import java.util.Collection;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Objects;
import java.util.Properties;

import org.eclipse.aether.RepositorySystemSession;
import org.eclipse.aether.artifact.Artifact;
import org.eclipse.aether.metadata.Metadata;
import org.eclipse.aether.repository.LocalArtifactRegistration;
import org.eclipse.aether.repository.LocalArtifactRequest;
import org.eclipse.aether.repository.LocalArtifactResult;
import org.eclipse.aether.repository.RemoteRepository;

import static java.util.Objects.requireNonNull;

/**
 * These are implementation details for enhanced local repository manager, subject to change without prior notice.
 * Repositories from which a cached artifact was resolved are tracked in a properties file named
 * _remote.repositories, with content key as filename>repo_id and value as empty string. If a file has
 * been installed in the repository, but not downloaded from a remote repository, it is tracked as empty repository id
 * and always resolved. For example:
 *
 * 
 * artifact-1.0.pom>=
 * artifact-1.0.jar>=
 * artifact-1.0.pom>central=
 * artifact-1.0.jar>central=
 * artifact-1.0.zip>central=
 * artifact-1.0-classifier.zip>central=
 * artifact-1.0.pom>my_repo_id=
 * 
* * @see EnhancedLocalRepositoryManagerFactory */ class EnhancedLocalRepositoryManager extends SimpleLocalRepositoryManager { private static final String LOCAL_REPO_ID = ""; private final String trackingFilename; private final TrackingFileManager trackingFileManager; private final LocalPathPrefixComposer localPathPrefixComposer; EnhancedLocalRepositoryManager( Path basedir, LocalPathComposer localPathComposer, String trackingFilename, TrackingFileManager trackingFileManager, LocalPathPrefixComposer localPathPrefixComposer) { super(basedir, "enhanced", localPathComposer); this.trackingFilename = requireNonNull(trackingFilename); this.trackingFileManager = requireNonNull(trackingFileManager); this.localPathPrefixComposer = requireNonNull(localPathPrefixComposer); } private String concatPaths(String prefix, String artifactPath) { if (prefix == null || prefix.isEmpty()) { return artifactPath; } return prefix + '/' + artifactPath; } @Override public String getPathForLocalArtifact(Artifact artifact) { return concatPaths( localPathPrefixComposer.getPathPrefixForLocalArtifact(artifact), super.getPathForLocalArtifact(artifact)); } @Override public String getPathForRemoteArtifact(Artifact artifact, RemoteRepository repository, String context) { return concatPaths( localPathPrefixComposer.getPathPrefixForRemoteArtifact(artifact, repository), super.getPathForRemoteArtifact(artifact, repository, context)); } @Override public String getPathForLocalMetadata(Metadata metadata) { return concatPaths( localPathPrefixComposer.getPathPrefixForLocalMetadata(metadata), super.getPathForLocalMetadata(metadata)); } @Override public String getPathForRemoteMetadata(Metadata metadata, RemoteRepository repository, String context) { return concatPaths( localPathPrefixComposer.getPathPrefixForRemoteMetadata(metadata, repository), super.getPathForRemoteMetadata(metadata, repository, context)); } @Override public LocalArtifactResult find(RepositorySystemSession session, LocalArtifactRequest request) { Artifact artifact = request.getArtifact(); LocalArtifactResult result = new LocalArtifactResult(request); Path filePath; // Local repository CANNOT have timestamped installed, they are created only during deploy if (Objects.equals(artifact.getVersion(), artifact.getBaseVersion())) { filePath = getAbsolutePathForLocalArtifact(artifact); checkFind(filePath, result); } if (!result.isAvailable()) { for (RemoteRepository repository : request.getRepositories()) { filePath = getAbsolutePathForRemoteArtifact(artifact, repository, request.getContext()); checkFind(filePath, result); if (result.isAvailable()) { break; } } } return result; } private void checkFind(Path path, LocalArtifactResult result) { if (Files.isRegularFile(path)) { result.setPath(path); Properties props = readRepos(path); if (props.get(getKey(path, LOCAL_REPO_ID)) != null) { // artifact installed into the local repo is always accepted result.setAvailable(true); } else { String context = result.getRequest().getContext(); for (RemoteRepository repository : result.getRequest().getRepositories()) { if (props.get(getKey(path, getRepositoryKey(repository, context))) != null) { // artifact downloaded from remote repository is accepted only downloaded from request // repositories result.setAvailable(true); result.setRepository(repository); break; } } if (!result.isAvailable() && !isTracked(props, path)) { /* * NOTE: The artifact is present but not tracked at all, for inter-op with simple local repo, assume * the artifact was locally installed. */ result.setAvailable(true); } } } } @Override public void add(RepositorySystemSession session, LocalArtifactRegistration request) { Collection repositories; if (request.getRepository() == null) { repositories = Collections.singleton(LOCAL_REPO_ID); } else { repositories = getRepositoryKeys(request.getRepository(), request.getContexts()); } if (request.getRepository() == null) { addArtifact(request.getArtifact(), repositories, null, null); } else { for (String context : request.getContexts()) { addArtifact(request.getArtifact(), repositories, request.getRepository(), context); } } } private Collection getRepositoryKeys(RemoteRepository repository, Collection contexts) { Collection keys = new HashSet<>(); if (contexts != null) { for (String context : contexts) { keys.add(getRepositoryKey(repository, context)); } } return keys; } private void addArtifact( Artifact artifact, Collection repositories, RemoteRepository repository, String context) { requireNonNull(artifact, "artifact cannot be null"); Path file = repository == null ? getAbsolutePathForLocalArtifact(artifact) : getAbsolutePathForRemoteArtifact(artifact, repository, context); addRepo(file, repositories); } private Properties readRepos(Path artifactPath) { Path trackingFile = getTrackingFile(artifactPath); Properties props = trackingFileManager.read(trackingFile); return (props != null) ? props : new Properties(); } private void addRepo(Path artifactPath, Collection repositories) { Map updates = new HashMap<>(); for (String repository : repositories) { updates.put(getKey(artifactPath, repository), ""); } Path trackingPath = getTrackingFile(artifactPath); trackingFileManager.update(trackingPath, updates); } private Path getTrackingFile(Path artifactPath) { return artifactPath.getParent().resolve(trackingFilename); } private String getKey(Path path, String repository) { return path.getFileName() + ">" + repository; } private boolean isTracked(Properties props, Path path) { if (props != null) { String keyPrefix = path.getFileName() + ">"; for (Object key : props.keySet()) { if (key.toString().startsWith(keyPrefix)) { return true; } } } return false; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy