1 /* 2 * Licensed to the Apache Software Foundation (ASF) under one 3 * or more contributor license agreements. See the NOTICE file 4 * distributed with this work for additional information 5 * regarding copyright ownership. The ASF licenses this file 6 * to you under the Apache License, Version 2.0 (the 7 * "License"); you may not use this file except in compliance 8 * with the License. You may obtain a copy of the License at 9 * 10 * http://www.apache.org/licenses/LICENSE-2.0 11 * 12 * Unless required by applicable law or agreed to in writing, 13 * software distributed under the License is distributed on an 14 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 15 * KIND, either express or implied. See the License for the 16 * specific language governing permissions and limitations 17 * under the License. 18 */ 19 package org.eclipse.aether.resolution; 20 21 import org.eclipse.aether.RepositorySystem; 22 import org.eclipse.aether.metadata.Metadata; 23 import org.eclipse.aether.transfer.MetadataNotFoundException; 24 25 import static java.util.Objects.requireNonNull; 26 27 /** 28 * The result of a metadata resolution request. 29 * 30 * @see RepositorySystem#resolveMetadata(org.eclipse.aether.RepositorySystemSession, java.util.Collection) 31 */ 32 public final class MetadataResult { 33 34 private final MetadataRequest request; 35 36 private Exception exception; 37 38 private boolean updated; 39 40 private Metadata metadata; 41 42 /** 43 * Creates a new result for the specified request. 44 * 45 * @param request The resolution request, must not be {@code null}. 46 */ 47 public MetadataResult(MetadataRequest request) { 48 this.request = requireNonNull(request, "metadata request cannot be null"); 49 } 50 51 /** 52 * Gets the resolution request that was made. 53 * 54 * @return The resolution request, never {@code null}. 55 */ 56 public MetadataRequest getRequest() { 57 return request; 58 } 59 60 /** 61 * Gets the resolved metadata (if any). 62 * 63 * @return The resolved metadata or {@code null} if the resolution failed. 64 */ 65 public Metadata getMetadata() { 66 return metadata; 67 } 68 69 /** 70 * Sets the resolved metadata. 71 * 72 * @param metadata The resolved metadata, may be {@code null} if the resolution failed. 73 * @return This result for chaining, never {@code null}. 74 */ 75 public MetadataResult setMetadata(Metadata metadata) { 76 this.metadata = metadata; 77 return this; 78 } 79 80 /** 81 * Records the specified exception while resolving the metadata. 82 * 83 * @param exception The exception to record, may be {@code null}. 84 * @return This result for chaining, never {@code null}. 85 */ 86 public MetadataResult setException(Exception exception) { 87 this.exception = exception; 88 return this; 89 } 90 91 /** 92 * Gets the exception that occurred while resolving the metadata. 93 * 94 * @return The exception that occurred or {@code null} if none. 95 */ 96 public Exception getException() { 97 return exception; 98 } 99 100 /** 101 * Sets the updated flag for the metadata. 102 * 103 * @param updated {@code true} if the metadata was actually fetched from the remote repository during the 104 * resolution, {@code false} if the metadata was resolved from a locally cached copy. 105 * @return This result for chaining, never {@code null}. 106 */ 107 public MetadataResult setUpdated(boolean updated) { 108 this.updated = updated; 109 return this; 110 } 111 112 /** 113 * Indicates whether the metadata was actually fetched from the remote repository or resolved from the local cache. 114 * If metadata has been locally cached during a previous resolution request and this local copy is still up-to-date 115 * according to the remote repository's update policy, no remote access is made. 116 * 117 * @return {@code true} if the metadata was actually fetched from the remote repository during the resolution, 118 * {@code false} if the metadata was resolved from a locally cached copy. 119 */ 120 public boolean isUpdated() { 121 return updated; 122 } 123 124 /** 125 * Indicates whether the requested metadata was resolved. Note that the metadata might have been successfully 126 * resolved (from the local cache) despite {@link #getException()} indicating a transfer error while trying to 127 * refetch the metadata from the remote repository. 128 * 129 * @return {@code true} if the metadata was resolved, {@code false} otherwise. 130 * @see Metadata#getPath() 131 */ 132 public boolean isResolved() { 133 return getMetadata() != null && getMetadata().getPath() != null; 134 } 135 136 /** 137 * Indicates whether the requested metadata is not present in the remote repository. 138 * 139 * @return {@code true} if the metadata is not present in the remote repository, {@code false} otherwise. 140 */ 141 public boolean isMissing() { 142 return getException() instanceof MetadataNotFoundException; 143 } 144 145 @Override 146 public String toString() { 147 return getMetadata() + (isUpdated() ? " (updated)" : " (cached)"); 148 } 149 }