Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/FraunhoferIOSB/FROST-Server
A Complete Server implementation of the OGC SensorThings API
https://github.com/FraunhoferIOSB/FROST-Server
Last synced: about 2 months ago
JSON representation
A Complete Server implementation of the OGC SensorThings API
- Host: GitHub
- URL: https://github.com/FraunhoferIOSB/FROST-Server
- Owner: FraunhoferIOSB
- License: lgpl-3.0
- Created: 2016-07-15T10:36:12.000Z (over 8 years ago)
- Default Branch: v2.x
- Last Pushed: 2024-10-17T16:15:57.000Z (3 months ago)
- Last Synced: 2024-10-19T23:58:19.152Z (3 months ago)
- Language: Java
- Homepage: https://fraunhoferiosb.github.io/FROST-Server/
- Size: 11.2 MB
- Stars: 199
- Watchers: 19
- Forks: 74
- Open Issues: 65
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-sensorthings-api - FROST-Server - Server is the first complete, open-source implementation of the OGC SensorThings API Part 1: Sensing (Tools / Example Query)
README
# FROST-Server [![Build Status](https://github.com/FraunhoferIOSB/FROST-Server/workflows/Maven%20Build/badge.svg)](https://github.com/FraunhoferIOSB/FROST-Server/actions) [![Codacy Badge](https://api.codacy.com/project/badge/Grade/da22d7347eb7450a955274916ed2d336)](https://www.codacy.com/gh/FraunhoferIOSB/FROST-Server?utm_source=github.com&utm_medium=referral&utm_content=FraunhoferIOSB/FROST-Server&utm_campaign=Badge_Grade) [![Docker badge](https://img.shields.io/docker/pulls/fraunhoferiosb/frost-server.svg)](https://hub.docker.com/r/fraunhoferiosb/frost-server/)
![FROST-Server Logo](https://raw.githubusercontent.com/FraunhoferIOSB/FROST-Server/v2.x/docs/images/FROST-Server-darkgrey.png)
A Server implementation of the [OGC SensorThings API](https://github.com/opengeospatial/sensorthings). The **FR**aunhofer **O**pensource **S**ensor**T**hings-Server
is the first complete, open-source official reference implementation of the [OGC SensorThings API Part 1: Sensing 1.0](https://docs.ogc.org/is/15-078r6/15-078r6.html). It also implements [OGC SensorThings API Part 1: Sensing 1.1](https://docs.ogc.org/is/18-088/18-088.html) and [OGC SensorThings API Part 2: Tasking Core 1.1](https://docs.ogc.org/is/17-079r1/17-079r1.html).## Downloading
Instead of compiling the server yourself, you can also download pre-built war and jar files from Maven Central:
* [FROST-Server.MQTTP](https://repo1.maven.org/maven2/de/fraunhofer/iosb/ilt/FROST-Server/FROST-Server.MQTTP/) FROST-Server.MQTTP-x.y.z.war
* [FROST-Server.HTTP](https://repo1.maven.org/maven2/de/fraunhofer/iosb/ilt/FROST-Server/FROST-Server.HTTP/) FROST-Server.HTTP-x.y.z.war
* [FROST-Server.MQTT](https://repo1.maven.org/maven2/de/fraunhofer/iosb/ilt/FROST-Server/FROST-Server.MQTT/) FROST-Server.MQTT-x.y.z-jar-with-dependencies.jarOr you can [use Docker](https://fraunhoferiosb.github.io/FROST-Server/deployment/docker.html).
## Extendable Data Model and pluggable APIs
FROST-Server implements the SensorThings API data model and API, but is not limited to these.
Using plugins the data model can be extended or even completely replaced depending on your specific requirements.
APIs and result formats can also be added using plugins.
By default, FROST-Server comes with experimental plugins for the OData 4.0 and 4.01 APIs and for CSV and GeoJSON result formats.## Fine-grained Authorisation
Authorisation rules can either be simple with Read, Create, Update and Delete on a service level,
or they can be very fine-grained with, for instance, certain users being able to read or create only Observations in Datastreams of certain Things.## Documentation
Documentation can be found on the [documentation site](https://fraunhoferiosb.github.io/FROST-Server/)
## Changes and Updates
See the [Change Log](CHANGELOG.md).
## Kubernetes (Helm) support
See [helm/frost-server/README.md](helm/frost-server/README.md) for how to use the FROST-Server Helm chart for a Kubernetes deployment.
## Compiling
To compile FROST-Server you need to have a JDK and Maven installed.
1. Checkout the project from github: `git clone https://github.com/FraunhoferIOSB/FROST-Server.git`
2. Go to the project root (The top-most directory with a pom.xml) `cd FROST-Server`
3. Give the command `mvn clean install`. This should build the war and jar files in:
* `FROST-Server.MQTTP/target/`
* `FROST-Server.HTTP/target/`
* `FROST-Server.MQTT/target/`
You may have to add the option `-Djavafx.platform=win` (`win` can be replaced with `linux` or `mac`) if the JavaFx platform is not detected automatically.## Contributing
Contributions are what make the open source community such an amazing place to learn, inspire, and create.
Any contributions are greatly appreciated.
You can read more in our [contribution guidelines](CONTRIBUTING.md).## Authors
Hylke van der Schaaf,
Michael Jacoby## License
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 .