summaryrefslogtreecommitdiffstats
path: root/common-app-api/src/main/java/org/openecomp/sdc/be/csar/storage/ArtifactStorageManager.java
blob: 0a4f355642ab8a1220fc0d25e1464c41fd92b3b7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/*
 * ============LICENSE_START=======================================================
 *  Copyright (C) 2021 Nordix Foundation
 *  ================================================================================
 *  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.
 *
 *  SPDX-License-Identifier: Apache-2.0
 *  ============LICENSE_END=========================================================
 */

package org.openecomp.sdc.be.csar.storage;

import java.io.InputStream;

/**
 * Manages the artifact storage and handles operations on the artifacts
 */
public interface ArtifactStorageManager {

    /**
     * Persists the uploaded artifact in the storage.
     *
     * @param vspId                the VSP id
     * @param versionId            the VSP version id
     * @param uploadedArtifactInfo the uploaded
     * @return the information about the persisted artifact
     */
    ArtifactInfo persist(String vspId, String versionId, ArtifactInfo uploadedArtifactInfo);

    /**
     * Uploads a file to the Artifact Storage. This file will be temporary until persisted by {@link #persist(String, String, ArtifactInfo)}.
     *
     * @param vspId        the VSP id
     * @param versionId    the VSP version id
     * @param fileToUpload the file input stream
     * @return the information about the uploaded artifact
     */
    ArtifactInfo upload(String vspId, String versionId, InputStream fileToUpload);

    /**
     * Checks if the Artifact Storage is enabled.
     *
     * @return {@code true} if enable, {@code false} otherwise
     */
    default boolean isEnabled() {
        return false;
    }

    /**
     * @return Storage Configuration
     */
    ArtifactStorageConfig getStorageConfiguration();

    InputStream get(final ArtifactInfo artifactInfo);

    void delete(ArtifactInfo artifactInfo);
}