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

com.yahoo.vespa.config.server.filedistribution.FileDistributionFactory Maven / Gradle / Ivy

There is a newer version: 8.441.21
Show newest version
// Copyright Vespa.ai. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.vespa.config.server.filedistribution;

import com.yahoo.cloud.config.ConfigserverConfig;
import com.yahoo.component.annotation.Inject;
import com.yahoo.config.application.api.FileRegistry;
import com.yahoo.config.model.api.FileDistribution;
import com.yahoo.jrt.Supervisor;
import com.yahoo.jrt.Transport;
import java.io.File;

/**
 * Factory for creating providers that are used to interact with file distribution.
 *
 * @author Ulf Lilleengen
 */
@SuppressWarnings("WeakerAccess")
public class FileDistributionFactory implements AutoCloseable {

    protected final ConfigserverConfig configserverConfig;
    protected final FileDirectory fileDirectory;
    private final Supervisor supervisor = new Supervisor(new Transport("filedistribution"));


    @Inject
    public FileDistributionFactory(ConfigserverConfig configserverConfig, FileDirectory fileDirectory) {
        this.configserverConfig = configserverConfig;
        this.fileDirectory = fileDirectory;
    }

    public FileRegistry createFileRegistry(File applicationPackage) {
        return new FileDBRegistry(createFileManager(applicationPackage));
    }

    public FileDistribution createFileDistribution() {
        return new FileDistributionImpl(supervisor);
    }

    public AddFileInterface createFileManager(File applicationDir) {
        return new ApplicationFileManager(applicationDir, fileDirectory, configserverConfig.hostedVespa());
    }

    public FileDirectory fileDirectory() { return fileDirectory; }

    public void close() {
        supervisor.transport().shutdown().join();
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy