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

com.metaeffekt.resource.InventoryResource Maven / Gradle / Ivy

/*
 * Copyright 2021-2024 the original author or authors.
 *
 * Licensed 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 com.metaeffekt.resource;

import com.metaeffekt.artifact.analysis.utils.FileUtils;
import lombok.Getter;
import org.metaeffekt.core.inventory.processor.model.Artifact;
import org.metaeffekt.core.inventory.processor.model.Inventory;
import org.metaeffekt.core.inventory.processor.reader.InventoryReader;
import org.metaeffekt.core.inventory.processor.writer.InventoryWriter;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.File;
import java.io.IOException;
import java.util.LinkedHashMap;
import java.util.Map;

import static java.lang.String.format;

public class InventoryResource extends Resource {

    private final static Logger LOG = LoggerFactory.getLogger(InventoryResource.class);

    @Getter
    private final File file;

    private final Inventory providedInventory;

    private Inventory loadedInventory;

    public InventoryResource(File file, Inventory inventory) {
        this.file = file;
        this.providedInventory = inventory;
    }

    public Inventory getInventory() {
        synchronized (this) {
            if (loadedInventory == null) {
                if (providedInventory != null) {
                    loadedInventory = providedInventory;
                } else {
                    loadedInventory = reloadInventory();
                }
            }
        }
        return loadedInventory;
    }

    @Override
    public void sync() throws IOException {
        if (!file.exists()) {
            FileUtils.forceMkdirParent(file);
        }
        new InventoryWriter().writeInventory(getInventory(), file);
    }

    @Override
    public void sync(File targetFile) throws IOException {
        if (targetFile.getParentFile() != null && !targetFile.getParentFile().exists()) {
            FileUtils.forceMkdirParent(targetFile);
        }
        new InventoryWriter().writeInventory(getInventory(), targetFile);
    }

    public Map buildQualifierArtifactMap() {
        final Inventory inventory = getInventory();
        final Map qualifierArtifactMap = new LinkedHashMap<>();

        for (final Artifact artifact : inventory.getArtifacts()) {
            final String artifactQualifier = qualifierOf(artifact);
            if (!qualifierArtifactMap.containsKey(artifactQualifier)) {
                qualifierArtifactMap.put(artifactQualifier, artifact);
            } else {
                throw new IllegalStateException(String.format(
                        "Duplicate artifact qualifier detected in inventory [%s]. Qualifier: [%s]",
                        getFile(), artifactQualifier));
            }
        }
        return qualifierArtifactMap;
    }

    public String qualifierOf(Artifact artifact) {
        return "[" +
                artifact.getId() + "-" +
                artifact.getChecksum() + "-" +
                artifact.getGroupId() + "-" +
                artifact.getVersion() +
                "]";
    }

    public Inventory reloadInventory() {
        if (file != null && file.exists()) {
            try {
                return new InventoryReader().readInventory(file);
            } catch (IOException e) {
                throw new IllegalStateException("Cannot load inventory from file: [" + file.getAbsolutePath() + "]", e);
            }
        } else {
            // when no file was given we return a new inventory
            return new Inventory();
        }
    }

    /**
     * Creates the resource from the specified file. If the file does not exist an empty inventory is created. If
     * The file already exists the inventory is loaded.
     *
     * @param inventoryFile The inventory file to be used
     * @return The created inventory resource
     */
    public static InventoryResource attachFile(File inventoryFile) {
        return new InventoryResource(inventoryFile, null);
    }

    /**
     * Initializes from an existing file. The file must exist.
     *
     * @param inventoryFile The inventory file to be used
     * @return The created inventory resource
     */
    public static InventoryResource fromFile(File inventoryFile) {
        validateInventoryFile(inventoryFile);
        return new InventoryResource(inventoryFile, null);
    }

    private static void validateInventoryFile(File inventoryFile) {
        if (!inventoryFile.exists()) {
            throw new IllegalStateException(String.format("Inventory file [%s] does not exist.", inventoryFile));
        }
    }

    public static InventoryResource fromInventory(Inventory inventory) {
        return new InventoryResource(null, inventory);
    }

    public static InventoryResource create() {
        return new InventoryResource(null, null);
    }


    public void syncIfPossible(File inventoryFile) {
        try {
            sync(inventoryFile);
        } catch (IOException e) {
            LOG.warn(format("Cannot write inventory from [%s].", inventoryFile));
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy