Skip to content

Commit

Permalink
Fixed MultiDatastream not picking up ID type of Thing and Sensor
Browse files Browse the repository at this point in the history
  • Loading branch information
hylkevds committed Jul 10, 2024
1 parent e3cef0d commit 06e24cf
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 5 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@
* Fixed $select not properly working on unitOfMeasurement sub-properties.
* Fixed #1934, incorrect URL parameter in docs.
* Changed header handling to allow for duplicate headers.
* Fixed MultiDatastream not picking up ID type of Thing and Sensor.


## Release version 2.3.0
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@
import de.fraunhofer.iosb.ilt.frostserver.persistence.PersistenceManagerFactory;
import de.fraunhofer.iosb.ilt.frostserver.persistence.pgjooq.JooqPersistenceManager;
import de.fraunhofer.iosb.ilt.frostserver.persistence.pgjooq.tables.TableCollection;
import de.fraunhofer.iosb.ilt.frostserver.plugin.coremodel.CoreModelSettings;
import de.fraunhofer.iosb.ilt.frostserver.plugin.coremodel.PluginCoreModel;
import de.fraunhofer.iosb.ilt.frostserver.property.EntityPropertyMain;
import de.fraunhofer.iosb.ilt.frostserver.property.NavigationPropertyMain.NavigationPropertyEntity;
Expand Down Expand Up @@ -94,6 +95,7 @@ public class PluginMultiDatastream implements PluginRootDocument, PluginModel, C

private CoreSettings settings;
private MdsModelSettings modelSettings;
private CoreModelSettings coreModelSettings;
private boolean enabled;
private boolean fullyInitialised;

Expand All @@ -104,6 +106,7 @@ public InitResult init(CoreSettings settings) {
enabled = pluginSettings.getBoolean(MdsModelSettings.TAG_ENABLE_MDS_MODEL, MdsModelSettings.class);
if (enabled) {
modelSettings = new MdsModelSettings(settings);
coreModelSettings = new CoreModelSettings(settings);
settings.getPluginManager().registerPlugin(this);
}
return InitResult.INIT_OK;
Expand Down Expand Up @@ -221,9 +224,11 @@ public boolean linkEntityTypes(PersistenceManager pm) {

if (pm instanceof JooqPersistenceManager ppm) {
final TableCollection tableCollection = ppm.getTableCollection();
final DataType dataTypeSnsr = ppm.getDataTypeFor(coreModelSettings.idTypeSensor);
final DataType dataTypeThng = ppm.getDataTypeFor(coreModelSettings.idTypeThing);
final DataType dataTypeMds = ppm.getDataTypeFor(modelSettings.idTypeMultiDatastream);
final DataType dataTypeObsProp = tableCollection.getTableForType(pluginCoreModel.etObservedProperty).getPkFields().get(0).getDataType();
tableCollection.registerTable(etMultiDatastream, new TableImpMultiDatastreams(dataTypeMds, this, pluginCoreModel));
tableCollection.registerTable(etMultiDatastream, new TableImpMultiDatastreams(dataTypeMds, dataTypeSnsr, dataTypeThng, this, pluginCoreModel));
tableCollection.registerTable(new TableImpMultiDatastreamsObsProperties(dataTypeMds, dataTypeObsProp));
}
fullyInitialised = true;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -137,17 +137,17 @@ public class TableImpMultiDatastreams extends StaTableAbstract<TableImpMultiData
/**
* The column <code>public.MULTI_DATASTREAMS.ID</code>.
*/
public final TableField<Record, ?> colId = createField(DSL.name("ID"), getIdType(), this);
public final TableField<Record, ?> colId = createField(DSL.name("ID"), getIdType().nullable(false), this);

/**
* The column <code>public.MULTI_DATASTREAMS.SENSOR_ID</code>.
*/
public final TableField<Record, ?> colSensorId = createField(DSL.name("SENSOR_ID"), getIdType(), this);
public final TableField<Record, ?> colSensorId;

/**
* The column <code>public.MULTI_DATASTREAMS.THING_ID</code>.
*/
public final TableField<Record, ?> colThingId = createField(DSL.name("THING_ID"), getIdType(), this);
public final TableField<Record, ?> colThingId;

private final transient PluginMultiDatastream pluginMultiDatastream;
private final transient PluginCoreModel pluginCoreModel;
Expand All @@ -157,13 +157,19 @@ public class TableImpMultiDatastreams extends StaTableAbstract<TableImpMultiData
*
* @param idType The (SQL)DataType of the Id columns used in the actual
* database.
* @param idTypeSnsr The (SQL)DataType of the SENSOR_ID column used in the
* database.
* @param idTypeTng The (SQL)DataType of the THING_ID column used in the
* database.
* @param pMultiDs the multiDatastream plugin this table belongs to.
* @param pCoreModel the coreModel plugin that this data model links to.
*/
public TableImpMultiDatastreams(DataType<?> idType, PluginMultiDatastream pMultiDs, PluginCoreModel pCoreModel) {
public TableImpMultiDatastreams(DataType<?> idType, DataType<?> idTypeSnsr, DataType<?> idTypeTng, PluginMultiDatastream pMultiDs, PluginCoreModel pCoreModel) {
super(idType, DSL.name("MULTI_DATASTREAMS"), null, null);
this.pluginMultiDatastream = pMultiDs;
this.pluginCoreModel = pCoreModel;
colSensorId = createField(DSL.name("SENSOR_ID"), idTypeSnsr.nullable(false));
colThingId = createField(DSL.name("THING_ID"), idTypeTng.nullable(false));
}

private TableImpMultiDatastreams(Name alias, TableImpMultiDatastreams aliased, PluginMultiDatastream pMultiDs, PluginCoreModel pCoreModel) {
Expand All @@ -174,6 +180,8 @@ private TableImpMultiDatastreams(Name alias, TableImpMultiDatastreams aliased, T
super(aliased.getIdType(), alias, aliased, updatedSql);
this.pluginMultiDatastream = pMultiDs;
this.pluginCoreModel = pCoreModel;
colSensorId = createField(DSL.name("SENSOR_ID"), aliased.colSensorId.getDataType().nullable(false));
colThingId = createField(DSL.name("THING_ID"), aliased.colThingId.getDataType().nullable(false));
}

@Override
Expand Down

0 comments on commit 06e24cf

Please sign in to comment.