Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.netflix.astyanax.AbstractColumnListMutation Maven / Gradle / Ivy
/*******************************************************************************
* Copyright 2011 Netflix
*
* 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.netflix.astyanax;
import com.google.common.base.Preconditions;
import com.netflix.astyanax.serializers.*;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.nio.ByteBuffer;
import java.util.Date;
import java.util.UUID;
import java.util.zip.GZIPOutputStream;
import org.apache.commons.codec.binary.StringUtils;
/**
* Abstract implementation of a row mutation
*
* @author lucky
*
* @param
*/
public abstract class AbstractColumnListMutation implements ColumnListMutation {
protected long timestamp;
protected Integer defaultTtl = null;
public AbstractColumnListMutation(long timestamp) {
this.timestamp = timestamp;
}
@Override
public ColumnListMutation putColumn(C columnName, String value, Integer ttl) {
return putColumn(columnName, value, StringSerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final String value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, String value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, String value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putColumn(C columnName, byte[] value, Integer ttl) {
return putColumn(columnName, value, BytesArraySerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, V value, Serializer valueSerializer, Integer ttl) {
if (value == null)
return this;
return putColumn(columnName, value, valueSerializer, ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final byte[] value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, byte[] value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, byte[] value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putColumn(C columnName, byte value, Integer ttl) {
return putColumn(columnName, value, ByteSerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final byte value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Byte value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Byte value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumn(C columnName, short value, Integer ttl) {
return putColumn(columnName, value, ShortSerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final short value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Short value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Short value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumn(C columnName, int value, Integer ttl) {
return putColumn(columnName, value, IntegerSerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final int value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Integer value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Integer value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putColumn(C columnName, long value, Integer ttl) {
return putColumn(columnName, value, LongSerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final long value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Long value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Long value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putColumn(C columnName, boolean value, Integer ttl) {
return putColumn(columnName, value, BooleanSerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final boolean value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Boolean value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Boolean value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putColumn(C columnName, ByteBuffer value, Integer ttl) {
return putColumn(columnName, value, ByteBufferSerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final ByteBuffer value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, ByteBuffer value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, ByteBuffer value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putColumn(C columnName, Date value, Integer ttl) {
return putColumn(columnName, value, DateSerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final Date value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Date value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Date value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putColumn(C columnName, float value, Integer ttl) {
return putColumn(columnName, value, FloatSerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final float value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Float value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Float value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putColumn(C columnName, double value, Integer ttl) {
return putColumn(columnName, value, DoubleSerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final double value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Double value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, Double value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putColumn(C columnName, UUID value, Integer ttl) {
return putColumn(columnName, value, UUIDSerializer.get(), ttl);
}
@Override
public ColumnListMutation putColumn(final C columnName, final UUID value) {
return putColumn(columnName, value, null);
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, UUID value) {
if (value != null) {
return putColumn(columnName, value);
}
return this;
}
@Override
public ColumnListMutation putColumnIfNotNull(C columnName, UUID value, Integer ttl) {
if (value != null) {
return putColumn(columnName, value, ttl);
}
return this;
}
@Override
public ColumnListMutation putEmptyColumn(final C columnName) {
return putEmptyColumn(columnName, null);
}
@Override
public ColumnListMutation setTimestamp(long timestamp) {
this.timestamp = timestamp;
return this;
}
@Override
public ColumnListMutation setDefaultTtl(Integer ttl) {
this.defaultTtl = ttl;
return this;
}
@Override
public ColumnListMutation putCompressedColumn(C columnName, String value, Integer ttl) {
Preconditions.checkNotNull(value, "Can't insert null value");
if (value == null) {
putEmptyColumn(columnName, ttl);
return this;
}
ByteArrayOutputStream out = new ByteArrayOutputStream();
GZIPOutputStream gzip;
try {
gzip = new GZIPOutputStream(out);
gzip.write(StringUtils.getBytesUtf8(value));
gzip.close();
return this.putColumn(columnName, ByteBuffer.wrap(out.toByteArray()), ttl);
} catch (IOException e) {
throw new RuntimeException("Error compressing column " + columnName, e);
}
}
@Override
public ColumnListMutation putCompressedColumn(C columnName, String value) {
return putCompressedColumn(columnName, value, null);
}
@Override
public ColumnListMutation putCompressedColumnIfNotNull(C columnName, String value, Integer ttl) {
if (value == null)
return this;
return putCompressedColumn(columnName, value, ttl);
}
@Override
public ColumnListMutation putCompressedColumnIfNotNull(C columnName, String value) {
if (value == null)
return this;
return putCompressedColumn(columnName, value);
}
public Integer getDefaultTtl() {
return defaultTtl;
}
public long getTimestamp() {
return timestamp;
}
}