io.trino.metastore.Storage 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.metastore;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.google.common.collect.ImmutableMap;
import com.google.errorprone.annotations.Immutable;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
import static com.google.common.base.MoreObjects.toStringHelper;
import static java.util.Objects.requireNonNull;
@Immutable
public class Storage
{
private final StorageFormat storageFormat;
private final Optional location;
private final Optional bucketProperty;
private final boolean skewed;
private final Map serdeParameters;
@JsonCreator
public Storage(
@JsonProperty("storageFormat") StorageFormat storageFormat,
@JsonProperty("location") Optional location,
@JsonProperty("bucketProperty") Optional bucketProperty,
@JsonProperty("skewed") boolean skewed,
@JsonProperty("serdeParameters") Map serdeParameters)
{
this.storageFormat = requireNonNull(storageFormat, "storageFormat is null");
this.location = requireNonNull(location, "location is null");
this.bucketProperty = requireNonNull(bucketProperty, "bucketProperty is null");
this.skewed = skewed;
this.serdeParameters = ImmutableMap.copyOf(requireNonNull(serdeParameters, "serdeParameters is null"));
}
@JsonProperty
public StorageFormat getStorageFormat()
{
return storageFormat;
}
@JsonProperty("location")
public Optional getOptionalLocation()
{
return location;
}
public String getLocation()
{
// Default getter requires location to be set. Location is not set in the following scenarios:
// 1. CREATE TABLE flow in Hive connector sets delegate-transactional-managed-table-location-to-metastore to true and location is determined by HMS.
// 2. Iceberg format tables
// 3. Delta format tables (sometimes)
return location.orElseThrow();
}
@JsonProperty
public Optional getBucketProperty()
{
return bucketProperty;
}
@JsonProperty
public boolean isSkewed()
{
return skewed;
}
@JsonProperty
public Map getSerdeParameters()
{
return serdeParameters;
}
@Override
public String toString()
{
return toStringHelper(this)
.add("skewed", skewed)
.add("storageFormat", storageFormat)
.add("location", location)
.add("bucketProperty", bucketProperty)
.add("serdeParameters", serdeParameters)
.toString();
}
@Override
public boolean equals(Object o)
{
if (this == o) {
return true;
}
if (o == null || getClass() != o.getClass()) {
return false;
}
Storage storage = (Storage) o;
return skewed == storage.skewed &&
Objects.equals(storageFormat, storage.storageFormat) &&
Objects.equals(location, storage.location) &&
Objects.equals(bucketProperty, storage.bucketProperty) &&
Objects.equals(serdeParameters, storage.serdeParameters);
}
@Override
public int hashCode()
{
return Objects.hash(skewed, storageFormat, location, bucketProperty, serdeParameters);
}
public static Builder builder()
{
return new Builder();
}
public static Builder builder(Storage storage)
{
return new Builder(storage);
}
public static class Builder
{
private StorageFormat storageFormat;
private Optional location = Optional.empty();
private Optional bucketProperty = Optional.empty();
private boolean skewed;
private Map serdeParameters = ImmutableMap.of();
private Builder() {}
private Builder(Storage storage)
{
this.storageFormat = storage.storageFormat;
this.location = storage.location;
this.bucketProperty = storage.bucketProperty;
this.skewed = storage.skewed;
this.serdeParameters = storage.serdeParameters;
}
public Builder setStorageFormat(StorageFormat storageFormat)
{
this.storageFormat = storageFormat;
return this;
}
public Builder setLocation(Optional location)
{
this.location = location;
return this;
}
public Builder setLocation(String location)
{
this.location = Optional.of(location);
return this;
}
public Builder setBucketProperty(HiveBucketProperty bucketProperty)
{
this.bucketProperty = Optional.of(bucketProperty);
return this;
}
public Builder setBucketProperty(Optional bucketProperty)
{
this.bucketProperty = bucketProperty;
return this;
}
public Builder setSkewed(boolean skewed)
{
this.skewed = skewed;
return this;
}
public Builder setSerdeParameters(Map serdeParameters)
{
this.serdeParameters = serdeParameters;
return this;
}
public Storage build()
{
return new Storage(storageFormat, location, bucketProperty, skewed, serdeParameters);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy