// Copyright © 2015 HSL <https://www.hsl.fi>
// This program is dual-licensed under the EUPL v1.2 and AGPLv3 licenses.
package fi.hsl.parkandride.back;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Types;
import javax.annotation.Nullable;
import org.geolatte.geom.ByteBuffer;
import org.geolatte.geom.ByteOrder;
import org.geolatte.geom.Geometry;
import org.geolatte.geom.codec.Wkb;
import org.geolatte.geom.codec.WkbDecoder;
import org.geolatte.geom.codec.WkbEncoder;
import org.geolatte.geom.codec.Wkt;
import com.querydsl.sql.types.AbstractType;
public class H2GeometryType<T extends Geometry> extends AbstractType<T> {
private final ByteOrder byteOrder = ByteOrder.NDR;
private final Class<T> type;
public H2GeometryType(Class<T> type) {
super(Types.BLOB);
this.type = type;
}
@Override
public Class<T> getReturnedClass() {
return type;
}
@Override
@Nullable
public T getValue(ResultSet rs, int startIndex) throws SQLException {
byte[] bytes = rs.getBytes(startIndex);
if (bytes != null) {
byte[] wkb;
if (bytes[0] != 0 && bytes[0] != 1) { // decodes EWKB
wkb = new byte[bytes.length - 32];
System.arraycopy(bytes, 32, wkb, 0, wkb.length);
} else {
wkb = bytes;
}
WkbDecoder decoder = Wkb.newDecoder(Wkb.Dialect.POSTGIS_EWKB_1);
return (T) decoder.decode(ByteBuffer.from(wkb));
} else {
return null;
}
}
@Override
public void setValue(PreparedStatement st, int startIndex, T value) throws SQLException {
WkbEncoder encoder = Wkb.newEncoder(Wkb.Dialect.POSTGIS_EWKB_1);
ByteBuffer buffer = encoder.encode(value, byteOrder);
st.setBytes(startIndex, buffer.toByteArray());
}
@Override
public String getLiteral(T geometry) {
String str = Wkt.newEncoder(Wkt.Dialect.POSTGIS_EWKT_1).encode(geometry);
if (geometry.getSRID() > -1) {
return "ST_GeomFromText('" + str + "', " + geometry.getSRID() + ")";
} else {
return "ST_GeomFromText('" + str + "')";
}
}
}