[Buildroot] [PATCH v5] domoticz: new package

fabrice.fontaine at orange.com fabrice.fontaine at orange.com
Thu May 19 08:47:17 UTC 2016


Dear all,

I will sent a new patch with the two small bug fixes following the review of Julien.

However, concerning the issue with sqlite and jffs2, I think that the modification on sqlite.mk should be made in a separate patch.
Perhaps, this patch could be applied on sqlite if BR2_TARGET_ROOTFS_JFFS2 is set. However, I have not seen any package using BR2_TARGET_ROOTFS_xxx variables so this is perhaps not the right way to do it.

A second solution could be to disable domoticz on jffs2 filesystem but then again I will have to check on BR2_TARGET_ROOTFS_JFFS2.

A third solution would be to always remove the "PRAGMA journal_mode = WAL" (and perhaps also "PRAGMA journal_mode=DELETE") from main/SQLHelper.cpp in domoticz but I don't know if this could have some side effects on domoticz performances on other filesystems.

Best Regards,

Fabrice

-----Message d'origine-----
De : Thiago A. Corrêa [mailto:thiago.correa at gmail.com] 
Envoyé : mercredi 18 mai 2016 20:43
À : Julien Boibessot
Cc : FONTAINE Fabrice IMT/OLPS; buildroot at buildroot.org
Objet : Re: [Buildroot] [PATCH v5] domoticz: new package

There is a problem with domoticz on JFFS2 systems, because it enables some pragmas. Sqlite then tries to mmap on JFFS2 which is not supported and everything fails, Domoticz can't even create the tables.
 I fixed it changing sqlite.mk to add:

+SQLITE_CFLAGS += -DSQLITE_TEMP_STORE=3
+SQLITE_CFLAGS += -DSQLITE_SHM_DIRECTORY=/tmp SQLITE_CFLAGS += 
+-DSQLITE_OMIT_WAL

Maybe it could be added to the patch, checking if JFFS2 output is enabled.


On Wed, May 18, 2016 at 2:28 PM, Julien Boibessot <julien.boibessot at free.fr> wrote:
> Hello Fabrice,
>
> I finally got time to test your v5...
>
> On 03/05/2016 10:14, fabrice.fontaine at orange.com wrote:
>> Domoticz is a Home Automation System that lets you monitor andi
>
> typo: andi -> and
>
>> configure various devices like: Lights, Switches, various 
>> sensors/meters like Temperature, Rain, Wind, UV, Electra, Gas, Water 
>> and much more. Notifications/Alerts can be sent to any mobile device.
>>
>> Signed-off-by: Fabrice Fontaine <fabrice.fontaine at orange.com>
>> ---
>> Changes v4 -> v5 (after review of Julien Boibessot):
>>  - Add dedicated init scripts for systemV and systemd instead of using
>>    domoticz.sh as it is not compatible with buildroot init system
>>
>> Changes v3 -> v4 (after review of Julien Boibessot):
>>  - Remove unneeded files (License and updatedomo) from target directory.
>>    Do not remove History.txt as it is used in source code
>>  - Install domoticz binary and all its files in /opt/domoticz instead of
>>    /usr by overriding CMAKE_INSTALL_PREFIX
>>  - Modify and install domoticz.sh if systemV is enabled by defining
>>    DOMOTICZ_INSTALL_INIT_SYSV
>>
>> Changes v2 -> v3 (after review of Samuel Martin):
>>  - Use OFF instead of no for consistency with other cmake packages
>>  - Always set USE_STATIC_BOOST and USE_STATIC_OPENZWAVE to OFF as
>>    BR2_STATIC_LIBS will always be false due to mosquitto dependency
>>
>> Changes v1 -> v2 (after review of Samuel Martin):
>>  - Add a hash file
>>  - Replace the dependency on BR2_PACKAGE_LUA_5_2 by a dependency on
>>    BR2_PACKAGE_LUA_5_2 or BR2_PACKAGE_LUA_5_3
>>  - Add dependencies on BR2_USE_MMU and !BR2_STATIC_LIBS (from 
>> mosquitto)
>>  - Add dependency on BR2_PACKAGE_BOOST_ARCH_SUPPORTS (from boost)
>>  - Automatically add zwave support in domoticz if the user has selected
>>    the openzwave package
>>  - Set USE_STATIC_BOOST and USE_STATIC_OPENZWAVE to the correct values
>>    in domoticz.mk depending on BR2_STATIC_LIBS value to avoid breaking
>>    static-only build
>>
>>  package/Config.in                 |  1 +
>>  package/domoticz/Config.in        | 32 ++++++++++++++++++
>>  package/domoticz/S99domoticz      | 38 ++++++++++++++++++++++
>>  package/domoticz/domoticz.hash    |  2 ++
>>  package/domoticz/domoticz.mk      | 68 +++++++++++++++++++++++++++++++++++++++
>>  package/domoticz/domoticz.service | 10 ++++++
>>  6 files changed, 151 insertions(+)
>>  create mode 100644 package/domoticz/Config.in  create mode 100644 
>> package/domoticz/S99domoticz  create mode 100644 
>> package/domoticz/domoticz.hash  create mode 100644 
>> package/domoticz/domoticz.mk  create mode 100644 
>> package/domoticz/domoticz.service
>>
>> diff --git a/package/Config.in b/package/Config.in index 
>> 10d9a6e..6b33a02 100644
>> --- a/package/Config.in
>> +++ b/package/Config.in
>> @@ -1326,6 +1326,7 @@ menu "Miscellaneous"
>>       source "package/bc/Config.in"
>>       source "package/clamav/Config.in"
>>       source "package/collectd/Config.in"
>> +     source "package/domoticz/Config.in"
>>       source "package/empty/Config.in"
>>       source "package/gnuradio/Config.in"
>>       source "package/googlefontdirectory/Config.in"
>> diff --git a/package/domoticz/Config.in b/package/domoticz/Config.in 
>> new file mode 100644 index 0000000..c7c2878
>> --- /dev/null
>> +++ b/package/domoticz/Config.in
>> @@ -0,0 +1,32 @@
>> +config BR2_PACKAGE_DOMOTICZ
>> +     bool "domoticz"
>> +     depends on BR2_PACKAGE_BOOST_ARCH_SUPPORTS # boost
>> +     depends on BR2_USE_MMU # mosquitto
>> +     depends on !BR2_STATIC_LIBS # mosquitto
>> +     depends on BR2_TOOLCHAIN_HAS_THREADS
>> +     depends on BR2_INSTALL_LIBSTDCPP
>> +     depends on BR2_USE_WCHAR
>> +     depends on BR2_PACKAGE_LUA_5_2 || BR2_PACKAGE_LUA_5_3
>> +     select BR2_PACKAGE_BOOST
>> +     select BR2_PACKAGE_BOOST_DATE_TIME
>> +     select BR2_PACKAGE_BOOST_SYSTEM
>> +     select BR2_PACKAGE_BOOST_THREAD
>> +     select BR2_PACKAGE_LIBCURL
>> +     select BR2_PACKAGE_MOSQUITTO
>> +     select BR2_PACKAGE_OPENSSL
>> +     select BR2_PACKAGE_SQLITE
>> +     select BR2_PACKAGE_ZLIB
>> +     help
>> +       Domoticz is a Home Automation System that lets you monitor 
>> +andi
>
> typo: andi -> and
>
>> +       configure various devices like: Lights, Switches, various
>> +       sensors/meters like Temperature, Rain, Wind, UV, Electra, Gas, Water
>> +       and much more. Notifications/Alerts can be sent to any mobile device.
>> +
>> +       http://domoticz.com
>> +
>> +comment "domoticz needs lua >= 5.2 and a toolchain w/ C++, threads, wchar, dynamic library"
>> +     depends on BR2_PACKAGE_BOOST_ARCH_SUPPORTS
>> +     depends on BR2_USE_MMU
>> +     depends on !BR2_INSTALL_LIBSTDCPP || !BR2_TOOLCHAIN_HAS_THREADS || \
>> +             !BR2_USE_WCHAR || BR2_STATIC_LIBS || \
>> +             !(BR2_PACKAGE_LUA_5_2 || BR2_PACKAGE_LUA_5_3)
>> diff --git a/package/domoticz/S99domoticz 
>> b/package/domoticz/S99domoticz new file mode 100644 index 
>> 0000000..9a53105
>> --- /dev/null
>> +++ b/package/domoticz/S99domoticz
>> @@ -0,0 +1,38 @@
>> +#!/bin/sh
>> +
>> +NAME=domoticz
>> +PIDFILE=/var/run/$NAME.pid
>> +DAEMON=/opt/domoticz/$NAME
>> +DAEMON_ARGS="-daemon -www 18080 -sslwww 443"
>
> hum isn't it 8080 instead of 18080 ?
>
> otherwise it still build and run fine for me (ARM uclibc and systemV init).
>
> So:
> Tested-by: Julien Boibessot <julien.boibessot at armadeus.com>
>
> And hoping it will soon be merged into BR mainline...
>
> Best regards,
> Julien
>
>> +
>> +start() {
>> +     printf "Starting $NAME: "
>> +     start-stop-daemon -S -q -m -b -p $PIDFILE --exec $DAEMON -- $DAEMON_ARGS
>> +     [ $? = 0 ] && echo "OK" || echo "FAIL"
>> +}
>> +stop() {
>> +     printf "Stopping $NAME: "
>> +     start-stop-daemon -K -q -p $PIDFILE
>> +     [ $? = 0 ] && echo "OK" || echo "FAIL"
>> +}
>> +restart() {
>> +     stop
>> +     start
>> +}
>> +
>> +case "$1" in
>> +  start)
>> +     start
>> +     ;;
>> +  stop)
>> +     stop
>> +     ;;
>> +  restart|reload)
>> +     restart
>> +     ;;
>> +  *)
>> +     echo "Usage: $0 {start|stop|restart}"
>> +     exit 1
>> +esac
>> +
>> +exit $?
>> diff --git a/package/domoticz/domoticz.hash 
>> b/package/domoticz/domoticz.hash new file mode 100644 index 
>> 0000000..9180a9b
>> --- /dev/null
>> +++ b/package/domoticz/domoticz.hash
>> @@ -0,0 +1,2 @@
>> +# Locally computed:
>> +sha256       02b4cdde8e376258aeae3d5621edf8bb6b3563c34282e50194db343fcec9c0f5        domoticz-3.4834.tar.gz
>> diff --git a/package/domoticz/domoticz.mk 
>> b/package/domoticz/domoticz.mk new file mode 100644 index 
>> 0000000..64d4074
>> --- /dev/null
>> +++ b/package/domoticz/domoticz.mk
>> @@ -0,0 +1,68 @@
>> +####################################################################
>> +############
>> +#
>> +# domoticz
>> +#
>> +####################################################################
>> +############
>> +
>> +DOMOTICZ_VERSION = 3.4834
>> +DOMOTICZ_SITE = $(call github,domoticz,domoticz,$(DOMOTICZ_VERSION))
>> +DOMOTICZ_LICENSE = GPLv3
>> +DOMOTICZ_LICENSE_FILES = License.txt DOMOTICZ_DEPENDENCIES = boost 
>> +host-pkgconf libcurl lua mosquitto openssl \
>> +        sqlite zlib
>> +
>> +# Due to mosquitto dependency, domoticz depends on !BR2_STATIC_LIBS 
>> +so sets # USE_STATIC_BOOST to OFF DOMOTICZ_CONF_OPTS += 
>> +-DUSE_STATIC_BOOST=OFF
>> +
>> +# Do not use any built-in libraries which are enabled by default for 
>> +lua, # sqlite and mqtt DOMOTICZ_CONF_OPTS += -DUSE_BUILTIN_LUA=OFF 
>> +DOMOTICZ_CONF_OPTS += -DUSE_BUILTIN_SQLITE=OFF DOMOTICZ_CONF_OPTS += 
>> +-DUSE_BUILTIN_MQTT=OFF
>> +
>> +ifeq ($(BR2_PACKAGE_LIBUSB),y)
>> +DOMOTICZ_DEPENDENCIES += libusb
>> +endif
>> +
>> +ifeq ($(BR2_PACKAGE_OPENZWAVE),y)
>> +DOMOTICZ_DEPENDENCIES += openzwave
>> +
>> +# Due to mosquitto dependency, domoticz depends on !BR2_STATIC_LIBS 
>> +so sets # USE_STATIC_OPENZWAVE to OFF otherwise domoticz will not 
>> +found openzwave # library as it searchs by default a static library 
>> +DOMOTICZ_CONF_OPTS += -DUSE_STATIC_OPENZWAVE=OFF endif
>> +
>> +# Install domoticz in a dedicated directory (/opt/domoticz) as 
>> +domoticz expects # by default that all its subdirectories (www, 
>> +Config, scripts, ...) are in the # binary directory 
>> +DOMOTICZ_TARGET_DIR = /opt/domoticz DOMOTICZ_CONF_OPTS += 
>> +-DCMAKE_INSTALL_PREFIX=$(DOMOTICZ_TARGET_DIR)
>> +
>> +# Delete License.txt and updatedomo files installed by domoticz in 
>> +target # directory # Do not delete History.txt as it is used in 
>> +source code define DOMOTICZ_REMOVE_UNNEEDED_FILES
>> +     $(RM) $(TARGET_DIR)/$(DOMOTICZ_TARGET_DIR)/License.txt
>> +     $(RM) $(TARGET_DIR)/$(DOMOTICZ_TARGET_DIR)/updatedomo
>> +endef
>> +
>> +DOMOTICZ_POST_INSTALL_TARGET_HOOKS += DOMOTICZ_REMOVE_UNNEEDED_FILES
>> +
>> +# Use dedicated init scripts for systemV and systemd instead of 
>> +using # domoticz.sh as it is not compatible with buildroot init 
>> +system define DOMOTICZ_INSTALL_INIT_SYSV
>> +     $(INSTALL) -D -m 0755 package/domoticz/S99domoticz \
>> +             $(TARGET_DIR)/etc/init.d/S99domoticz
>> +endef
>> +
>> +define DOMOTICZ_INSTALL_INIT_SYSTEMD
>> +     $(INSTALL) -D -m 644 package/domoticz/domoticz.service \
>> +             $(TARGET_DIR)/usr/lib/systemd/system/domoticz.service
>> +     mkdir -p $(TARGET_DIR)/etc/systemd/system/multi-user.target.wants
>> +     ln -sf ../../../../usr/lib/systemd/system/domoticz.service \
>> +             
>> +$(TARGET_DIR)/etc/systemd/system/multi-user.target.wants/domoticz.se
>> +rvice
>> +endef
>> +
>> +$(eval $(cmake-package))
>> diff --git a/package/domoticz/domoticz.service 
>> b/package/domoticz/domoticz.service
>> new file mode 100644
>> index 0000000..446b41a
>> --- /dev/null
>> +++ b/package/domoticz/domoticz.service
>> @@ -0,0 +1,10 @@
>> +[Unit]
>> +Description=Domoticz Home Automation System After=network.target
>> +
>> +[Service]
>> +ExecStart=/opt/domoticz/domoticz -daemon -www 8080 -sslwww 443 
>> +Restart=always
>> +
>> +[Install]
>> +WantedBy=multi-user.target
>
> _______________________________________________
> buildroot mailing list
> buildroot at busybox.net
> http://lists.busybox.net/mailman/listinfo/buildroot

_________________________________________________________________________________________________________________________

Ce message et ses pieces jointes peuvent contenir des informations confidentielles ou privilegiees et ne doivent donc
pas etre diffuses, exploites ou copies sans autorisation. Si vous avez recu ce message par erreur, veuillez le signaler
a l'expediteur et le detruire ainsi que les pieces jointes. Les messages electroniques etant susceptibles d'alteration,
Orange decline toute responsabilite si ce message a ete altere, deforme ou falsifie. Merci.

This message and its attachments may contain confidential or privileged information that may be protected by law;
they should not be distributed, used or copied without authorisation.
If you have received this email in error, please notify the sender and delete this message and its attachments.
As emails may be altered, Orange is not liable for messages that have been modified, changed or falsified.
Thank you.



More information about the buildroot mailing list