de.fraunhofer.iosb.ilt.frostserver.persistence.pgjooq.fieldwrapper.StaTimeIntervalWrapper Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of FROST-Server.SQLjooq Show documentation
Show all versions of FROST-Server.SQLjooq Show documentation
SQL bindings for the FROST-Server.
/*
* Copyright (C) 2024 Fraunhofer Institut IOSB, Fraunhoferstr. 1, D 76131
* Karlsruhe, Germany.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program. If not, see .
*/
package de.fraunhofer.iosb.ilt.frostserver.persistence.pgjooq.fieldwrapper;
import static de.fraunhofer.iosb.ilt.frostserver.persistence.pgjooq.utils.Utils.INTERVAL_PARAM;
import de.fraunhofer.iosb.ilt.frostserver.persistence.pgjooq.bindings.MomentBinding;
import de.fraunhofer.iosb.ilt.frostserver.property.type.TypeComplex;
import java.util.Map;
import net.time4j.Moment;
import org.jooq.Condition;
import org.jooq.Field;
import org.jooq.impl.DSL;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Some paths point to time-intervals that return two column references. If the
* references include a start and end time, they are treated as a time interval.
*/
public class StaTimeIntervalWrapper implements TimeFieldWrapper {
private static final Logger LOGGER = LoggerFactory.getLogger(StaTimeIntervalWrapper.class.getName());
public static final String KEY_TIME_INTERVAL_START = TypeComplex.NAME_INTERVAL_START;
public static final String KEY_TIME_INTERVAL_END = TypeComplex.NAME_INTERVAL_END;
private static final String INCOMPATIBLE_OP = "Incompatible operator: Interval '";
/**
* Flag indicating that the original time given was in UTC.
*/
private static final boolean UTC = true;
private final Field start;
private final Field end;
public StaTimeIntervalWrapper(Map expressions) {
this.start = expressions.get(KEY_TIME_INTERVAL_START);
this.end = expressions.get(KEY_TIME_INTERVAL_END);
}
public StaTimeIntervalWrapper(Field start, Field end) {
this.start = start;
this.end = end;
}
public StaTimeIntervalWrapper(Moment start, Moment end) {
this.start = DSL.inline(start, MomentBinding.dataType());
this.end = DSL.inline(end, MomentBinding.dataType());
}
public Field getStart() {
return start;
}
public Field getEnd() {
return end;
}
@Override
public Field getDefaultField() {
return getStart();
}
@Override
public Field getFieldAsType(Class expectedClazz, boolean canCast) {
Class fieldType = start.getType();
if (expectedClazz.isAssignableFrom(fieldType)) {
return (Field) start;
}
if (canCast && expectedClazz == String.class) {
return (Field) start.cast(String.class);
}
LOGGER.debug("Not a {}: {} ({} -- {})", expectedClazz.getName(), start, start.getClass().getName(), fieldType.getName());
return null;
}
@Override
public Field getDateTime() {
return getStart();
}
@Override
public boolean isUtc() {
return UTC;
}
private FieldWrapper specificOp(String op, StaDurationWrapper other) {
switch (op) {
case "+":
case "-":
String template = "(? " + op + " " + INTERVAL_PARAM + ")";
return new StaTimeIntervalWrapper(
DSL.field(template, MomentBinding.dataType(), start, other.getDuration()),
DSL.field(template, MomentBinding.dataType(), end, other.getDuration()));
default:
throw new UnsupportedOperationException(INCOMPATIBLE_OP + op + "' " + other.getClass().getName());
}
}
private FieldWrapper specificOp(String op, StaDateTimeWrapper other) {
if ("-".equals(op)) {
// We calculate with the start time and return a duration.
return new StaDurationWrapper(start, other.getDateTime());
}
throw new UnsupportedOperationException(INCOMPATIBLE_OP + op + "' " + other.getClass().getName());
}
private FieldWrapper specificOp(String op, StaTimeIntervalWrapper other) {
if ("-".equals(op)) {
// We calculate with the start time and return a duration.
return new StaDurationWrapper(start, other.start);
} else {
throw new UnsupportedOperationException(INCOMPATIBLE_OP + op + "' " + other.getClass().getName());
}
}
@Override
public FieldWrapper simpleOp(String op, FieldWrapper other) {
if (other instanceof StaDurationWrapper staDurationWrapper) {
return specificOp(op, staDurationWrapper);
}
if (other instanceof StaDateTimeWrapper staDateTimeWrapper) {
return specificOp(op, staDateTimeWrapper);
}
if (other instanceof StaTimeIntervalWrapper staTimeIntervalWrapper) {
return specificOp(op, staTimeIntervalWrapper);
}
throw new UnsupportedOperationException("Can not add, sub, mul or div with Duration and " + other.getClass().getName());
}
private Condition specificOpBool(String op, StaDateTimeWrapper other) {
Field s1 = start;
Field e1 = end;
Field t2 = other.getDateTime();
switch (op) {
case "=":
return s1.equal(t2).and(e1.equal(t2));
case "!=":
return s1.notEqual(t2).and(e1.notEqual(t2));
case ">":
return s1.greaterThan(t2);
case ">=":
return s1.greaterOrEqual(t2);
case "<":
return e1.lessOrEqual(t2).and(s1.lessThan(t2));
case "<=":
return e1.lessOrEqual(t2);
case "a":
return s1.greaterThan(t2);
case "b":
return e1.lessOrEqual(t2).and(s1.lessThan(t2));
case "c":
return s1.lessOrEqual(t2).and(e1.greaterThan(t2));
case "m":
return s1.equal(t2).or(e1.equal(t2));
case "o":
return s1.equal(t2).or(s1.lessOrEqual(t2).and(e1.greaterThan(t2)));
case "s":
return s1.equal(t2);
case "f":
return e1.equal(t2);
default:
throw new UnsupportedOperationException("Unknown boolean operation: " + op);
}
}
private Condition specificOpBool(String op, StaTimeIntervalWrapper other) {
Field s1 = start;
Field e1 = end;
Field s2 = other.getStart();
Field e2 = other.getEnd();
switch (op) {
case "=":
return s1.equal(s2).and(e1.equal(e2));
case "!=":
return s1.notEqual(s2).and(e1.notEqual(e2));
case ">":
return s1.greaterOrEqual(e2).and(s1.greaterThan(s2));
case ">=":
return s1.greaterOrEqual(s2).and(e1.greaterOrEqual(e2));
case "<":
return e1.lessOrEqual(s2).and(s1.lessThan(s2));
case "<=":
return s1.lessOrEqual(s2).and(e1.lessOrEqual(e2));
case "a":
return s1.greaterOrEqual(e2).and(s1.greaterThan(s2));
case "b":
return e1.lessOrEqual(s2).and(s1.lessThan(s2));
case "c":
return s1.lessOrEqual(s2).and(e1.greaterThan(s2)).and(e1.greaterOrEqual(e2));
case "m":
return s1.equal(e2).or(e1.equal(s2));
case "o":
return s1.greaterOrEqual(e2).or(s2.greaterOrEqual(e1)).not().or(s1.equal(s2));
case "s":
return s1.equal(s2);
case "f":
return e1.equal(e2);
default:
throw new UnsupportedOperationException("Unknown boolean operation: " + op);
}
}
@Override
public FieldWrapper simpleOpBool(String op, FieldWrapper other) {
if (other instanceof StaDateTimeWrapper staDateTimeWrapper) {
return new SimpleFieldWrapper(
specificOpBool(op, staDateTimeWrapper));
}
if (other instanceof StaTimeIntervalWrapper staTimeIntervalWrapper) {
return new SimpleFieldWrapper(
specificOpBool(op, staTimeIntervalWrapper));
}
throw new UnsupportedOperationException("Can not compare between Duration and " + other.getClass().getName());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy