Search in sources :

Example 1 with PlatformEntity

use of org.n52.series.db.beans.PlatformEntity in project SOS by 52North.

the class PlatformDAO method getPlatformForIdentifier.

public PlatformEntity getPlatformForIdentifier(String identifier, Session session) {
    Criteria criteria = session.createCriteria(PlatformEntity.class).add(Restrictions.eq(PlatformEntity.IDENTIFIER, identifier));
    LOGGER.trace("QUERY getPlatformForIdentifier(identifier): {}", HibernateHelper.getSqlString(criteria));
    return (PlatformEntity) criteria.uniqueResult();
}
Also used : PlatformEntity(org.n52.series.db.beans.PlatformEntity) Criteria(org.hibernate.Criteria)

Example 2 with PlatformEntity

use of org.n52.series.db.beans.PlatformEntity in project SOS by 52North.

the class PlatformDAO method getOrInsertPlatform.

public PlatformEntity getOrInsertPlatform(String value, Session session) {
    PlatformEntity platform = getPlatformForIdentifier(value, session);
    if (platform == null) {
        platform = new PlatformEntity();
        addIdentifier(platform, value, session);
        addName(platform, value, session);
        session.save(platform);
        session.flush();
        session.refresh(platform);
    }
    return platform;
}
Also used : PlatformEntity(org.n52.series.db.beans.PlatformEntity)

Example 3 with PlatformEntity

use of org.n52.series.db.beans.PlatformEntity in project SOS by 52North.

the class PlatformDAO method getOrInsertHistoricalLocation.

private HistoricalLocationEntity getOrInsertHistoricalLocation(PlatformEntity platform, LocationEntity location, Session session) {
    HistoricalLocationEntity historicalLocation = new HistoricalLocationEntity();
    historicalLocation.setIdentifier(UUID.randomUUID().toString(), getDaoFactory().isStaSupportsUrls());
    historicalLocation.setThing(platform);
    historicalLocation.setTime(DateTime.now().toDate());
    session.save(historicalLocation);
    session.flush();
    session.refresh(historicalLocation);
    location.addHistoricalLocation(historicalLocation);
    session.saveOrUpdate(location);
    session.flush();
    return historicalLocation;
}
Also used : HistoricalLocationEntity(org.n52.series.db.beans.sta.HistoricalLocationEntity)

Example 4 with PlatformEntity

use of org.n52.series.db.beans.PlatformEntity in project SOS by 52North.

the class HibernateObservationUtilitiesTest method createSubObservationOfSweArrayObservationViaGetObservationById.

@Test
public // present
void createSubObservationOfSweArrayObservationViaGetObservationById() throws OwsExceptionReport, ConnectionProviderException, ConverterException {
    // PREPARE
    Session session = getSession();
    try {
        Transaction transaction = session.beginTransaction();
        GetObservationByIdRequest request = new GetObservationByIdRequest();
        request.setVersion(Sos2Constants.SERVICEVERSION);
        FormatEntity hProcedureDescriptionFormat = new FormatEntity();
        FormatEntity hFeatureOfInterestType = new FormatEntity();
        FeatureEntity hFeatureOfInterest = new FeatureEntity();
        PhenomenonEntity hObservableProperty = new PhenomenonEntity();
        CategoryEntity hCategory = new CategoryEntity();
        PlatformEntity hPlatform = new PlatformEntity();
        FormatEntity hObservationType = new FormatEntity();
        OfferingEntity hOffering = new OfferingEntity();
        DatasetEntity hObservationConstellation = new DatasetEntity();
        CodespaceEntity hCodespace = new CodespaceEntity();
        ProcedureEntity hProcedure = new ProcedureEntity();
        QuantityDataEntity hObservation = new QuantityDataEntity();
        ResultTemplateEntity hResultTemplateEntity = new ResultTemplateEntity();
        hProcedureDescriptionFormat.setFormat(PROCEDURE_DESCRIPTION_FORMAT);
        hCodespace.setName(CODESPACE);
        hProcedure.setIdentifier(PROCEDURE);
        hProcedure.setFormat(hProcedureDescriptionFormat);
        hFeatureOfInterestType.setFormat(FEATURE_OF_INTEREST_TYPE);
        hFeatureOfInterest.setIdentifier(FEATURE);
        hFeatureOfInterest.setFeatureType(hFeatureOfInterestType);
        hFeatureOfInterest.setIdentifierCodespace(hCodespace);
        hPlatform.setIdentifier(FEATURE);
        hObservableProperty.setIdentifier(OBSERVABLE_PROPERTY);
        hCategory.setIdentifier(OBSERVABLE_PROPERTY);
        hObservationType.setFormat(OmConstants.OBS_TYPE_SWE_ARRAY_OBSERVATION);
        hOffering.setIdentifier(OFFERING);
        hObservationConstellation.setProcedure(hProcedure);
        hObservationConstellation.setOffering(hOffering);
        hObservationConstellation.setObservableProperty(hObservableProperty);
        hObservationConstellation.setOmObservationType(hObservationType);
        hObservationConstellation.setFeature(hFeatureOfInterest);
        hObservationConstellation.setDeleted(false);
        hObservationConstellation.setHidden(false);
        hObservationConstellation.setCategory(hCategory);
        hObservationConstellation.setPlatform(hPlatform);
        hResultTemplateEntity.setFeature(hFeatureOfInterest);
        hResultTemplateEntity.setOffering(hOffering);
        hResultTemplateEntity.setPhenomenon(hObservableProperty);
        hResultTemplateEntity.setProcedure(hProcedure);
        hResultTemplateEntity.setIdentifier("test-rt-1");
        hResultTemplateEntity.setEncoding("<swe:TextEncoding xmlns:swe=\"http://www.opengis.net/swe/2.0\" " + "xmlns:sams=\"http://www.opengis.net/samplingSpatial/2.0\" " + "xmlns:sml=\"http://www.opengis.net/sensorML/1.0.1\" " + "xmlns:sf=\"http://www.opengis.net/sampling/2.0\" " + "xmlns:swes=\"http://www.opengis.net/swes/2.0\" " + "xmlns:sos=\"http://www.opengis.net/sos/2.0\" " + "xmlns:gml=\"http://www.opengis.net/gml/3.2\" " + "xmlns:xs=\"http://www.w3.org/2001/XMLSchema\" " + "xmlns:om=\"http://www.opengis.net/om/2.0\" " + "xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" " + "xmlns:xlink=\"http://www.w3.org/1999/xlink\" " + "tokenSeparator=\"#\" blockSeparator=\"@\"/>");
        hResultTemplateEntity.setStructure("\"<swe:DataRecord xmlns:swe=\"http://www.opengis.net/swe/2.0\" " + "xmlns:sams=\"http://www.opengis.net/samplingSpatial/2.0\" " + "xmlns:sml=\"http://www.opengis.net/sensorML/1.0.1\" " + "xmlns:sf=\"http://www.opengis.net/sampling/2.0\" " + "xmlns:swes=\"http://www.opengis.net/swes/2.0\" " + "xmlns:sos=\"http://www.opengis.net/sos/2.0\" " + "xmlns:gml=\"http://www.opengis.net/gml/3.2\" " + "xmlns:xs=\"http://www.w3.org/2001/XMLSchema\" " + "xmlns:om=\"http://www.opengis.net/om/2.0\" " + "xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" " + "xmlns:xlink=\"http://www.w3.org/1999/xlink\">\r\n" + "  <swe:field name=\"phenomenonTime\">\r\n" + "    <swe:Time definition=\"http://www.opengis.net/def/property/OGC/0/PhenomenonTime\">\r\n" + "      <swe:uom xlink:href=\"http://www.opengis.net/def/uom/ISO-8601/0/Gregorian\"/>\r\n" + "    </swe:Time>\r\n" + "  </swe:field>\r\n" + "  <swe:field name=\"Discharge\">\r\n" + "    <swe:Quantity definition=\"http://sweet.jpl.nasa.gov/2.0/hydroSurface.owl#Discharge\">\r\n" + "      <swe:uom code=\"m3\"/>\r\n" + "    </swe:Quantity>\r\n" + "  </swe:field>\r\n" + "</swe:DataRecord>\"");
        session.save(hProcedureDescriptionFormat);
        session.save(hProcedure);
        session.save(hCodespace);
        session.save(hOffering);
        session.save(hFeatureOfInterestType);
        session.save(hFeatureOfInterest);
        session.save(hPlatform);
        session.save(hObservableProperty);
        session.save(hCategory);
        session.save(hObservationType);
        session.save(hObservationConstellation);
        session.save(hResultTemplateEntity);
        session.flush();
        hObservation.setValue(BigDecimal.valueOf(1.0));
        hObservation.setSamplingTimeStart(DateTime.now().toDate());
        hObservation.setSamplingTimeEnd(hObservation.getSamplingTimeStart());
        hObservation.setResultTime(hObservation.getSamplingTimeStart());
        hObservation.setDataset(hObservationConstellation);
        hObservation.setStaIdentifier("123");
        hObservation.setDeleted(false);
        session.save(hObservation);
        transaction.commit();
        ArrayList<DataEntity<?>> observationsFromDataBase = new ArrayList<>();
        observationsFromDataBase.add(hObservation);
        SosHelper sosHelper = new SosHelper();
        sosHelper.setServiceURL(URI.create("http://test.org/"));
        DaoFactory daoFactory = new DaoFactory();
        daoFactory.setSosHelper(sosHelper);
        // CALL
        OmObservationCreatorContext ctx = new OmObservationCreatorContext(null, null, daoFactory, new ProfileHanlderMock(), Mockito.mock(AdditionalObservationCreatorRepository.class), null, new FeatureQueryHandlerMock(), null, null, null, null, null, Mockito.mock(BindingRepository.class));
        ObservationStream resultList = HibernateObservationUtilities.createSosObservationsFromObservations(observationsFromDataBase, request, Locale.ENGLISH, null, ctx, session);
        // TEST RESULTS
        assertThat(resultList, is(notNullValue()));
        assertThat(resultList.hasNext(), is(true));
        Object value = resultList.next().getValue().getValue();
        assertThat(resultList.hasNext(), is(false));
        assertThat(value, is(instanceOf(QuantityValue.class)));
        Double val = ((QuantityValue) value).getValue().doubleValue();
        // assertThat(value, is(instanceOf(SweDataArray.class)));
        // Double val = Double.parseDouble(((SweDataArray) value).getValues().get(0).get(1));
        assertThat(val, is(closeTo(1.0, 0.00001)));
    } finally {
        returnSession(session);
    }
}
Also used : CodespaceEntity(org.n52.series.db.beans.CodespaceEntity) ArrayList(java.util.ArrayList) PhenomenonEntity(org.n52.series.db.beans.PhenomenonEntity) DaoFactory(org.n52.sos.ds.hibernate.dao.DaoFactory) AdditionalObservationCreatorRepository(org.n52.sos.ds.hibernate.util.observation.AdditionalObservationCreatorRepository) ProcedureEntity(org.n52.series.db.beans.ProcedureEntity) PlatformEntity(org.n52.series.db.beans.PlatformEntity) QuantityDataEntity(org.n52.series.db.beans.QuantityDataEntity) SosHelper(org.n52.sos.util.SosHelper) GetObservationByIdRequest(org.n52.shetland.ogc.sos.request.GetObservationByIdRequest) CategoryEntity(org.n52.series.db.beans.CategoryEntity) FeatureEntity(org.n52.series.db.beans.FeatureEntity) OmObservationCreatorContext(org.n52.sos.ds.hibernate.util.observation.OmObservationCreatorContext) FormatEntity(org.n52.series.db.beans.FormatEntity) DatasetEntity(org.n52.series.db.beans.DatasetEntity) Transaction(org.hibernate.Transaction) ObservationStream(org.n52.shetland.ogc.om.ObservationStream) BindingRepository(org.n52.iceland.binding.BindingRepository) ResultTemplateEntity(org.n52.series.db.beans.ResultTemplateEntity) DataEntity(org.n52.series.db.beans.DataEntity) QuantityDataEntity(org.n52.series.db.beans.QuantityDataEntity) OfferingEntity(org.n52.series.db.beans.OfferingEntity) Session(org.hibernate.Session) Test(org.junit.Test)

Example 5 with PlatformEntity

use of org.n52.series.db.beans.PlatformEntity in project sensorweb-server-sta by 52North.

the class ThingService method updateEntity.

@Override
@Transactional
public PlatformEntity updateEntity(String id, PlatformEntity newEntity, HttpMethod method) throws STACRUDException {
    // checkUpdate(entity);
    if (HttpMethod.PATCH.equals(method)) {
        synchronized (getLock(id)) {
            Optional<PlatformEntity> existing = getRepository().findByStaIdentifier(id, IdentifierRepository.FetchGraph.FETCHGRAPH_LOCATION, IdentifierRepository.FetchGraph.FETCHGRAPH_HIST_LOCATION);
            if (existing.isPresent()) {
                PlatformEntity merged = merge(existing.get(), newEntity);
                if (newEntity.hasLocationEntities()) {
                    boolean changedLocations = processLocations(merged, newEntity.getLocations());
                    merged = getRepository().save(merged);
                    if (changedLocations) {
                        generateHistoricalLocation(merged);
                    }
                }
                return getRepository().save(merged);
            } else {
                throw new STACRUDException("Unable to update. Entity not found.", HTTPStatus.NOT_FOUND);
            }
        }
    } else if (HttpMethod.PUT.equals(method)) {
        throw new STACRUDException("Http PUT is not yet supported!", HTTPStatus.NOT_IMPLEMENTED);
    }
    throw new STACRUDException("Invalid http method for updating entity!", HTTPStatus.BAD_REQUEST);
}
Also used : PlatformEntity(org.n52.series.db.beans.PlatformEntity) STACRUDException(org.n52.shetland.ogc.sta.exception.STACRUDException) Transactional(org.springframework.transaction.annotation.Transactional)

Aggregations

PlatformEntity (org.n52.series.db.beans.PlatformEntity)18 HistoricalLocationEntity (org.n52.series.db.beans.sta.HistoricalLocationEntity)13 LocationEntity (org.n52.series.db.beans.sta.LocationEntity)10 DatastreamEntity (org.n52.series.db.beans.sta.DatastreamEntity)6 STACRUDException (org.n52.shetland.ogc.sta.exception.STACRUDException)6 ExpandItem (org.n52.shetland.filter.ExpandItem)5 STAInvalidQueryException (org.n52.shetland.ogc.sta.exception.STAInvalidQueryException)5 HashSet (java.util.HashSet)4 LinkedHashSet (java.util.LinkedHashSet)4 PhenomenonEntity (org.n52.series.db.beans.PhenomenonEntity)4 ProcedureEntity (org.n52.series.db.beans.ProcedureEntity)4 ObservationEntity (org.n52.series.db.beans.sta.ObservationEntity)3 Specification (org.springframework.data.jpa.domain.Specification)3 Optional (java.util.Optional)2 Set (java.util.Set)2 Expression (javax.persistence.criteria.Expression)2 Join (javax.persistence.criteria.Join)2 JoinType (javax.persistence.criteria.JoinType)2 Root (javax.persistence.criteria.Root)2 Subquery (javax.persistence.criteria.Subquery)2