8378aefe7e
This fixes ~100 SAT findings. It also adds some more null annotations to the HABot classes. Signed-off-by: Wouter Born <github@maindrain.net> |
||
---|---|---|
.. | ||
src/main | ||
.classpath | ||
.project | ||
NOTICE | ||
README.md | ||
pom.xml |
README.md
CometVisu Backend for openHAB
Introduction
This adds a backend for the web based visualization CometVisu http://www.cometvisu.org. The CometVisu is a highly customizable visualization, that runs in any browser. Unlike the browser based UI´s in openHAB, the CometVisu does not rely on sitemaps (although they can be used). The layout is defined with an XML-based configuration file, which allows a multi column layout.
Requirements
- openHAB 2.0 or greater
- CometVisu 0.8.6 or greater https://github.com/CometVisu/CometVisu/releases
Installation
- Install the CometVisu addon (optionally you can also install the CometVisu-PHP addon, but it is not required to run the CometVisu)
- Enable the auto-download feature via configuration setting OR
- Download the CometVisu release https://github.com/CometVisu/CometVisu/releases and extract the "release" folder (the one which contains the index.html file) of the downloaded archive somewhere on your openHAB server (make sure that openHAB can access that folder).
Note: You have to set the path to this folder in your configuration (webFolder).
Configuration
Server configuration via Paper UI
You can customize some settings of the CometVisu backend in the services configuration section of the PaperUI. You can find the CometVisu configuration in the "ui" category.
Via Config file
You can customize some settings of the CometVisu backend in a configuration file named 'cometvisu.cfg' which has to be created in the 'conf/services/' folder of your openHAB instance, if it does not exist.
The following settings are available:
Relative path to the folder the CometVisu client can be found (must point to the directory that contains the CometVisu's index.html file, which is usually the release-folder):
webFolder=\<absolute-path-to-your-local-cometvisu-copy\>
The alias where you can access the client e.g http://<openhab-server>:8080/<webAlias>/
webAlias=/cometvisu
Activate the automatic download if the CometVisu client.
autoDownload=true (default is false)
Please note that, when you activate this feature, the latest release of the CometVisu client is downloaded to your openHAb server. The CometVisu is licensed under the GNU General Public License v3.0. If you do not agree to this license, you must not activate this feature.
Enable icon mapping from openHAB-items to CometVisu-items (Note this is only needed if you use the automatic sitemap->config generation feature).
icons>enableMapping=true
List of mappings of structure: icons.mapping><openhab-icon>=<cometvisu-icon>
icons.mapping>firstfloor=control_building_int_og
cons.mapping>groundfloor=control_building_int_eg
The list of icons in the CometVisu is available at:
http://<openhab-server>:8080/<webAlias>/icon/knx-uf-iconset/showicons.php
You can also customize the mounted folders in the CometVisu manager. The CometVisu manager can only access files/folders in the resource/config folder. In order to make other files of the CometVisu available mount points are used and this feature is used in order to make the demo config folder accessible. You can add further mount points if you need to access other resources in the cometvisu. Please keep in mind that only subfolders of the CometVisu installation can be mounted, you cannot access paths outside this folder.
Default setting is:
mount>demo=resource/demo
This mounts the resource/demo
subfolder as demo
-folder in the manager. By default these mounted folders
are not writeable, which means that you cannot create/edit files and folders in there. You can add some flags to
the mount entry to customize some settings, the available flags are:
w: mounted content is writeable
s: show subfolders in the mounted folder
A complete mount entry with these flags looks like this:
mount>designs=resource/designs:ws
Override CometVisu files
You can create a folder called 'cometvisu' in openHAB's 'conf/' folder and create files there which should be used instead of CometVisu's own. For example, you can put all your customizations there (e.g. you config, custom.css, etc.). So the CometVisu itself stays untouched and can easily be replaced with a new release.
Please use the same folder structure and file names as they are used in the CometVisu package. For example if you want to replace the original config with your own copy the file to the following path:
'conf/cometvisu/config/visu_config.xml'
Or for design customizations use:
'conf/cometvisu/designs/metal/custom.css'
Client configuration
If you don´t use the given example below, please make sure that you correctly configure openHAB as backend in the CometVisu-Config by adding backend="oh2"
to the root pages-element (e.g. <pages...backend="oh2"...>
)
It is a good start to use the new sitemap support, to get a working example config, which you can store an customize for your needs. Open a sitemap in the CometVisu client like this:
http://<openhab-server>:8080/<webAlias>/?config=<sitemap-name>
You can use the editor to change and store this config. You can start with the demo-sitemap to get a quick overview about how the CometVisu looks like.
New features (compared to the 1.x version)
- PHP support: Editor is working, rsslog-plugin can be used (see examples)
- Persistence support: Any persisted item can be used to create a chart
- GroupItem support: as known from the openHAB UI´s the group-functions like the number of open windows in a group of contacts can be shown in the visu
Examples
Show how many lights are switched on
- Items: uses the demo.items provided by openHAB
- Config (please add the infoaction-plugin in pages->meta->plugins in your config in order to use this):
<infoaction>
<label>Lights</label>
<widgetinfo>
<info format="%d">
<address transform="OH:number" mode="read" variant="">number:Lights</address>
</info>
</widgetinfo>
<widgetaction>
<switch mapping="OnOff" styling="Red_Green">
<address transform="OH:switch" variant="">Lights</address>
</switch>
</widgetaction>
</infoaction>
- use it in navbar:
<pagejump target="Lights">
<layout colspan="0" />
<label>
<icon name="control_building_empty" />Übersicht
</label>
<widgetinfo>
<info format="%d">
<layout colspan="0" />
<address transform="OH:number" mode="read" variant="">number:Lights</address>
</info>
</widgetinfo>
</pagejump>
Charts:
- Items: see demo.items
- Config:
<diagram height="300px" series="day" refresh="600">
<rrd consolidationFunction="AVERAGE">Weather_Temperature</rrd>
<rrd consolidationFunction="AVERAGE">Weather_Temp_Max</rrd>
<rrd consolidationFunction="AVERAGE">Weather_Temp_Min</rrd>
</diagram>
some notes:
consolidationFunction
is only obeyed, when the item is persisted by the rrd4j persistence service- Altough you have to define <rrd...>Item_name for every line in the config, the used items do not have to be persisted by the rrd4j persistence service, any other service will work too, but you have to specify the service name as prefix to the item name, e.g.
<rrd>mysql:Weather_Temp_Min</rrd>
to get the date from the mysql persistence service. - Currently the CometVisu-Chart-Backend can only generate charts from persisted Number-Items. Other item types are not supported.
RSS-Log:
- Items: no special item needed
- Config:
<rsslog src="plugins/rsslog/rsslog.php" refresh="60" mode="last">
<label>Events</label>
<layout colspan="12" rowspan="9"/>
</rsslog>
- Fill the log from a rule:
var content = "Call recevied from 123456",encode("UTF-8")
var tag = "Call".encode("UTF-8")
sendHttpGetRequest("http://<openhab-server>:8080/<webAlias>/plugins/rsslog.php?c="+content+"&t="+tag)
RSS-Log from persisted item:
- Items:
String Logger
- Config:
<rsslog src="plugins/rsslog/rsslog_oh.php" refresh="60" filter="Logger">
<label>Events</label>
<layout colspan="12" rowspan="9"/>
</rsslog>
- Fill the log from a rule:
# Message structure is <title>|<content>|<state>|<tags>
sendCommand(Logger,"Call received|Received call from 123456789|0|Call,Incoming")
# but you can also just use any string like
sendCommand(Logger,"Received call from 123456789")
ColorItem (supported since CometVisu-Release 0.8.2) =>
<colorchooser>
<label>Color</label>
<address transform="OH:color" variant="rgb">ITEM_NAME</address>
</colorchooser>
Please note: You have to add the colorchooser plugin in the meta>plugins section of you config
Known problems
Not all of the PHP-based functions in the CometVisu client have been tested so far. The untested features are:
- Automatic configuration upgrade, when the library version has changed
- calendarlist plugin
- upnpcontroller plugin
The sitemap support can only be used as a starting point for own customizations, e.g. you open an automatic generated config and store it in by CometVisu by using the editor. Then you start to customize it to your own needs. New items must by added by hand from the moment you stored and changed the generated config.
404 error
Please make sure that openHAB has the rights to read the configured <webFolder> folder.
403 error
If you get an 403 - Access Denied error, when you try to open the CometVisu in your browser you have not copied the correct release folder into the <webFolder> folder. Please check if there is a subfolder with the exact name "release/", which contains an index.html file and copy the content to the folder defined in the <webFolder>-property.
Hints for development
Source file are automatically generated from CometVisu's visu_config.xsd and openapi.yaml files.
For a manual update of these files copy them to the src/main/resources folder and run
mvn clean generated-sources
.
If the library version changes the value must be updated in org.openhab.ui.cometvisu.internal.backend.model.config.LibVersion
.
TODO
Maybe it is possible to define a general structure (in addition to a sitemap), that maps and groups items based on their context, e.g. which floor/room/subsection the belong to
<floor>
<room navbar="top">
<all-lights-items colspan="12">
<all-rollershutter-items colspan="6">
<all-contact-items colspan="6">
<all-other-items colspan="12">
</room>
</floor>
Something like that could help to improve the sitemap->config generation.
Screenshots
some screenshots can be found here:
Links
- German CometVisu Support Forum: http://knx-user-forum.de/forum/supportforen/cometvisu
- User documentation for the CometVisu: http://www.cometvisu.org/
- GitHub project page of the CometVisu: https://github.com/CometVisu/CometVisu