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

com.cognite.client.ThreeDFiles Maven / Gradle / Ivy

/*
 * Copyright (c) 2020 Cognite AS
 *
 * 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.cognite.client;

import com.cognite.client.dto.ThreeDFileBinary;
import com.cognite.client.servicesV1.ConnectorServiceV1;
import com.google.auto.value.AutoValue;
import com.google.common.base.Preconditions;
import org.apache.commons.lang3.RandomStringUtils;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;

import java.net.URI;
import java.nio.file.Path;
import java.time.Duration;
import java.time.Instant;
import java.util.Objects;

/**
 * This class represents the Cognite 3DFiles api endpoint.
 *
 * It provides methods for reading and writing.
 */
@AutoValue
public abstract class ThreeDFiles extends ApiBase {

    /**
     * Downloads 3D file binaries to a local / network path.
     *
     * Downloads a set of 3D file binaries based on {@code id}.
     *
     * Supported destination file stores for the file binary:
     * - Local (network) disk. Specify the temp path as {@code file:////}.
     * Examples: {@code file://localhost/home/files/, file:///home/files/, file:///c:/temp/}
     * - Google Cloud Storage. Specify the temp path as {@code gs:////}.
     *
     * @param threeDFileId The id of the 3D file to download.
     * @param downloadPath The URI to the download storage
     * @return File containers with file headers and references/byte streams of the binary.
     */
    public ThreeDFileBinary downloadToPath(Long threeDFileId, Path downloadPath) throws Exception {
        return download(threeDFileId, downloadPath, false);
    }

    /**
     * Downloads 3D file binaries.
     *
     * Downloads a set of 3D file binaries based on {@code id}. The file
     * binaries can be downloaded as files or byte streams. In case the file is very large (> 200MB) it has to
     * be streamed directly to the file system (i.e. downloaded as a file).
     *
     * Supported destination file stores for the file binary:
     * - Local (network) disk. Specify the temp path as {@code file:////}.
     * Examples: {@code file://localhost/home/files/, file:///home/files/, file:///c:/temp/}
     * - Google Cloud Storage. Specify the temp path as {@code gs:////}.
     *
     * @param threeDFileId The id of the 3D file to download.
     * @param downloadPath The URI to the download storage
     * @param preferByteStream Set to true to return byte streams when possible, set to false to always store
     *                         binary as file.
     * @return File containers with file headers and references/byte streams of the binary.
     */
    public ThreeDFileBinary download(Long threeDFileId, Path downloadPath, boolean preferByteStream) throws Exception {
        String loggingPrefix = getLoggingPrefix();
        Preconditions.checkArgument(java.nio.file.Files.isDirectory(downloadPath),
                loggingPrefix + "The download path must be a valid directory.");

        Instant startInstant = Instant.now();
        if (Objects.isNull(threeDFileId)) {
            LOG.warn("{} No 3D file id specified in the request. Will skip the download request.", loggingPrefix);
            return null;
        }

        ThreeDFileBinary fileBinary = downloadFileBinary(threeDFileId, downloadPath.toUri(), !preferByteStream);

        LOG.info(loggingPrefix + "Successfully downloaded 3D file with id {} within a duration of {}.",
                threeDFileId,
                Duration.between(startInstant, Instant.now()).toString());

        return fileBinary;
    }

    @NotNull
    private String getLoggingPrefix() {
        String loggingPrefix = "download() - " + RandomStringUtils.randomAlphanumeric(5) + " - ";
        return loggingPrefix;
    }

    /**
     * Downloads 3D file binaries.
     *
     * This method is intended for advanced use cases, for example when using this SDK as a part of
     * a distributed system.
     *
     * Downloads a set of 3D file binaries based on {@code id}. The 3d file
     * binaries can be downloaded as files or byte streams. In case the file is very large (> 200MB) it has to
     * be streamed directly to the file system (to the temp storage area).
     *
     * Supported temp storage for the file binary:
     * - Local (network) disk. Specify the temp path as {@code file:////}.
     * Examples: {@code file://localhost/home/files/, file:///home/files/, file:///c:/temp/}
     * - Google Cloud Storage. Specify the temp path as {@code gs:////}.
     *
     * @param threeDFileId The id of the 3D file to download.
     * @param tempStoragePath The URI to the download storage. Set to null to only perform in-memory download.
     * @param forceTempStorage Set to true to always download the binary to temp storage
     * @return The file binary.
     * @throws Exception
     */
    public ThreeDFileBinary downloadFileBinary(final Long threeDFileId,
                                               @Nullable final URI tempStoragePath,
                                               final boolean forceTempStorage) throws Exception {
        final int MAX_RETRIES = 3;
        String loggingPrefix = "downloadFileBinaries() - " + RandomStringUtils.randomAlphanumeric(5) + " - ";
        Preconditions.checkArgument(!(null == tempStoragePath && forceTempStorage),
                "Illegal parameter combination. You must specify a URI in order to force temp storage.");

        Instant startInstant = Instant.now();
        // do not send empty requests.
        if (Objects.isNull(threeDFileId)) {
            LOG.warn("{} No 3D file id specified in the request. Will skip the download request.", loggingPrefix);
            return null;
        }

        LOG.debug(loggingPrefix + "Start downloading 3D file with id {} at {}", threeDFileId, startInstant);

        /** Download file **/
        ThreeDFileBinary downloadResponse =
                executeFileBinariesDownload(threeDFileId, tempStoragePath, forceTempStorage);

        LOG.debug("{} Completed download 3D file with id {} at {}", loggingPrefix, threeDFileId, startInstant);

        return downloadResponse;
    }


    private ThreeDFileBinary executeFileBinariesDownload(Long threeDFileId,
                                                   @Nullable URI tempStoragePath,
                                                   boolean forceTempStorage) throws Exception {
        // Set up the download service
        ConnectorServiceV1.ThreeDFileBinaryReader reader = getClient().getConnectorService().readThreeDFileBinariesById()
                .enableForceTempStorage(forceTempStorage);

        if (null != tempStoragePath) {
            reader = reader.withTempStoragePath(tempStoragePath);
        }

        Request request = addAuthInfo(Request.create().withRootParameter("id", threeDFileId));

        return reader.readThreeDFileBinaries(request);
    }

    private static ThreeDFiles.Builder builder() {
        return new AutoValue_ThreeDFiles.Builder();
    }

    /**
     * Constructs a new {@link ThreeDFiles} object using the provided client configuration.
     *
     * This method is intended for internal use--SDK clients should always use {@link CogniteClient}
     * as the entry point to this class.
     *
     * @param client The {@link CogniteClient} to use for configuration settings.
     * @return the assets api object.
     */
    public static ThreeDFiles of(CogniteClient client) {
        return ThreeDFiles.builder()
                .setClient(client)
                .build();
    }

    @AutoValue.Builder
    abstract static class Builder extends ApiBase.Builder {
        abstract ThreeDFiles build();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy