Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/openremote/openremote
100% open-source IoT Platform - Integrate your devices, create rules, and analyse and visualise your data
https://github.com/openremote/openremote
asset-management building dashboard dataplatform energy energy-management energy-monitor fleet-management fleet-telematics iot iot-platform iot-projects knx mqtt mqtt-broker rules-engine smartcity websocket
Last synced: 6 days ago
JSON representation
100% open-source IoT Platform - Integrate your devices, create rules, and analyse and visualise your data
- Host: GitHub
- URL: https://github.com/openremote/openremote
- Owner: openremote
- License: other
- Created: 2016-02-03T11:14:02.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2025-01-07T13:51:24.000Z (14 days ago)
- Last Synced: 2025-01-07T18:08:05.287Z (14 days ago)
- Topics: asset-management, building, dashboard, dataplatform, energy, energy-management, energy-monitor, fleet-management, fleet-telematics, iot, iot-platform, iot-projects, knx, mqtt, mqtt-broker, rules-engine, smartcity, websocket
- Language: Java
- Homepage: https://openremote.io
- Size: 274 MB
- Stars: 1,294
- Watchers: 67
- Forks: 309
- Open Issues: 259
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-smartgrid - Openremote - source IoT Platform - Integrate your devices, create rules, and analyse and visualise your data. (Tools & Platforms)
- awesome-homelab - OpenRemote - source IoT Platform - Integrate your devices, create rules, and analyse and visualise your data | (Apps / X)
README
# OpenRemote
![CI/CD](https://github.com/openremote/openremote/workflows/CI/CD/badge.svg)
[![Open Source? Yes!](https://badgen.net/badge/Open%20Source%20%3F/Yes%21/blue?icon=github)](https://github.com/Naereen/badges/)[Source](https://github.com/openremote/openremote) **·** [Documentation](https://docs.openremote.io) **·** [Forum](https://forum.openremote.io) **·** [Issues](https://github.com/openremote/openremote/issues) **·** [Docker Images](https://hub.docker.com/u/openremote/) **·** [OpenRemote Inc.](https://openremote.io)
Welcome to OpenRemote; an intuitive user-friendly 100% open source IoT platform. You can build a complete IoT device management solution including: device management and auto provisioning, customisation of asset types, automation via when-then, flow, javascript and groovy rules, data analytics, connectivity via several protocol agents and manager APIs (e.g. MQTT broker, HTTP/REST, WS), Multi-tenancy (realms), Users and roles management, Edge gateway, Front-end UI web components and consoles, and an Insights dashboard builder.
As the code base is 100% open source, applications are limitless. Here's an architecture overview:
## Quickstart
You can quickly try the online demo with restricted access, login credentials are `smartcity:smartcity`:
[Online demo](https://demo.openremote.app/manager/?realm=smartcity)
The quickest way to get your own environment with full access is to make use of our docker images (both `amd64` and `arm64` are supported).
1. Make sure you have [Docker Desktop](https://www.docker.com/products/docker-desktop) installed (v18+).
2. Download the docker compose file:
[OpenRemote Stack](https://raw.githubusercontent.com/openremote/openremote/master/docker-compose.yml) (Right click 'Save link as...')
3. In a terminal `cd` to where you just saved the compose file and then run:
```
docker compose pull
docker compose -p openremote up
```
If all goes well then you should now be able to access the OpenRemote Manager UI at [https://localhost](https://localhost). You will need to accept the self-signed
certificate, see [here](https://www.technipages.com/google-chrome-bypass-your-connection-is-not-private-message) for details how to do this in Chrome (similar for other browsers).### Login credentials
Username: admin
Password: secret### Changing host and/or port
The URL you use to access the system is important, the default is configured as `https://localhost` if you are using a VM or want to run on a different port then you will need to set the `OR_HOSTNAME` and `OR_SSL_PORT` environment variables, so if for example you will be accessing using `https://192.168.1.1:8443` then use the following startup command:BASH:
```
OR_HOSTNAME=192.168.1.1 OR_SSL_PORT=8443 docker compose -p openremote up -d
```
orCMD:
```
cmd /C "set OR_HOSTNAME=192.168.1.1 && set OR_SSL_PORT=8443 && docker compose -p openremote up -d"
```## What next
Try creating assets, agents, rules, users, realms, etc. using the Manager UI, please refer to the [documentation](https://docs.openremote.io) for more information, some things to try:- [Manager UI Guide](https://docs.openremote.io/docs/user-guide/manager-ui/) - Learn more about the User Interface
- [Creating an HTTP Agent tutorial](https://docs.openremote.io/docs/tutorials/open-weather-api-using-http-agent) - Connect to an online weather service
- [Custom Deployment](https://docs.openremote.io/docs/user-guide/deploying/custom-deployment) - Style the Manager to your brand
- [Setting up an IDE](https://docs.openremote.io/docs/developer-guide/setting-up-an-ide) - Set up your development environment
- [Working on the UI](https://docs.openremote.io/docs/developer-guide/working-on-ui-and-apps) - Create a web application compatible with OpenRemote
- [Creating a custom project](https://docs.openremote.io/docs/developer-guide/creating-a-custom-project) - Create a project with custom protocols, asset types and setup code## Where's the data stored?
Persistent data is stored in a PostgreSQL DB which is stored in the `openremote_postgresql-data` docker volume which is durably stored independently of the running containers (see all with `docker volume ls`).
Note that historical attribute data is purged daily based on value of `OR_DATA_POINTS_MAX_AGE_DAYS`; this value can also be overridden for individual attributes by using the `dataPointsMaxAgeDays` configuration item.
See the [Developer Guide](https://docs.openremote.io/docs/developer-guide/useful-commands-and-queries/#backuprestore-openremote-db) for details on making backups of the database.## Contributing to OpenRemote
For information and how to set up a development environment, see the [Developer Guide](https://docs.openremote.io/docs/category/developer-guide).
We work with Java, Groovy, TypeScript, Gradle, Docker, and a wide range of APIs and protocol implementations.
We follow the [GitHub Flow](https://docs.github.com/en/get-started/quickstart/github-flow) workflow with tags and releases for published versions of our components; when working on the codebase create descriptive branch names (e.g. `feature/cool_feature_x`, `hotfix/flux_capacitor`, `issue/123`, etc.).
When your changes are complete then create a Pull Request ensuring that your branch is up-to-date with the source branch and that code changes are covered by tests and that the full test suite passes.
## Discuss OpenRemote
Join us on the [community forum](https://forum.openremote.io/).