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

io.trino.filesystem.hdfs.HadoopPaths Maven / Gradle / Ivy

/*
 * 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 io.trino.filesystem.hdfs;

import com.google.common.base.VerifyException;
import io.trino.filesystem.Location;
import org.apache.hadoop.fs.Path;

import java.net.URI;
import java.net.URISyntaxException;

public final class HadoopPaths
{
    private HadoopPaths() {}

    public static Path hadoopPath(Location location)
    {
        // hack to preserve the original path for S3 if necessary
        String path = location.toString();
        Path hadoopPath = new Path(path);
        if ("s3".equals(hadoopPath.toUri().getScheme()) && !path.equals(hadoopPath.toString())) {
            return new Path(toPathEncodedUri(location));
        }
        return hadoopPath;
    }

    private static URI toPathEncodedUri(Location location)
    {
        try {
            return new URI(
                    location.scheme().orElse(null),
                    location.host().orElse(null),
                    "/" + location.path(),
                    null,
                    location.path());
        }
        catch (URISyntaxException e) {
            throw new VerifyException("Failed to convert location to URI: " + location, e);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy