mirror of https://github.com/apache/archiva.git
add new classes
git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1542900 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
8553f7687f
commit
a4c7b97e8d
|
@ -0,0 +1,64 @@
|
|||
package org.apache.archiva.metadata.repository.cassandra;
|
||||
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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.
|
||||
*/
|
||||
|
||||
/**
|
||||
* @author Olivier Lamy
|
||||
*/
|
||||
public class CassandraUtils
|
||||
{
|
||||
|
||||
private static final String EMPTY_VALUE = "";
|
||||
|
||||
public static final String SEPARATOR = "->";
|
||||
|
||||
public static String generateKey( final String... bases )
|
||||
{
|
||||
final StringBuilder builder = new StringBuilder();
|
||||
if ( bases == null || bases.length == 0 )
|
||||
{
|
||||
return builder.toString();
|
||||
}
|
||||
|
||||
for ( final String s : bases )
|
||||
{
|
||||
if ( s != null )
|
||||
{
|
||||
builder.append( s );
|
||||
}
|
||||
else
|
||||
{
|
||||
builder.append( EMPTY_VALUE );
|
||||
}
|
||||
builder.append( SEPARATOR );
|
||||
}
|
||||
if ( builder.length() > 0 )
|
||||
{
|
||||
builder.setLength( builder.length() - SEPARATOR.length() );
|
||||
}
|
||||
return builder.toString();
|
||||
}
|
||||
|
||||
private CassandraUtils()
|
||||
{
|
||||
// no-op
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,191 @@
|
|||
package org.apache.archiva.metadata.repository.cassandra.model;
|
||||
|
||||
/*
|
||||
* Licensed to the Apache Software Foundation (ASF) under one
|
||||
* or more contributor license agreements. See the NOTICE file
|
||||
* distributed with this work for additional information
|
||||
* regarding copyright ownership. The ASF licenses this file
|
||||
* to you 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.
|
||||
*/
|
||||
|
||||
|
||||
import com.netflix.astyanax.serializers.AbstractSerializer;
|
||||
import com.netflix.astyanax.serializers.ComparatorType;
|
||||
import org.apache.cassandra.db.marshal.UTF8Type;
|
||||
import org.apache.commons.codec.binary.StringUtils;
|
||||
import org.apache.commons.io.IOUtils;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
|
||||
import java.io.ByteArrayInputStream;
|
||||
import java.io.ByteArrayOutputStream;
|
||||
import java.io.IOException;
|
||||
import java.nio.ByteBuffer;
|
||||
import java.nio.charset.Charset;
|
||||
import java.util.zip.Deflater;
|
||||
import java.util.zip.DeflaterInputStream;
|
||||
import java.util.zip.DeflaterOutputStream;
|
||||
import java.util.zip.InflaterInputStream;
|
||||
|
||||
|
||||
/**
|
||||
* For Huge String we use a compression
|
||||
* @author Olivier Lamy
|
||||
*/
|
||||
public class HugeStringSerializer
|
||||
extends AbstractSerializer<String>
|
||||
{
|
||||
|
||||
private Logger logger = LoggerFactory.getLogger( getClass() );
|
||||
|
||||
private static final String UTF_8 = "UTF-8";
|
||||
|
||||
private static final HugeStringSerializer instance = new HugeStringSerializer();
|
||||
|
||||
private static final Charset charset = Charset.forName( UTF_8 );
|
||||
|
||||
public static HugeStringSerializer get()
|
||||
{
|
||||
return instance;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ByteBuffer toByteBuffer( String obj )
|
||||
{
|
||||
if ( obj == null )
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
byte[] bytes = compressWithDeflate( StringUtils.getBytesUtf8( obj ) );
|
||||
return ByteBuffer.wrap( bytes );
|
||||
}
|
||||
catch ( IOException e )
|
||||
{
|
||||
throw new RuntimeException( "Fail to compress column data", e );
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public String fromByteBuffer( ByteBuffer byteBuffer )
|
||||
{
|
||||
if ( byteBuffer == null )
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
ByteBuffer dup = byteBuffer.duplicate();
|
||||
try
|
||||
{
|
||||
String str = getFromDeflateBytes( dup.array() );
|
||||
return str;
|
||||
}
|
||||
catch ( IOException e )
|
||||
{
|
||||
throw new RuntimeException( "Fail to decompress column data", e );
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public String getFromDeflateBytes( byte[] bytes )
|
||||
throws IOException
|
||||
{
|
||||
ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream( bytes );
|
||||
InflaterInputStream inflaterInputStream = new InflaterInputStream( byteArrayInputStream );
|
||||
return IOUtils.toString( inflaterInputStream );
|
||||
}
|
||||
|
||||
public byte[] compressWithDeflate( byte[] unCompress )
|
||||
throws IOException
|
||||
{
|
||||
try
|
||||
{
|
||||
ByteArrayOutputStream buffer = new ByteArrayOutputStream();
|
||||
DeflaterOutputStream out = new DeflaterOutputStream( buffer, new Deflater( Deflater.BEST_COMPRESSION ) );
|
||||
out.write( unCompress );
|
||||
out.finish();
|
||||
ByteArrayInputStream bais = new ByteArrayInputStream( buffer.toByteArray() );
|
||||
byte[] res = IOUtils.toByteArray( bais );
|
||||
return res;
|
||||
}
|
||||
catch ( IOException e )
|
||||
{
|
||||
logger.debug( "IOException in compressStringWithDeflate", e );
|
||||
throw e;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public ComparatorType getComparatorType()
|
||||
{
|
||||
return ComparatorType.BYTESTYPE;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ByteBuffer fromString( String str )
|
||||
{
|
||||
return instance.fromString( str );
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getString( ByteBuffer byteBuffer )
|
||||
{
|
||||
return instance.getString( byteBuffer );
|
||||
}
|
||||
|
||||
/*
|
||||
private static final String UTF_8 = "UTF-8";
|
||||
private static final HugeStringSerializer instance = new HugeStringSerializer();
|
||||
private static final Charset charset = Charset.forName(UTF_8);
|
||||
|
||||
public static HugeStringSerializer get() {
|
||||
return instance;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ByteBuffer toByteBuffer(String obj) {
|
||||
if (obj == null) {
|
||||
return null;
|
||||
}
|
||||
return ByteBuffer.wrap(obj.getBytes(charset));
|
||||
}
|
||||
|
||||
@Override
|
||||
public String fromByteBuffer(ByteBuffer byteBuffer) {
|
||||
if (byteBuffer == null) {
|
||||
return null;
|
||||
}
|
||||
final ByteBuffer dup = byteBuffer.duplicate();
|
||||
return charset.decode(dup).toString();
|
||||
}
|
||||
|
||||
@Override
|
||||
public ComparatorType getComparatorType() {
|
||||
return ComparatorType.UTF8TYPE;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ByteBuffer fromString(String str) {
|
||||
return UTF8Type.instance.fromString(str);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getString(ByteBuffer byteBuffer) {
|
||||
return UTF8Type.instance.getString(byteBuffer);
|
||||
}
|
||||
*/
|
||||
}
|
Loading…
Reference in New Issue