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

org.eclipse.aether.spi.connector.layout.RepositoryLayout Maven / Gradle / Ivy

There is a newer version: 3.0.0-alpha-3
Show 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.spi.connector.layout;

import java.net.URI;
import java.util.List;

import org.eclipse.aether.artifact.Artifact;
import org.eclipse.aether.metadata.Metadata;
import org.eclipse.aether.spi.connector.checksum.ChecksumAlgorithmFactory;

import static java.util.Objects.requireNonNull;

/**
 * The layout for a remote repository whose artifacts/metadata can be addressed via URIs.
 * 

* Note: Implementations must be stateless. */ public interface RepositoryLayout { /** * A descriptor for a checksum location. This descriptor simply associates the location of a checksum file with the * underlying checksum algorithm used to calculate/verify it. */ final class ChecksumLocation { private final URI location; private final ChecksumAlgorithmFactory checksumAlgorithmFactory; /** * Creates a new checksum file descriptor with the specified algorithm and location. The method * {@link #forLocation(URI, ChecksumAlgorithmFactory)} is usually more convenient though. * * @param location The relative URI to the checksum file within a repository, must not be {@code * null}. * @param checksumAlgorithmFactory The checksum type used to calculate the checksum, must not be {@code null}. */ public ChecksumLocation(URI location, ChecksumAlgorithmFactory checksumAlgorithmFactory) { verify(location, checksumAlgorithmFactory); this.location = location; this.checksumAlgorithmFactory = checksumAlgorithmFactory; } /** * Creates a checksum descriptor for the specified artifact/metadata location and algorithm. The location * of the checksum file itself is derived from the supplied resource URI by appending the file extension * specified by the algorithm factory. See {@link ChecksumAlgorithmFactory#getFileExtension()}. * * @param location The relative URI to the artifact/metadata whose checksum file is being * obtained, must not be * {@code null} and must not have a query or fragment part. * @param checksumAlgorithmFactory The algorithm used to calculate the checksum, must not be {@code null}. * @return The checksum file descriptor, never {@code null}. */ public static ChecksumLocation forLocation(URI location, ChecksumAlgorithmFactory checksumAlgorithmFactory) { verify(location, checksumAlgorithmFactory); if (location.getRawQuery() != null) { throw new IllegalArgumentException("resource location must not have query parameters: " + location); } if (location.getRawFragment() != null) { throw new IllegalArgumentException("resource location must not have a fragment: " + location); } return new ChecksumLocation( URI.create(location + "." + checksumAlgorithmFactory.getFileExtension()), checksumAlgorithmFactory); } private static void verify(URI location, ChecksumAlgorithmFactory checksumAlgorithmFactory) { requireNonNull(location, "checksum location cannot be null"); if (location.isAbsolute()) { throw new IllegalArgumentException("checksum location must be relative"); } requireNonNull(checksumAlgorithmFactory, "checksum algorithm factory cannot be null"); } /** * Gets the {@link ChecksumAlgorithmFactory} that is used to calculate the checksum. * * @return The checksum factory, never {@code null}. */ public ChecksumAlgorithmFactory getChecksumAlgorithmFactory() { return checksumAlgorithmFactory; } /** * Gets the location of the checksum file with a remote repository. The URI is relative to the root directory of * the repository. * * @return The relative URI to the checksum file, never {@code null}. */ public URI getLocation() { return location; } @Override public String toString() { return location + " (" + checksumAlgorithmFactory.getName() + ")"; } } /** * Returns immutable list of {@link ChecksumAlgorithmFactory} this instance of layout uses, never {@code null}. * The order also represents the order how remote external checksums are retrieved and validated. * * @see org.eclipse.aether.spi.connector.checksum.ChecksumPolicy.ChecksumKind * @since 1.8.0 */ List getChecksumAlgorithmFactories(); /** * Tells whether given artifact have remote external checksums according to current layout or not. If it returns * {@code true}, then layout configured checksums will be expected: on upload they will be calculated and deployed * along artifact, on download they will be retrieved and validated. * * If it returns {@code false} the given artifacts will have checksums omitted: on upload they will not be * calculated and deployed, and on download they will be not retrieved nor validated. * * The result affects only layout provided checksums. See * {@link org.eclipse.aether.spi.connector.checksum.ChecksumPolicy.ChecksumKind#REMOTE_EXTERNAL}. * On download, the {@link org.eclipse.aether.spi.connector.layout.RepositoryLayout#getChecksumAlgorithmFactories()} * layout required checksums are calculated, and non layout-provided checksums are still utilized. * * Typical case to return {@code false} (to omit checksums) is for artifact signatures, that are already a * "sub-artifact" of some main artifact (for example a JAR), and they can be validated by some other means. * * @see org.eclipse.aether.spi.connector.checksum.ChecksumPolicy.ChecksumKind * @see #getChecksumAlgorithmFactories() * @since 1.8.0 */ boolean hasChecksums(Artifact artifact); /** * Gets the location within a remote repository where the specified artifact resides. The URI is relative to the * root directory of the repository. * * @param artifact The artifact to get the URI for, must not be {@code null}. * @param upload {@code false} if the artifact is being downloaded, {@code true} if the artifact is being * uploaded. * @return The relative URI to the artifact, never {@code null}. */ URI getLocation(Artifact artifact, boolean upload); /** * Gets the location within a remote repository where the specified metadata resides. The URI is relative to the * root directory of the repository. * * @param metadata The metadata to get the URI for, must not be {@code null}. * @param upload {@code false} if the metadata is being downloaded, {@code true} if the metadata is being * uploaded. * @return The relative URI to the metadata, never {@code null}. */ URI getLocation(Metadata metadata, boolean upload); /** * Gets the checksums files that a remote repository keeps to help detect data corruption during transfers of the * specified artifact. * * @param artifact The artifact to get the checksum files for, must not be {@code null}. * @param upload {@code false} if the checksums are being downloaded/verified, {@code true} if the checksums are * being uploaded/created. * @param location The relative URI to the artifact within the repository as previously obtained from * {@link #getLocation(Artifact, boolean)}, must not be {@code null}. * @return The checksum files for the given artifact, possibly empty but never {@code null}. If empty, that means * that this layout does not provide checksums for given artifact. */ List getChecksumLocations(Artifact artifact, boolean upload, URI location); /** * Gets the checksums files that a remote repository keeps to help detect data corruption during transfers of the * specified metadata. * * @param metadata The metadata to get the checksum files for, must not be {@code null}. * @param upload {@code false} if the checksums are being downloaded/verified, {@code true} if the checksums are * being uploaded/created. * @param location The relative URI to the metadata within the repository as previously obtained from * {@link #getLocation(Metadata, boolean)}, must not be {@code null}. * @return The checksum files for the given metadata, possibly empty but never {@code null}. If empty, that means * that this layout does not provide checksums for given artifact. */ List getChecksumLocations(Metadata metadata, boolean upload, URI location); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy