- TBD
BREAKING CHANGES
- None, Supported are nodejs 10.x, 12.x and 14.x (Node.js 15.x is also working WHEN USED WITH npm 6!! in the automated tests, but formally not supported)
- If you have enabled Multihost Discovery please disable and enable it again if you really need it persistent running. By re-enabling it you update the used passphrase with a better encryption mechanism.
- (Foxriver76) Harmonize username handling between admin and js-controller by transforming the object id to lowercase. With this user names will be treated case insensitive from now on!
Features
- (raintonr) Update Let's encrypt implementation; all relevent adapters (web and such) need updates to use it! NEEDS NODE.JS 12.x+! (see DOCS LINK TODO)
- (bluefox) Restart adapters that use Let's encrypt after certificates were updated
- (bluefox) Provide min/max for convert alias functions
- (foxriver76) handling major adapter upgrades more carefully (CLI on upgrade will show if it's a major upgrade and major upgrades will be skipped on upgrade all when executed by admin
- (AlCalzone) detect and allow short github URL format when (auto-)installing adapters (
iobroker url User/repo#branchorcommit
) - (AlCalzone) Support more Github URL formats for
iobroker url
command - (AlCalzone) support github branch names with slashes on adapter install
- (foxriber76) Add notification system (see DOCS LINK TODO)
- (foxriver76) enhance setup (and setup first) with redis to all port configuration
- (foxriver76) set connectionName for redis connections and simulator support
- (bluefox) Added "http" and "stream" options for logs
- (Apollon77) add seq logging support to js-controller
- (foxriver76) Fix wrong logger pattern that caused issues on windows
- (Apollon77) fix potential crash when restoring backup
- (Apollon77) restore old logfile deletion logic because rotator library do not work as expected
- (Apollon77) Optimize File DBs to lower write i/o by 50% (backup file is now renamed instead of rewritten)
- (AlCalzone/Apollon77) Restructure DB code to allow easier new DB types
- (Apollon77) enhance letsencrypt to also allow to specify alternative names for certs
Optimizations and Fixes
- (foxriver76) Detect adapter restart loops and stop restarting after 3 crashes (an adapter is considered "working" when no crash by an exception happens within 10 minutes)
- (foxriver76) Fix failed logins if username is uppercase, be reworking user logic and caching
- (bluefox) Set for def states the quality: QUALITY_SUBS_INITIAL
- (AlCalzone) fix npm uninstall loglevel argument
- (foxriver76) delete pids.txt when iobroker was stopped
- (bluefox) Add missing attributes by multihost if Redis is used for objects/states, Remove unused settings from iobroker-dist.json, Remove pass and user from connection settings. Use options.auth_pass
- (AlCalzone) Package-Manager: log which packages were (already) installed
- (foxriver76) replace redis "KEYS" command by "SCAN" to optimize redis access performance
- (foxriver76) optimize redis library usage to prevent errors on redis outages
- (bluefox) Catch errors when plugins initialize. At least log will work and could be checked for errors.
- (foxriver76) allow migration of instances to already existing host
- (foxriver76) also allow . for install/add cli command
- (AlCalzone) buffer streams that are piped to stdout to fix weird Windows logging cases
- (foxriver76/AlCalzone) Optimize upgrade/downgrade logic for adapters, ask for a downgrade only if lower version is to be installed
- (foxriver76) allow redis redis migration when changing host of redis - fix bug where process crashes when controller is running when migrating
- (bluefox) Catch errors for subscribe on alias without target
- (foxriver76) only perform auto scaling on alias if not null
- (foxriver76) if repository request fails also use cached sources on updating repository
- (foxriver76) prevent host deletion from same host - otherwise it will remove the system.host states but instances will still be on the removed host, because transfer happens to itself
- (foxriver76) use instanceObjects from system.adapter.* object instead from io-package.json
- (foxriver76) notify of errors on readFileCertificates to show permission problems etc.
- (foxriver76) multihost discovery now logs ignored messages on debug and also logs the senders address
- (foxriver76) sync up created objects on instance start and instance creation by using helper function in tools.js, e.g. .loglevel was missing on instance creation
- (bluefox) Package-Manager: Filter empty packets out to suppress error message
- (foxriver76) rename repository names for new installations and on updates to beta/stable
- (foxriver76) rewrite collectDiagInfo to Promises and fix minor issue with it
- (foxriver76) only scale aliases if target or source is represented by unit %
- (foxriver76) create meta.user on file sync cli, if not existing
- (Apollon77) also create meta.user on setup first if not existing
- (foxriver76) fix enumInstances used by CLI commands
- (foxriver76) when missing rights to access log dir do not crash hard anymore, instead fallback to default directory
- (bluefox) Fix error if type of native data changed in the new version from basic type e.g. 'string' to 'object'.
- (AlCalzone) Remove hardcoded references to GitHub master branch because newer repositories use "main"
- (Apollon77) update _design objects also on js-controller upgrade/setup first
- (Apollon77) optimize deletion of files in ioBroker file storage
- (foxriver76) do not return an error if object does not exist on del*Object
- (Apollon77) optimize logs when instance is restarted
- (foxriver76) Preserve name field on instance object creation/update
- (foxriver76) optimize parameters and flags on CLI
- (foxriver76) Use yargs helper instead of building our own string output to allow showing --help for a specific command instead of the whole output and allow support for auto completion (
iobroker _createCompletion >> ~/.bashrc
) - (foxriver76, Apollon77) also accept pre-release version in some semver checks for dependencies
- (foxriver76) replace outdated encryption mechanism of multihost
- (Apollon77) prevent an endless loop when lua script initialization was not possible
- (Apollon77) catch semver errors in upgrade commands
- (foxriver76) ensure setAdapterInstanceEnabled can not hang
- (Apollon77, foxriver, bluefox, AlCalzone) Several fixes and refactorings to prevent potential crash cases reported by Sentry and other sources
Developer relevant DEPRECATIONS/WARNINGS
- (foxriver76) we warn if object not exists when setting a state via adapter.setState. Adjust your code that a state value is NOT set before the object is successfully created. If this deep check is NOT wanted for performance reasons the adapter needs to be initialized with strictObjectChecks = false!! (see DOCS LINK TODO)
- (foxriver76) readFile should not validate meta object, we now throw on writeFile if id is no valid meta object
- (AlCalzone) update Forbidden ID Characters: use Unicode properties to define which characters are allowed instead of blacklisting. For ASCII the allowed characters are the same as before - for other languages mainly character class of Unicode are allowed! (see DOCS LINK TODO)
- (foxriver76) Throw on invalid setState objects; was logged as deprecated before
- (foxriver76) remove getMessage shim, no adapter uses it anymore; was logged as deprecated before
Developer relevant new Features
- (foxriver76) use aes-192-cbc as encryption - backward compatible with current encryption, nothing to do for adapter-developers (see DOCS LINK TODO)
- (bluefox) Add system view to filter for "folder" objects
- (bluefox) add set/clearTimeout and set/clearInterval to adapter methods and check on unload that they were all cleared and clear if needed with logging, so developers are reminded to clean up!
- (AlCalzone) Add ...Async version for getChannels - make sure to check before using or use correct js-controller version dependency!
- (Apollon77) modularize databases into own npm packages and basically support adding new types of databases; add deprecation infos and logging to "old legacy" files in lib/states and lib/objects to not be used anymore; requires mostly updates in testing (see DOCS LINK TODO)
- (foxriver76) allow to specify the instance for debug starts (
iobroker debug adaptername.1
) - (foxriver76) Enhance extendObject to allow to preserve specified fields (e.g. common.name)
- (foxriver76) add adapter method getUserId
Developer relevant Optimizations and Fixes
- (foxriver76) implement maybeCallback and maybeCallbackWithError and use it in adapter.js
- (AlCalzone) use fs-extra instead of mkdirp
- (AlCalzone) read JSON files using fs-extra's readJSONSync
- (AlCalzone) fix callback definitions in adapter.js, We have signatures for (almost) everything in @types/iobroker and we should use them
- (AlCalzone) move from Promises to async/await in some places, use a single readyPromise instead of an array
- (foxriver76) migrated ci tests to github actions
- (foxriver76) resolve adapter main file as tools.js method
- (foxriver76) optimize extendObject with def value
- (AlCalzone) Handle existing, but undefined properties in validateSetStateObjectArgument
- (foxriver76) also escape + char on regex, it's not forbidden
- (bluefox) Set default state only for objects of type "state"
- (AlCalzone) include folders in the result of getAdapterObjects
- (Apollon77) Make sure to not trigger subscribes or messages when unload is called
- (Apollon77) deleting a not existing object is handled as success instead of Not-Exists error
- general dependency updates
- code style optimizations
- (foxriver76) fix output of
iobroker plugin status
command - (foxriver76) fix deletion of states on instance-deletion
- (Apollon77) add additional checks to prevent Errors (Sentry)
- (Apollon77) Make sure Sentry activation info is also shown on upgrade self command
- (Apollon77) Upgrade winston-daily-rotate-file library to prevent a crash case
- (Apollon77) Return empty array on non existing directory for readDir
- (foxriver76) fix "host this" command
- (Apollon77) Update Sentry plugin to be more transparent on temporary disabling reasons
- (foxriver76) fix error when writing binary States
- (foxriver76) catch error on alias ids with empty objects
- (Apollon77) make sure promise rejections without error are not crashing the controller
- (bluefox) Add Controller messages to allow read and write controller base settings (iobroker.json); introduce adapter feature flag CONTROLLER_READWRITE_BASE_SETTINGS
- (Apollon77) handle edge case where hostName is not a string when sending messages (Sentry IOBROKER-ADMIN-B)
- (Apollon77) handle case where letsencrypt directory can not be created (Sentry IOBROKER-ADMIN-C/IOBROKER-WEB-B)
- (bluefox) add IDs to some log messages
- (foxriver76) fix some logging in objects lib
- (Apollon77) make sure to catch error when reading log directory (Sentry IOBROKER-JS-CONTROLLER-1F)
- (foxriver76) Make decrypt and encrypt methods available in adapter object for developers. System secret is read automatically soonly the value is passed to the function
- (AlCalzone) Add adapter exit code 13 (ADAPTER_REQUESTED_REBUILD) to also allow to tell js-controller to rebuild this adapter.
- (Apollon77) change logging for invalid readFile actions to debug because ca be triggered also by other cases then planned ones. Update objects lib
- (Apollon77) make sure command on cmdExec is a string (Sentry IOBROKER-JS-CONTROLLER-1H)
- (Apollon77) Check more cases for existence of variables before accessing them (Sentry IOBROKER-JS-CONTROLLER-E)
- (Apollon77) Add a node.js version check and output special error message if node.js version is not satisfied
- (AlCalzone) Add missing parameter
digest
to crypto calls - (AlCalzone) further code optimizatons
- (AlCalzone) Allow reverse lookup of exit codes (exit code -> error name)
- (Apollon77) make sure Objects/States backup files are deleted correctly according to backup settings
- (foxriver76) Make sure default state value is only set if state is not existing also in setObject
- (foxriver76) check that alias is of type state when adding subscribing pattern
- (Apollon77) Make sure error are checked correctly (Sentry IOBROKER-JS-CONTROLLER-1N)
- (Apollon77) Inform about sentry activation if not configured on "iobroker setup first"
- (bluefox) implement maintenance mode for adapter methods
- (bluefox) store for binary states the binary flag in objects
- (Apollon77) update Plugin system
- (Apollon77) update Sentry plugin to respect all options to disable reporting including new disableDataReporting flag ( will be integrated into Admin later)
- (AlCalzone) Add Plugin CLI commands to enable/disable plugins
- (Apollon77) make sure disabling instances while installation is running do not crash the controller (Sentry IOBROKER-JS-CONTROLLER-Z)
- (From Forum) prevent error on backup restore
- (Apollon77) Make sure error handing do not throw exception
- (Apollon77) Catch all errors when trying to store the File DB (Sentry IOBROKER-JS-CONTROLLER-14/15)
- (Apollon77) Make sure also edge cases on start adapter are handled correctly (Sentry IOBROKER-JS-CONTROLLER-12)
- (Apollon77) Use 3.3.4 of objects library to prevent an error from 3.3.3
- (Apollon77) make sure to correctly create empty logfile on "delLogs" (Sentry IOBROKER-JS-CONTROLLER-Q)
- (foxriver76) make callback consistent when client has closed connection (Sentry IOBROKER-JS-CONTROLLER-R)
- (foxriver76) add missing Error for DB closed, which was used but undefined in tools.js
- (foxriver76) if buffer is of type object and not a buffer object log a warning - also bufferFrom null will also result in an error, prevent it (Sentry IOBROKER-JS-CONTROLLER-S)
- (foxriver76) in edge cases def can be an object, we also support this on extendObject
- (foxriver76) make sure stacktrace is there on validateId
- (foxriver76) avoid error on installAdapters function due to downloadRetry (Sentry IOBROKER-JS-CONTROLLER-V)
- (Apollon77) make sure Logfile is rewritten with empty content (Sentry IOBROKER-JS-CONTROLLER-Q)
- (Apollon77) Update Sentry Plugin to 1.0.0, adds pathBlacklist option, fixes pot. crash reason
- (foxriver76) ensure backward compatibility with auto decrypt function
- (Apollon77) Re-allow states to be set with no val property but check that there is at least one property
- (foxriver76) also call enumerateAdapterDocs when deleting all instances
- (Apollon77) correct error handling for letsencrypt challenge server
- (foxriver76) fix default value of extend*Object
- (AlCalzone) Add 'CONTROLLER_NPM_AUTO_REBUILD' to supported features
- (Apollon77) make sure system.config objects has correct type
- (foxriver76) make sure that callback of extend*Object returns object as before (was broken in 3.0.15)
- (Apollon77) make sure error cases are handled on zip file creation for objects (Sentry IOBROKER-JS-CONTROLLER-J)
- (Apollon77) make sure to check id when iterating over it (Sentry IOBROKER-WEB-3)
- (foxriver76) fix path on getInstalledInfo (was broken in 3.0.15)
- (Apollon77) Adjust ID checking to allow numbers for non foreign id's for now but log warn
- (foxriver76/Apollon77) Adjust extendObject logic and only set state when state was not defined before
- (Apollon77) check that path is found before using it on rebuild CLI command (Sentry issue)
- (foxriver76) fix error on caught process exceptions
- (foxriver76) make sure that procs[id] is not undefined in some cases (Sentry IOBROKER-JS-CONTROLLER-E/G)
- (foxriver76/Apollon77) handle weird case where io-package.json from controller is not on normal place when getInstalledInfo is called (Sentry IOBROKER-JS-CONTROLLER-B/C/D/F/H)
- (foxriver76) fix bug for some cases where common.def is used on creation of foreign objects
- (Apollon77) make sure error cases are handled on zip file creation for objects (Sentry IOBROKER-JS-CONTROLLER-J)
- First version for latest repository
- (Apollon77) catch errors when letsencrypt server can not bind to port 80 (Sentry IOBROKER-WEB-1)
- (Apollon77) fix in objects lib when db connection closes while loading view results
- (bluefox) fixes and optimizations
- (Apollon77) prevent logged error from file DB where it ws tried to write meta file for already deleted folders
- (Apollon77) display errors on npm uninstall
- (foxriver76) delete adapter and adapter.admin folders even if no corresponding meta objects exist
- (foxriver76) streamline dependencies/globalDependency checks in all places and allow different versions
- (Apollon77) fix crash when system views are not correctly initialized (Sentry IOBROKER-JS-CONTROLLER-9)
- (Apollon77) consider the Adapter Stop Timeout also for adapter restarts to give adapters enough time to stop before restarting
- (Apollon77) fix reported crash on obsolete object deletion (Sentry IOBROKER-JS-CONTROLLER-8)
- (Apollon77) fix reported crash when a new process can not be started because of ENOMEM (Sentry IOBROKER-JS-CONTROLLER-7)
- (foxriver76) make sure errors are return the same in two places
- (foxriver76/bluefox/Apollon77) small code optimizations
- (Apollon77) dependency updates
- (foxriver76) also allow to set user property for states
- (Apollon77) change FeatureFlag for Auto decrypt to ADAPTER_AUTO_DECRYPT_NATIVE
- (bluefox) Fixed vis debug
- (foxriver76/Apollon77) optimize and fix dependency checks to consider all dependencies correctly on install, upgrade and adapter start
- (AlCalzone) add
iobroker object extend
command - (AlCalzone) optimize performance when objects are duplicated and checked internally
- (AlCalzone) Add command
iobroker debug adapter
to start Node.js debug sessions for an adapter - (foxriver76) validate id also has to allow objects with correct properties (device, channel ...)
- (Apollon77) prevent crash if udp membership can not be added (Sentry IOBROKER-JS-CONTROLLER-5)
- (Apollon77) change object type for compact groups to "folder"
- (Apollon77) add adapter flag ALIAS_SEPARATE_READ_WRITE_ID
- (foxriver76) Remove mock for adapter.states.getState again, fixed two adapters
- (foxriver76) fix crash of redis setState when undefined is passed and refuse undefined as value in general
- (Apollon77) Make sure objects update from/ts/user when extending objects in all cases
- (Apollon77) Add "lc" property to list of allowed properties to set (prevent false positive errors with hm-rpc adapter)
- (Apollon77) Add mock for adapter.states.getState to prevent crashed with Soef Adapters
- (Apollon77) Make sure extendObject is checking object parts differently, prevent false positive logging
BREAKING CHANGES
- Nodejs 8.x will be no longer officially supported! Supported are nodejs 10.x, 12.x and (most likely) 14.x
Features
- (Apollon77) Enable zip Archive setting that it is on by default again. All Logs on Linux will be packaged to .gz on rotation. This can be deactivated by configuration (see Documentation)
- (Apollon77) Introduce CLI command "iobroker rebuild " or "iobroker rebuild self" (for controller) to execute an npm install/rebuild for the specified adapter
- (Apollon77) Detect the need for a rebuild because of a nodejs update by checking adapter crash error message and execute the "iobroker rebuild" command for the affected adapter up to 3 times.
- (foxriver76) Add ability to define separate read and write id for aliases (see Documentation)
- (foxriver76) Make file write intervals of objects and state file dbs configurable (see Documentation)
- (foxriver76) Check available RAM of the system before a new adapter process is started. If it is below 50/100MB log an error/warn and make it configurable via iobroker.json (see Documentation)
- (Apollon77) Add plugin system for js-controller and adapters (see Documentation)
- (Apollon77) Add and automatically enable Sentry as plugin for js-controller (see infos in README.md), can be disable per host via system.host.name.plugins.sentry.enabled (see Documentation)
Optimizations and Fixes
- (bluefox) Show options for start/stop/restart if more than one instance exists for the adapter
- (AlCalzone) Validate arguments for
iobroker del ...
CLI command - (bluefox) Log js-controller version by start of adapter too
- (Stabilostick) Set default certificate validity to 12 months, according to new Apple rules! Existing certificates will be recreated on controller installation if no custom certificate is used
- (bluefox) Also initialize objects with local redis connection details if setup command is called with "useRedis" parameter
- (foxriver76) Increase timeout of hostinfo command to prevent errors on systems with low CPU
- (foxriver76) The end of schedule adapters is no longer logged as error
- (foxriver76) Allow CLI commands to check status of an adapter instance
- (foxriver76) Enhancements and fixes for
iobroker list files
command, allow to specify exact meta folder name as parameter and not only the adapter - (foxriver76) Add forced repository update to help, add logging to show that it is used
- (foxriver76) Also delete uploaded vis widgets on adapter deletion
- (foxriver76) Restart referenced restart-adapters after uninstall also
- (foxriver76) Prevent dot as last char of an object or state id
- (foxriver76) Improve performance on filter actions (getObjectView) when redis is used as objects database
- (Apollon77) Optimize sigKill handling to prevent restart loops for edge cases and slow system
- (Apollon77) Optimize errormessage for invalid protocol on database connection and make easier understandable
- (Apollon77) Also catch unhandled promise rejections in adapters and handle like exceptions to allow error detection and automatic restart
- (foxriver76) Also remove objects from Enums on object deletion
- (foxriver76) Fix adapter exiting with wrong exit codes
- (bluefox) Fix restart CLI command
- (foxriver) Update cache manifest correctly on visdebug and fix process exit on non existing vis dir
- (foxriver76) No longer require restart of instance after alias object changes and other alias optimizations
- (foxriver76) Make sure files in internal file storage are always stored with correct path and also automatically fix existing entries
Developer relevant DEPRECATIONS/WARNINGS
- (foxriver76) Do not allow access to adapter.states and adapter.objects anymore and add warning logs to deprecate the usage. js-controller 3.1+ will remove these methods. Please adjust your adapters
- (foxriver76) Verify that a proper object of type "meta" exists when files are accessed in the internal ioBroker storage and output deprecation logging, these actions will be declined in js-controller 3.1+
- (AlCalzone) Validate the object argument to set[Foreign]State[Changed] and log warnings, such invalid set commands will be declined with js-controller 3.1
- (Apollon77) Move deprecation of getMessage to next controller version (3.1+)
- (foxriver76/Apollon77) Validate that id in several state and object methods is of type string and log warnings
- (foxriver76) Add basic checking for obj.common properties including logging. Please check logs and fix them, such invalid objects will be declined with js-controller 3.1
Developer relevant new Features
- (bluefox/foxriver76) Automatically encrypt all config attributes that are listed in common.encryptedNative in io-package, introduce ADAPTER_AUTO_DECRYPT_NATIVE (see Documentation) Admin support missing as of now!
- (bluefox) Introduce new dependency field for io-package called common.globalDependencies to check for global dependencies (see Documentation). Admin support missing as of now!
Developer relevant Optimizations and Fixes
- (Apollon77) Make sure that all places in adapters for states and objects that can return "really async" (e.g. because of DB communication) ALWAYS return async! (else callback !--count constructs can fail)
- (foxriver76) Also set default values of instanceObjects defined in io-package.json
- (bluefox) Improve extension mode for web extensions
- (foxriver76) Optimize extendObjects function of adapter.js (use from and ack)
- (foxriver76) Use from and ack when creating instanceObjects on installation of an instance
- (Apollon77) Fix potential crash where name is no string in some File object operations
- (foxriver76) Fix this.stop being undefined on daemon adapters
- (foxriver76) Also respect def values of io-package.json on automatic object recreation due to instance start
- (foxriver76) Respect state.from if provided on setState
- (Apollon77) Enhance checks for getObjectsView response
- general dependency updates
- code style optimizations
This version is especially for the new Windows Installer and will be used by it. It is not offered as normal update for the users on Linux (will not break, but not needed)!
- (AlCalzone) do not execute npm installs with --prefix but inside a given directory on windows
- (Apollon77) fix pot. crash for edge cases
- (Apollon77) allow to deactivate logfile zipping by iobroker.json (for non-windows systems)
- (Apollon77) make sure sigKill state only handles number values (fixes #638)
- (bluefox) add better checks for file CLI commands
- (Apollon77) make sure directory is created before writing meta data and send redis error correctly, prevent controller crash (fixes #644)
- (foxriver76) optimize package manager handling (fixes #631)
- (Apollon77) make sure deleting running instances does not crash js-controller (fixes #658)
- (Apollon77) Downgrade semver to stay compatible with nodejs 8
- (bluefox) Add for delObject the recursive flag to recursively delete objects; use feature flag ADAPTER_DEL_OBJECT_RECURSIVE in your adapter code to detect if the js-controller supports it or not!
- (bluefox) add check for sudo for package manager
- (Apollon77) Fix error on restore/validate when no name is provided
- (Apollon77) add/change checks for some calls (fixes #611 too ;-))
- (Apollon77) Add feature flag ADAPTER_DEL_OBJECT_RECURSIVE
- (Apollon77) adapter.restart used "terminate" directly which do not call unload and broke compact mode, changed to use stop()
- (foxriver76) Fix bug in nodejs version check and really disable adapter when requiring unsupported nodejs version
- (foxriver76) fixing issues in backup validation + add some missing commands to cli help
- (Apollon77) Do not have ioredis autoResubscribe because we do it by our own
- (Apollon77) change stopTimeout to prevent killing wrong process for long running "stopTimeouts" that were then fast in the end
- (bluefox) add CLI command "file rm" to delete files from ioBroker storage via command line
- (AlCalzone) fix some errors
- (AlCalzone) make sure repository hash is always checked correctly
- (Apollon77) make sure scheduled starts are also removed when a scheduled instance is stopped
- (Apollon77) make sure Multi-host discovery server does not unexpectedly restart when trying to stop ioBroker Master
- (Apollon77) add feature flag ADAPTER_SET_OBJECT_SETS_DEFAULT_VALUE for adapter class
- (Apollon77) allow sessions to run longer then 24days (fixes #618, addresses ioBroker/ioBroker.admin#467)
- (Apollon77) Check a wrong check for os on installation
- (Apollon77) Also check nodejs minimum version on adapter install
- (bluefox) fix CLI "state set"
- (Apollon77) Add some more logging to Objects/States DB
- (foxriver76) check if controller is running on
upgrade self
before controller upgrade (fixes #511) - (bluefox) Restart ioBroker after applying vendor information
- (Apollon77) fix pot. crashes happening while logs are rotated or packaged (thanks @mattberther and @rogerc)
- (Apollon77) Update deps
- (bluefox) disable log-symlink on windows because only admins are allowed to create symlinks here
- (foxriver76) fix async version of getEncryptedConfig
- (bluefox) obj type 'adapter' not set if installing adapter via octocat (#539)
- (bluefox) fixes Change settings of onlyWWW adapter cause exception (#549)
- Note: In order to remove custom settings you need Admin 3.7.6+
- (Apollon77) fix some more places where checks for not connected objects db were not triggered
- (Apollon77) add certificate handling if a local file is specified and do not overwrite if invalid in
setup first
- (Apollon77) add check in objects lib
- (Apollon77) only initialize PacketManager when needed to prevent error messages shown when not relevant
- (Apollon77) change logging when no packet manager found to info
- (Apollon77) disable gz-log-rotation on windows; remove added logging from debugging
- (Apollon77) make sure adapters and instances can be deleted again
- (Apollon77) make sure Redis simulator only set object data, all other logic is done in objects lib
- (Apollon77) create symlink to current logfile (fixes #578)
- (Apollon77) add some logging for archiving logfiles on windows
- (Apollon77) add warning messge for getMessage method to make deprecation more visible
- (bluefox) Fix wrong error handling for adapter deletions; should work again! Fixes #576
- (bluefox) Add Package installation by js-controller for Linux based systems (apt/yum package managers) via io-package common.osDependencies[process.platform]
- (Apollon77) readd getMessages to adapter.js and remove in controller 2.4 later to prevent to many adapter incompatibilities now
- (bluefox) CLI: check if object exists by "state set" command and other fixes
- (Apollon77) Make sure adapter with longer stopTimeouts can be restarted as usual; the "stopping" flag was blocking the restart logic
- (Apollon77) make sure adapters can be stopped again with setting .alive to false
- (Apollon77) optimize questions on
setup custom
- (Apollon77) fix log file rotation; additionally old logs are now packed with gz
- (bluefox) Fixed rights by object creation
- (bluefox) Add support for vendor specific logic and database initialization
- (Apollon77) make sure restart of instances work in all cases
- (AlCalzone) fix
iobroker start all
to not hang after starting all instances - (Apollon77) make sure auto rotation for logs work now with winston and make sure "old style manual cleanup" too
- (Apollon77) fix error when 'iobroker url' is called without any parameter
- (Apollon77) separate system and user/adapter subscribes, introduce "changeUser" trigger for States and Objects
- (Apollon77) Also allow ÄÖÜäöüа-яА-Я as characters for first character
- (Apollon77) Also log exceptions for compact group controller
- (Apollon77) Update dependencies
- (bluefox) remove getMessage and lenMessage from adapter methods because deprecated since long time
- (Apollon77) Remove Socket.io compatibility layer - master/slave systems coming from 1.5 need to update to 2.0 or manually!
- (Apollon77) make options parameter for getObjectList optional again
- (bluefox) Fix host deletion
- (Apollon77) update objects lib to prevent one crash case and make sure extendObject works as intended also for JavaScript adapter
- (Apollon77) make sure adapters are also reinstalled correctly when used in compact groups
- (Apollon77) Stable Release as minor update to separate from development/testing phase
- (Apollon77) optimize stopping and restarting behaviour (again)
- (Apollon77) enhance backup error handling for invalid files - they now display errors and not break the backup process
- (Apollon77) make sure new enabled/moved instances are started directly
- (Apollon77) increase object init timeout for adapter starts before complaining/stopping
- (Apollon77) fix file read/write to not allow invalid locations and add some more checking
- (Apollon77) add some more logging for ioredis initializations
- (Apollon77) Correct error message if certificate can not be parsed
- (bluefox) Fix upload of material adapter
- (Apollon77) prevent crash when adapter instance is deleted which is also running currently and if stopped by deletion
- (bluefox) make sure getForeignStates do not modify the input ids list
- (Apollon77) enhance
list instances
and only show compact infos if adapter supports it
- (Stabilostick) enhance certificate methods and add certificate checks in setup first
- (Stabilostick) add
iobroker cert view <name>
CLI command - (Apollon77) fix problems in stop controller handling
- (Apollon77) make sure multiple instances of same adapter do not disturb each other in compact mode, finalize compact mode
- (AlCalzone) correctly handle git commits and branches as custom install sources
- (Apollon77) make sure callbacks with setImmediate return the real values from code execution and not pot. changed values from other actions (fixing file content being undefined when write/read happen in parallel)
- (Apollon77) handle more cases for aliases automatically (On/Ein is converted to true case insensitive now)
- (bluefox) getForeignStates() return correct ids when used with aliases
- (Apollon77) optimize controller group stopping
- (Apollon77) when target state is deleted also emit "null" onChange events to adapters for alias states
- (Apollon77) optimize controller stop behaviour with compact groups
- (Apollon77) make sure that schedules instances can start even after a "once" run that set a sigKill value
- (Apollon77) add method to synchronize file directories with file DB storage
- add new CLI command "iobroker file sync " to do the sync
- integrate the sync with "iobroker setup first"
- (Apollon77) "upgrade name" for a controller will return an error to use "upgrade self"
- (Apollon77) "upgrade all" will no longer update controller too
- (Apollon77) add some more checks in adapter.js for existence of states/objects
- (Apollon77) enhance
iobroker setup custom
for Redis sentinel usage - (Apollon77) make sure flot store works again also with objects with empty names
- (Apollon77) Add some more logic to prevent access with invalid ids
- (Apollon77) change "enhancedLogging" to not be global but "per DB"
- (Apollon77) Fix compact mode on Windows systems
- (Apollon77) make sure multiple callbacks to "unload" will be ignored
- (bluefox) Rise all user in admin group to administrators
- (Apollon77) Allow buffers to be passed in messages again
- (bluefox) Fix session storage
- (Apollon77) Introduce 0_userdata as new home for user specific files, objects and states
- (Apollon77) Enhance logging
- (bluefox) fix letsencrypt (was broken n 2.0.35)
- (Apollon77) fix install adapter starts like vis installation when db is not available
- (Stabilostick) Auto generated self-signed certificates need to have a max duration of 2 years according to new Apple rules
- (Apollon77) Allow to use Redis password as "pass" parameter for States and Objects
- (Apollon77) Prevent hangs on "iobroker upgrade self" from 1.5 to 2.0
- (bluefox) Update IPs information periodically
- (bluefox) Remove safe-replace, bluebird, pyconf packages
- (paul53/AlCalzone/Apollon77) Fix datatype of system.host.cpu and system.adapter.XY.Z.cpu
- (Apollon77) Make sure alias.0 and other controller objects are also checked and created if needed on setup first when updating
- (bluefox) Allow one state to multiple aliases connections
- (Apollon77) Make sure required adapters are also checked correctly when using compact mode and groups
- (Apollon77) Enhance logging for unsupported (should not happen) commands
- (Apollon77) Allow custom settings to be removed again if objects are "file"
- (Apollon77) Remove default value for "switch" and "level.dimmer" roles
- (bluefox) fix user authentication
- (Apollon77) Sync objects and states retry max delay defaults
- (Apollon77) Re-Add the certificate check and automatic re-creation for old certificates as in 1.5.14
- (Apollon77) Also restart controller if only states connection disconnects
- (Apollon77) fix undefined variable on one place
- (Apollon77) enhance reconnection handling (system tries to reconnect up to 40s including re-sending all data changes before restart happens, on no connection to db on start a restart is tried every 30s)
- (Apollon77) fix file handing issue
- (bluefox) handle empty states correctly in Redis scenarios
- (Apollon77) fix backup on empty/null states
- (Apollon77) Correct meta data return for some special cases
- (Apollon77) Correct some potential object issues
- (Apollon77) Make sure Logs are only streamed to admin for selected loglevel
- (Apollon77) Fix "iobroker file write"
- (Apollon77) Make sure invalid ids are handled correctly without throwing errors
- (bluefox) Add alias.0 as object to be added
- (bluefox) Allow Arrays as state values
- (bluefox) Translate object names
This is the First version which is released into Latest Repository.
- (Apollon77) Also allow states/objects with capital letters as first letter
- (Apollon77) fix adapter/instance deletion
- (AlCalzone) fix CLI get state getValue
- (Apollon77) increase LUA script timeout
- (Apollon77) update in objects lib, also update other dependencies
- (bluefox) small logging optimization
- (Apollon77) optimize performance, especially for file/file systems
- (Apollon77) enhance path sanitization
- (Apollon77) hopefully prevent Redis errors on connection close
- (Apollon77) fix adapter logging with --debug flag
- (Apollon77) fix Adapter Restarts also for widgets
- (Apollon77) work on some performance optimizations
- (Apollon77) Fix binary state handling
- (Apollon77) make sure also states starting with "io" will be notified on stateChange
- (Apollon77) fix Loglevel change via instance state
- (Apollon77) make sure subscribes for instances states are correctly passed through to adapter for all cases he subscribed them (also for special states like logLevel or sigKill)
- (Apollon77) make sure id filtering also works correct for >10 instances of the same adapter
- (Apollon77) some more small fixes and optimizations
- (Bluefox) Do not kill instance in debug mode on PID mismatch
- (Apollon77) fix migration
- (Apollon77) fix potential cases where objects/states files were not stored
- (Apollon77) allow to specify network family for redis library, defaults to 0 (IPv4 and IPv6)
- (Apollon77) delay parallel start of scheduled instances to prevent system overload scenarios (same rules asd for adapter start, basically 4s delay)
- (Apollon77) Optimize some Migration questions
- (Apollon77) smaller fixes and optimization
- (Apollon77) streamline redis vs file States handling which was different also before controller 2.0:
- not set states will always return null now
- States will set to null completely (not only value) when they expire
- States will also be published to onChanged handlers when states are in Redis
- (Apollon77) rework expiry handling for File-States to use Timeouts
- (Apollon77) fix checking if ioBroker is running (bug in 2.0.13)
- (Apollon77) upgrade socket-io deps
- (Stabilostick) Randomize Certificate Serial numbers
- (Apollon77) optimize
iobroker status
CLI command - (Apollon77) some other small fixes
- (Apollon77) remove clearAllLogs logic
- (Apollon77) Correct selections with wildcards at the beginning, should solve the admin issues
- (Apollon77) Optimize Compact mode CLI commands (fixes #468, fixes #471, fixes #470)
- (Apollon77) fixes #475, #476
- (Apollon77) only use quit from redis and let ioredis handle the disconnect, hopefully fixes #472, update objects-ha-lib to 1.1.20
- (Apollon77) object changes are only logged as debug from now on, fixes #473
- (Apollon77) Some adapter tweaks when running in "--install" mode (no reporting, don't check sigKill)
- (Apollon77) Optimize Adapter and Controller stopping processes further
- (Apollon77) Optimize redis connection handling on exit
- (Apollon77) Update objects-ha lib to 1.1.19
- (Apollon77) Optimize Adapter and Controller stopping processes
- (Apollon77) Correct file based internal structure to prevent entries with "//" in the path
- (Apollon77) Check for existing of states DB in some more places to prevent problems in compact end scenarios
- (Apollon77) try to add a better retry logic on disconnect to the DBs, restart after 30s
- (Apollon77) make some file operations with Paths more compatible to former versions
- (Apollon77) prevent "keys Not found" error in log, be more redis compatible, fixes #461
- (Apollon77) prevent "invalid instance object" errors for channel objects, fixes #462
- (Apollon77) optimize further on compact- and general adapter starting mechanisms to better prevent multi-starts
- (Apollon77) update objects-ha lib to 1.1.17 to normalize filenames to prevent problems on double-slashes
- (Apollon77) fix some error while accessing custom directories, fixes #455
- (Apollon77) Add more logic to better handle migration edge cases (especially slaves vs migrations), fixes #458
- (Apollon77) Make sure invalid alias values do not crash controller process (logger was missing), fixes #456
- (Apollon77) Add better error and fallback handling for compact mode, fixes #460
- (Apollon77) fixes #434, host command
- (Apollon77) Add one more confirmation question when migrating objects
- (Apollon77) Log Process-ID for all adapter log messages
- (Apollon77) When Objects/States connection dies and is no longer able to be restored for adapters we end the adapter process. This prevents us from hanging processes
- (Apollon77) End adapters with code 11 when they decide to end itself because they are not the current process, so that no additional restarts happen
- Minimum requirement for js-controller 2.0 is nodejs 8.x
- Manually uploaded files into
iobroker-data/files/...
may no be fully supported. Please make sure to put them into officially allowed directories, e.g. vis.0 - The following Adapters needs to be updated to the listed versions to be compatible with js-controller 2.0
- simple-api 2.1.2 or higher
- email 1.0.5 or higher
- pushover 1.1.1 or higher
- hue 1.2.4 or higher
- node-red 1.10.1 or higher
- vis 1.2.1 or higher
- iqontrol 0.2.6 or higher
- socketio 2.1.2 or higher
- radar2 1.0.9 (1.2.0 from Github needs a manual fix!)
- ring 1.0.5 or higher
- (Bluefox/Apollon77) Add Compact Mode and compact groups, see Compact Information in README (Technology Preview)
- (bluefox) Add build-in Alias handling for Objects/States, see Alias Information in README (Technology Preview)
- (Bluefox/Apollon77) Add support to also use Redis for Objects and Files, see Redis Objects Information in README
- (Apollon77) Add Redis sentinel support, see Redis Sentinel Information in README
- (Apollon77) Allow dynamic change of Loglevel for adapter instance and js-controller hosts processes, see Dynamic Loglevel changes Information in README
- (Bluefox) Add optional migration for State and/or Objects values when using
setup custom
. - (Apollon77) add monitoring for event-Loop-Lag as host and adapter objects. This can be used to analyze if an node.js process is blocked too much
- (foxriver76) add possibility to validate backup files
- (alcalzone) Support command
iobroker logs
- (Stabilostick)
cert create
CLI commands - (Apollon77) Remember installation location for re-installations. For GitHub installs it gets the exact commit hash to reinstall really the correct version
- (Apollon77) Use remembered installation location for automatic adapter installs (e.g. if missing, host move cases)
- (Apollon77) adds adapter.supportsFeature('NAME') method to check if a certain feature exists. fixes #244, see Adapter Feature Detection Information in README for information and the full list of allowed features
- (foxriver76) Ability to define secured objects in io-pack access only via own adapter and admin, details see #287
- (foxriver76) added getObjectView and getObjectViewAsync on adapter object
- (foxriver76) added getObjectList and getObjectListAsync on adapter object
- (bluefox) allow the deletion of multiple objects with wildcard
- (foxriver76) setObject/setObjectNotExists now also sets default value of state after object creation
- (Apollon77) allow getPort to check for the port optionally on a certain host/IP
- (Apollon77) Streamline redis vs file States handling which was different also before controller 2.0:
- not set states will always return null now
- States will set to null completely (not only value) when they expire
- States will also be published to onChanged handlers when states are in Redis
- (Apollon77) Rewrite InMem databases (States & Objects) to TCP (redis compatible) protocol and deprecate socket.io version; will be removed approx. in v2.1. This change should prevent us from "Reconnection to DB" errors
- (bluefox) Add adapter handling to prevent "error 7" (adapters will stop itself as soon as PID is not as expected)
- (Apollon77) upgrade all dependencies, means: 0 vulnerabilities :-)
- (AlCalzone) Don't chmod 777 after controller upgrade
- (alcalzone) refactoring of many CLI commands
- (bluefox) add possibility to return zip file as a link and not as base64
- (bluefox) standardize error codes
- (alcalzone) Root should always npm install with --unsafe-perm
- (bluefox) enable gzip to read repositories
- (bluefox) read hash of sources.json before read the whole file
- (bluefox) Add some information to user-agent, like chrome, IE and Firefox do by update checks - the information is absolutely anonymous
- (bluefox) verify the version of node.js by start of the instance
- (bluefox) hide cmd window on windows
- (AlCalzone) Include certificate creation in
setup first
- (bluefox) suppress warning by npm install
- (bluefox) allow optional dependencies being installed
- (Apollon77) optimize
setup custom
and add more user guidance - (Apollon77) Add Feature overview to README
- (bluefox) forward upload console outputs from slave to master
- (Apollon77) make sure to upload and upgrade all relevant objects on installations and updates of adapters
- (Apollon77) always upgrade instance objects after successful installs or upgrades
- (Apollon77) optimize adapter start processes and such, especially when combined with needed automatic installations of adapters, also for error cases
- (Apollon77) after 2 installation tries with "last-installedFrom" use the installedVersion field to try to install from npm
- (Apollon77) hosts now ignore object changes when the affected instances is still in installQueue
- and much more code refactoring and optimizations in various places
- (Apollon77) log scheduled restarts as info only (fixes #315)
- (Apollon77) fixes #340 to maintain restartSchedule on updates
- (Apollon77) fix bug where "ack" was possible to set to any value via cli
- (alcalzone) Enable ESLint and fix most issues
- (bluefox) optimize multi host upload
- (Apollon77) Restart stopped adapters at the end of the upload and not before to make sure to not have two adapter restarts on upgrade cases
- (Apollon77) Enhance checks for failed installations in cli and controller
- (Apollon77) also update adapter instance statistic objects when no instanceObjects are defined
- (Apollon77) "alive" state values are only checked on adapter start if ack=true to allow to start a process if not running
- (Apollon77) fixes for multi-host detection
- (Apollon77) fix backup of states
- (bluefox) Make sure also VIS global CSS is included in backup and restored
- and many more fixes in various places
- (Stabilostick) Make sure Info Adapter Tab is displayed automatically on install
- (Stabilostick) Add CLI host commands to CLI usage help
- (Stabilostick) Replace winston-syslog dependency to prevent build errors on node.js 10+ when installing or updating ioBroker (not needed in 2.0.0)
- (Stabilostick) Replace default self signed SSL certificate to prevent errors in Node.Js 10.16+
- (Apollon77) Also replace default certificate used for all Web and Admin instances if the old certificate was used, so restart will use the new certificate
- (Apollon77) Install instance of info adapter too on first setup of controller
- (Apollon77) Allow to install specific versions/fix installing specific versions
- (bluefox) Read cache of repository before download the whole file
- (AlCalzone) if npm returns code 1 it is OK
- (AlCalzone) fix instances enumeration
- revert greenlock version to 2.7.1
- Required version for normal functionality: javascript 3.6.5, dasWetter: 2.7.1, upnp: 1.0.0
- (bluefox) Fix let's encrypt
- (bluefox) Fix "iob" script
- (Dominic Griesel) Revert the changes to
del[Foreign]State
, so the object is not deleted. - (bluefox) always install the version from repository and not the latest from npm
- (Ingo Fischer) Root should always npm install with --unsafe-perm
- (bluefox) fix iobroker stop
- (bluefox) fix Empty ID error
- (bluefox) fix error with formatDate
- (bluefox) disable the auto-control of quality codes
- (bluefox) Let's encrypt fixes
- (bluefox) Fix SSL issue with authentication
- (bluefox) Breaking changes: "][*,;'"`<>?" are no more allowed in IDs
- (bluefox) the user by changing of states and objects is logged
- (bluefox) install specific version of missing adapter
- (bluefox) add disk info
- (bluefox) add memAvailable state
- (bluefox) add noChmod experimental settings
- (bluefox) stop instances only if they belongs to current host
- (bluefox) delete adapter only on current host and leave it on others
- (bluefox) Combine States and Objects (#203)
- (bluefox) Implement adapter.terminate('Because I need it') (#197)
- (alcalzone) add restart, disable, updateConfig methods to Adapter class
- (bluefox) add reinstall.js
- (bluefox) add "iob" as shortcut
- (bluefox) add getInterfaces to sendToHost
- (bluefox) implement backup of data folders via dataFolder flag
- (alcalzone) Add a wrapper method to safely expose ES6 classes to legacy code
- (bluefox) add information if instance is alive in "list instances"
- (stabilostick) added 'pidusage' for information about cpu and new states per adapter instance
- (bluefox) support of new mime types: pdf, doc, xls, ppt
- (bluefox) implement flag common.eraseOnUpload
- (bluefox) set quality codes on connection lost and adapter disconnect
- (alcalzone) Give adapters a chance to handle their own uncaught errors
- (alcalzone) Add call stack information to hard to trace error logs
- (bluefox) add pattern2RegEx to tools
- (apollon77) the node10 testing was added
- (bluefox) the read file function was protected
- (bluefox) possible access rights problem was closed
- (bluefox) refactoring of memory calculations
- (bluefox) set default values of states by creation of new instances
- (alcalzone) Fix "install npm" messages, upgrade node typings to v6
- (bluefox) check if mem file could be read
- (buzzy1337) fix calculation of kilobyte to megabyte and fix reading /proc/meminfo
- (bluefox) Fix: Access to log files through admin does not work
- (bluefox) fix redis disconnect
- (bluefox) Update acme to V2 (#199)
- (bluefox) Improve deleteDevice (#186)
- (bluefox) fix cookie expiration
- (alcalzone) several async and testing fixes
- (bluefox) timeout for npm check added
- (bluefox) fix "object chmod 777 777 javascript.0.*" command
- (bluefox) do not send ready second time on reconnect db
- (Apollon77, Bluefox) prevent defaultObj to be overwritten with normal common details
- (bluefox) fix error if ID is empty
- (bluefox) check id by setObject
- (apollon77) Add amazon-dash to list of adapter to be installed with unsafe-perm
- (bluefox) leave backitup enabled after restore
Main changes: add instance with desired number, Force using of socket.io 2.1.0, Bugfixes
- (bluefox) fix error with letsencrypt debug output
- (bluefox) fix delObject
- (bluefox) fix restore of backup
- (bluefox) allow to add instance with desired number
- (apollon77) fix auto multi-host
- (bluefox) fix for adapter update
- (bluefox) Force using of socket.io 2.1.0
Main changes: uninstall via npm, downgrade winston-syslog, refactored deleteAdapter, object.json auto-backups
- (AlCalzone) fix npm version pre-install check
- (bluefox) remove winston-syslog 2.0 and replace it with 1.2.6
- (AlCalzone) refactored and promisified
deleteAdapter
anddeleteInstance
- (bluefox) remove controller from the adapters list in admin
- (bluefox) also uninstall adapters using npm
- (bluefox) backup object.json files every 2 hours for last 48 hours (warning! Disk usage)
- (bluefox) added cli command to update/add the vis/knx license
Main changes: socket.io Version downgraded because of bug. Better npm5 support
- (AlCalzone) Remove the outdated npm package and disable package-lock before installing (#175)
- (AlCalzone) reworked npm adapter version check without
npm
package - (AlCalzone) ignore local NPM for version check
- (AlCalzone) don't modify the parent's process PATH variable
- (AlCalzone) check npm version before installing and potentially disable package-lock
- (AlCalzone) don't cancel installation, or we're breaking ioBroker anyways
- (AlCalzone) ignore local npm version for preinstall check
- (bluefox) move socket.io from 2.0.4 to 1.5.1 because of bug
- (bluefox) add intro to default tabs
Main changes: support of npm5, Multihost fixed, added promises to adapter.js
- (bluefox) fix multi-host connect
- (bluefox) add "multi-host status" command
- (bluefox) make statistics interval adjustable
- (bluefox) better scan of installed adapters
- (bluefox) better deletion of adapters
- (bluefox) fix requests like getStates('*.info.connection')
- (bluefox) create instance's objects by start.
- (AlCalzone) Add promisified methods to the adapter class
- (AlCalzone) enable basic type-checking and fix found error
- (Apollon77) fix potential error and check if that.log exists
- (bluefox) updates npm packets
- (Apollon77) log an error when npmInstallWithCheck throws
- (AlCalzone) [npm5] Disable package-lock.json before installing anything
- (Apollon77) use stable tag from admin in dependencies
- (bluefox) fix empty ID error
- (bluefox) move buildRepository.js to ioBroker.repositories
- (bluefox) fix adapter download
- (Apollon77) also include npm5 fix into reinstall.sh
- (bluefox) add functions to standard enums
- (bluefox) check if pattern is valid
- (bluefox) catch error by deleting of adapter.
- (bluefox) better adapter directory search
- (Apollon77) another fix for reinstall.sh, add --unsafe-perm
- (Apollon77) exit mocha tests explicitely when completed, needed pot. with most current version of mocha
- (Apollon77) add npm5 check and "Block" to "iobroker install" commands
- (bluefox) The fix for npm5
- (bluefox) fix windows problem and storing of error messages
- (bluefox) fix logging level: silly
- (bluefox) fix dependency check
- (bluefox) fix small errors
- (bluefox) add repo commands to cli
- (bluefox) setTimeout(0) => setImmediate
- (bluefox) add timestamp and "from" information object
- (bluefox) allow to enable redis by setup
- (bluefox) catch backup errors
- (bluefox) ignore errors by setup first
- (bluefox) fix generate repository
- (bluefox) calculate number of datapoints in vis and deliver it in statistics
- (bluefox) fix restoring of backup
- (AlCalzone) fix install urls ending with ".git"
- (bluefox) fixed upgrade command
- (bluefox) allow install from custom repositories
- (bluefox) remove online and sources repositories
- (bluefox) fix multihosts command
- (bluefox) catch the error outputs of instances if they die
- (bluefox) no more support for node.js 0.10/0.12
- (bluefox) add new logging level: silly
- (bluefox) Extend statistics (node.js versions and some HW parameters will be reported)
- (bluefox) Update npm packets
- (bluefox) catch semver error
- (bluefox) change interface of getDevices functions
- (bluefox) change interface of createChannel functions
- (bluefox) working on multi-host service
- (bluefox) fix users cli
- (bluefox) implement defaultNewAcl
- (bluefox) remove 0.10 and add 8 by tests
- (bluefox) fix restart of adapters
- (bluefox) Close sockets by default for external connects
- (jens-maus) allow redis connections via unix sockets by specifying host as e.g. '/var/run/redis/redis.sock' and setting port to 0. This should slightly improve performance on busy installations.
- (Apollon77) optimizations for permission handling
- (bluefox) BREAKING Changes: For multi-host systems the user MUST explicit allow connections from other IPs in /opt/iobroker/iobroker-data/iobroker.json
"host": "127.0.0.1",
=>
"host": "0.0.0.0",
for objects (line 11) and for states (line 21).
- (bluefox) getHostInfo for new admin
- (bluefox) allow using of files for certificates
- (bluefox) always install zwave with unsafe-perm option
- (apollon77) add handling for undefined
- (apollon77) uptime is a number only and no String/List/Array beside the fact that also with a number a "toString" should exist, or it's undefined because an old host is listed with no value ...
- (bluefox) Change repository generation (not relevant for users)
- (bluefox) small change for install porcess (not relevant for users)
- (bluefox) No big changes, just version
- (bluefox) remove warning about iDs
- (bluefox) fix tests
- (bluefox) try to ignore npm error 1
- (bluefox) fix possible error.
- (bluefox) create states with ack=true by default
- (bluefox) do not store logs and messages and just publish it
- (bluefox) remove mochawsome
- (bluefox) add stable repository
- (bluefox) fix bug with user=>users (required for user rights)
- (bluefox) install discovery adapter too if exists at first start
- (bluefox) extend configuration with city, country and GPS coordinates
- (bluefox) send city and country in statistics and allow to disable it
- (bluefox) fix "iobroker passwd username"
- (bluefox) use SHA256 instead of SHA1 (All passwords must be reset via "iobroker passwd username")
- (bluefox) change cli commands for user: user add, user del, user set, user enable...
- (bluefox) replace letsencrypt with greenlock
- (bluefox) try to fix sha256 issue with node.js 0.10.x
- (bluefox) add uniti
- (Apollon77) change reinstall.sh script
- (bluefox) add setStateChanged
- (bluefox) implement event counters
- (bluefox) read values from cache if possible in adapter
- (bluefox) add parser adapter, smartmeter, fakeroku, wetty, fronius, Worx Landroid Rasenmäher
- (bluefox) fix log sources
- (bluefox) fix callbacks calls by setObjectNotExists
- (bluefox) fix getForeignObjects
- (bluefox) write tests
- (Patrick) adapter.namespace now always int (was int or string mixed)
- (Patrick) _fixId better results for empty obj and string (return namespace + '.')
- (bluefox) small fixes for multi-host
- (bluefox) add getInstalledAdapter for autodiscovery
- (bluefox) fix of autoSubscribe
- (bluefox) no extra uplaod if install of adapters from github
- (bluefox) documentation of adapter
- (bluefox) support of autoSubscribe
- (bluefox) add innogy-smarthome, vis-players
- (bluefox) fix error with "preserve" settings
- (bluefox) restart adapter immediately if desired
- (bluefox) support of web extensions
- (bluefox) add debug information for logging
- (bluefox) remove occ
- (bluefox) add mpd, icons-fatcow-hosting
- (bluefox) update node-schedule
- (bluefox) add cli command "show uuid"
- (bluefox) try to fix issue with npm3
- (bluefox) add console command "repo [name]"
- (bluefox) try to extract the information from local sources-dist.json it online not reachable
- (bluefox) add host remove
- (bluefox) install non enabled adapters
- (bluefox) install icons on backup too
- (bluefox) fix some sporadic errors
- (bluefox) support of getLocationOnDisk message for admin
- (bluefox) allow upgrade to specific version, like adapter@0.1.0
- (bluefox) you can change any native parameter of instance with set
- (bluefox) add support of syslog (see iobroker.json to enable)
- (bluefox) add radar
- (bluefox) do not change title of instance by upload and update
- (bluefox) fix new installation
- (bluefox) fix renaming of host by start
- (bluefox) implement auto-objects and auto-states for adapter
- (bluefox) recursive deletion of folders with objects.unlink
- (bluefox) support of tarballs as install path
- (bluefox) rename rpi to rpi2, homekit to homekit2
- (bluefox) add upnp
- (bluefox) fix fileName of log file
- (bluefox) remove peerDependencies
- (bluefox) fix letsencrypt to use fullchain.pem
- (bluefox) fix error with emitter
- (bluefox) fix formatDate for russian month
- (bluefox) backup letsencrypt files too
- (bluefox) install missing adapters one after other and not parallel.
- (bluefox) let remove UUID to prepare images with ioBroker
- (bluefox) using peerDependencies
- (bluefox) rename host automatically if singlehost
- (bluefox) add write/read properties to alive variable
- (bluefox) fix creation of package.json for npm 3
- (bluefox) try catch for parse of states
- (appolon77) add possibility to send messages with json
- (bluefox) updates some packages
- (bluefox) print node.js version at start
- (bluefox) force logger to use local time
- (appolon77) fix multi instance messaging
- (bluefox) using peerDependencies
- (bluefox) rename host automatically if singlehost
- (bluefox) update artnet
- (bluefox) add vis-canvas-gauges
- (bluefox) add rflink
- (bluefox) add foobar2000
- (bluefox) add mqtt client
- (bluefox) add lgtv
- (bluefox) add pushsafer
- (bluefox) fix read versions by multi-host
- (bluefox) add owntracks
- (bluefox) add amazon-dash
- (bluefox) control enabled for instance over system.adapter.NAME.INSTANCE.alive variable
- (bluefox) fixed letsencrypt file
- (bluefox) working on objects in redis
- (bluefox) add botvac adapter
- (bluefox) better multi-host
- (bluefox) fix formatDate
- (PArns) fix upgrade of adapters
- (bluefox) update "_design/xyz" by upgrade
- (bluefox) fix upgrade of adapters
- (bluefox) fix dependency if depend on js-controller
- (bluefox) implement auto-restart of adapters (expert mode)
- (bluefox) add rights check for getBinaryState/setBinaryState
- (bluefox) support of default ttl for sessions
- (bluefox) fix custom setup
- (bluefox) fix upload binary files
- (bluefox) fix list of files in subdirectories
- (bluefox) support of chained certificates
- (bluefox) add nut
- (bluefox) add vis-map
-
(bluefox) suport of exportand import
-
(bluefox) activate redis for states
-
(bluefox) fix install of adapter with singletonHost
-
(bluefox) issue event if state deleted (redis)
-
(bluefox) fix error with administrator users
-
(bluefox) do not store repository if with errors
-
(bluefox) fix checkPassword and setPassword
-
(bluefox) update wrong SSL certificates
-
(bluefox) add freemem state to host
-
(bluefox) add milliseconds to formatDate
-
(bluefox) update tar.gz
-
(bluefox) add fhem
-
(bluefox) add netatmo
-
(bluefox) add tankerkoenig
-
(bluefox) add vis-history
-
(bluefox) add homepilot
-
(bluefox) add cloud
- (bluefox) make from seconds the ms
- (bluefox) add console command "isrun"
- (bluefox) add "--timeout 5000"
- (bluefox) fix small errors
- (bluefox) change function formatValue
- (bluefox) fix stop of scheduled adapters
- (bluefox) add "--logs" flag for adapter start (required by adapter debugging)
- (bluefox) make hostname configurable
- (bluefox) fix update of adapters and settings
- (bluefox) fix restart script
- (bluefox) update default certificates
- (bluefox) do not handle exceptions in logger
- (bluefox) change logger
- (bluefox) set valid mimeType for *.manifest
- (bluefox) add noolite adapter
- (bluefox) change download script
- (bluefox) change rename script
- (bluefox) add starline
- (bluefox) change repository building
- (bluefox) add 'delete' objects
- (bluefox) change behavior by exceptions
- (bluefox) workaround for DHCP delay
- (bluefox) fix passwd command
- (bluefox) do not write error under windows: "cannot delete log file"
- (bluefox) replace winston with latest module
- (bluefox) add syslog support
- (bluefox) fix some LINT warnings
- (bluefox) add "host self" command (identical to "host this")
- (bluefox) fix error with npm 3 if no node_modules directory found
- (bluefox) support of noCache flag
- (bluefox) fix error if _data.json file broken
- (bluefox) support of file uploading: iobroker fileName /adapter/fileName
- (bluefox) fix getForeignObjects
- (bluefox) add telegram
- (bluefox) enable OEM naming
- (bluefox) fix small error if multi-host not available
- (bluefox) add reinstall script
- (bluefox) add vis-justgage adapter
- (bluefox) add mysensors
- (bluefox) add text2command adapter
- (bluefox) fix upload problem
- (bluefox) use node-schedule 1.0.0
- (bluefox) extend node node_modules/iobroker.js-controller/lib/buildRepository.js command
- (bluefox) update version of node-schedule to fix problem with Februar.2016
- (bluefox) update socket.io version
- (bluefox) add logo image
- (bluefox) add buildRepository.js
- (bluefox) If desired, that adapter must be terminated
- (bluefox) use isFloatComma in formatValue
- (soef) formatDate extended and formatValue added
- (soef) formatDate extended to use seconds as duratiorn
- (soef) formatValue added to convert a value to a string with thousand separator....
- (bluefox) add homekit and miele
- (bluefox) fix upload of files
- (bluefox) fix version
- (bluefox) fix log outputs
- (bluefox) add commands like "npm start"
- (bluefox) check singletonHost one on host
- (bluefox) add memoryLimitMB for controller and adapters
- (bluefox) make install from NON-git sources possible again.
- (bluefox) add rpi, weatherunderground, chromecast, geofency, samsung, squeezebox, vcard, yamaha
- (husky-koglhof) occ und rpi Adapter
- (angelnu) visdebug - check for different adapter directories
- (bluefox) enable install of icons-open-icon-library-png
- (bluefox) fix upgrade.
- (bluefox) fix permissions for administrator group, but not admin user.
- (bluefox) support of getHistory command and defaultHistory
- (bluefox) implement "iobroker restart adapter"
- (bluefox) enable write dependencies as an object
- (bluefox) remove directory adapter and move example to iobroker.template
- (bluefox) prepare support of syslog
- (bluefox) add ioBroker.sql
- (bluefox) add ioBroker.influxdb
- (bluefox) remove example adapter (it is replaced with iobroker.template)
- (bluefox) start of renaming of js-controller to enable branding
- (bluefox) add command visdebug
- (bluefox) add flag preserveSettings
- (bluefox) add vis-keyboard
- (bluefox) fix error with host rename
- (bluefox) fix sendTo and sendToHost with callback.
- (bluefox) update objects by upload of adapter (important for community adapters)
- (bluefox) add vis-google-fonts
- (bluefox) support of quality in setState
- (bluefox) add adapter mobile
- (bluefox) fix restart under linux
- (bluefox) add wolf adapter to repository
- (smilingJack) increase timeout by update of repository
- (bluefox) fix set --ssl
- (bluefox) add "connectTimeout" parameter to iobroker.json. Try to fix EADDRINUSE error under raspi.
- (bluefox) add vis-jqui-mfd
- (bluefox) allow install direct from github in admin
- (bluefox) add vis-fancyswitch, vis-rgraph
- (bluefox) fill state by createState even if no default value set
- (bluefox) add modbus
- (bluefox) add terminal adapter
- (bluefox) inplement "iobroker url xxx"
- (bluefox) fix restore
- (bluefox) fix _failCounter entry in Adapters
- (bluefox) fix log outputs
- (bluefox) fix installation of adapter
- (bluefox) fix first installation
- (bluefox) fix broker upgrade
- (bluefox) improve vis upload
- (bluefox) fix adapter.deleteChannel
- (bluefox) use regex by deleting of channel or instance
- (bluefox) fix delete instance errors
- (bluefox) add new console commands: set, host. To set settings of instance from console and change host name.
- (bluefox) fix error with node-red
- (bluefox) move setup files into directories
- (bluefox) add harmony to repository
- (bluefox) change log file extension to .log
- (bluefox) enable destroyDB, but check before if ioBroker is running
- (bluefox) update packages
- (bluefox) add bars, plumbs, scenes
- (bluefox) add "iobroker upload all" and "iobroker start all" commands
- (bluefox) fix "iobroker package"
- (bluefox) make it possible to allow OBJECTS and STATES only on localhost
- (bluefox) add new adapter pushbullet
- (bluefox) fix restart by installing.
- (bluefox) fix restartAdapters flag.(for vis-metro and co)
- (bluefox) add vis-hqWidgets
- (bluefox) add vis-colorpicker
- (bluefox) normalize paths in backup
- (bluefox) add better backup
- (bluefox) add flot to repository
- (bluefox) add chmodFile for adapter
- (bluefox) implement rm
- (bluefox) fix permissions problem
- (bluefox) set permission by creation of file
- (bluefox) make possible upload of subtree
- (bluefox) fix user name
- (bluefox) fix update function
- (bluefox) remove _failCounter from adapter list
- (bluefox) update license
- (bluefox) support of permissions
- (bluefox) fix backup
- (bluefox) fix error with noFileCache
- (bluefox) add unsubscribeForeignObjects to adapters
- (bluefox) add icon sets to repository
- (bluefox) implement list: objets, states, instances, adapters
- (bluefox) support of "list hosts"
- (bluefox) verify version by install and start
- (bluefox) fix error with dependencies
- (bluefox) fix delete of logs
- (bluefox) fix getPort function in adapter.
- (bluefox) support of permissions
- (bluefox) implement daily rolling files.
- (bluefox) fix addChannelToEnum, deleteChannelFromEnum, deleteChannel if no device name
- (bluefox) fix "state set", "message" console commands
- (bluefox) fix errors in adapter.js
- (bluefox) add default certificates
- (bluefox) optimize install call
- (bluefox) backup/restore
- (bluefox) use system npm for update and install
- (bluefox) generate uuid as hash of MAC
- (bluefox) delete empty adaptors from repository
- (bluefox) try to implement backup/restore
- (bluefox) support of "--install" flag for sayIt
- (bluefox) add megad to repository
- (bluefox) enable subscribeStates() same as subscribeStates('*')
- (bluefox) replace "slient" mode with "install" mode
- (bluefox) enable silent mode
- (bluefox) update utils.js (silent mode)
- (bluefox) fix error by setup.js
- (bluefox) fix error with sendTo('email')
- (bluefox) increase timeout for npm to 5000 ms
- (bluefox) fix function deleteDevice in adapter.js
- (bluefox) do not start more times the scheduled task after a long sleep
- (bluefox) fix error with trimFifo (used for history adapter)
- (bluefox) use system "npm" by updating of js-controller
- (bluefox) add start/stop/restart adapter from console.
- (bluefox) better wakeup of adapters.
- (bluefox) add sayit adapter
- (bluefox) fix clear of log file
- (bluefox) fix restart under windows
- (bluefox) add yr as npm
- (bluefox) extend adapter.js with formatDate
- (bluefox) add simple-api
- (bluefox) fix log for restart
- (bluefox) remove node-windows from dependencies
- (bluefox) fix log
- (bluefox) show npm version and not git version
- (bluefox) use npm packet to install and not the exec npm
- (bluefox) make it possible to install ioBroker with "npm install iobroker"
- (bluefox) add developing flag "noFileCache" to do not cache web files.
- (bluefox) improve "adapter.getPort" on windows.
- (bluefox) create iobroker.sh with 0777 by install
- (bluefox) fix problem with no objects after "setup" started
- (bluefox) move "data" directory by "npm install" to "../../iobroker-data"
- (bluefox) restart objects socket if some exception occurs
- (bluefox) fix error in objectsInMemClient and objectsInMemServer
- (bluefox) fix first setup
- (bluefox) support of multiple hosts
- (bluefox) fix problem with "hosts are not shown in admin"
- (bluefox) support of multiple hosts
- (bluefox) "chmod 777 * -R /opt/iobroker" => "chmod 777 -R /opt/iobroker"
- (bluefox) fix error update of js-controller under linux/osx
- (bluefox) fix error with publish/subscribe
- (bluefox) support of "onlyWWW" flag
- (bluefox) fix error if state is null or undefined
- (bluefox) store fifos from states in file
- (bluefox) support of file manager in vis
- (bluefox) try to fix update of controller
- (bluefox) fix error with subscribes
- (bluefox) fix error with extendObject
- (bluefox) fix error with delete adapter
- (bluefox) fix error in deleteChannelFromEnum
- (bluefox) fix upload problem
- (bluefox) fix package.json
- (bluefox) enable npm install
- (bluefox) no redis any more
- (bluefox) fix problem with restart controller
- (bluefox) check flag supportStopInstance before send signal to adapter
- (bluefox) fix problem with upgrade adapter
- (bluefox) fix problem with upload adapter
- (bluefox) implement getConfigKeys in redis.
- (bluefox) new running mode: "once"
- (bluefox) enable start of "no-daemon" adapters like "rickshaw" or "vis".
- (bluefox) fix delObject function
- (bluefox) remove unused log message
- (bluefox) optimize start/stop/restart.
- (bluefox) fix error in redis.
- (bluefox) fix error in redis.
- (bluefox) remove couchDB and store everything in redis.
- (bluefox) use npm to install some adapters.
- (bluefox) fix log in controller.js one more time
- (bluefox) fix log in controller.js
- (bluefox) fix some errors and add restart.js
- (bluefox) fix messageboxes
- (bluefox) fix log output in admin.
- (bluefox) new naming concept. No children and parents set extra.
- (bluefox) fix adapter.js
- (bluefox) call "chmod +x iobroker" after updgrade of controller
- (bluefox) fix adapter.js
- (bluefox) add logging to controller
- (bluefox) create restore/backup (from console)
- (bluefox) support of node-red as adapter and defined exit codes for errors
- (bluefox) support of node-red as adapter
- (bluefox) fix error with binary states
- (bluefox) fix error in "support of listDevices for configuration"
- (bluefox) (bluefox) fix creatChannel for adapter
- (bluefox) support of listDevices for configuration
- (bluefox) check common.os (e.g. to install adapter only on linux)
- (bluefox) support of common.install adapter settings.
- (bluefox) change state names to 'io.*'
- (bluefox) show version in log
- (bluefox) fix dependencies of packets
- (bluefox) fix error in adapter.js
- (bluefox) store repository in the DB
- (bluefox) change example adapter for emitEvent
- (bluefox) support of certificates
- (bluefox) fix names for states
- (bluefox) fix add/delete adapter
- (bluefox) fill source-dist.json with grunt
- (bluefox) call "npm install" after adapter updated
- (bluefox) new concept of updates and repositories
- (hobbyquaker) trimFifo calls callback with trimmed data
- (hobbyquaker) fix instance restart
- (hobbyquaker) admin-ui: enums
- (hobbyquaker) admin-ui: ...
- (hobbyquaker) fixes
- (hobbyquaker) admin-ui: adapter-settings
- (hobbyquaker) admin-ui: add instance
- (hobbyquaker) admin-ui: cmd execution
- (bluefox) adapter admin: https
- (bluefox) adapter admin: auth
- (bluefox) admin-ui: user and group management
- (hobbyquaker) fixes
- (hobbyquaker) added adapter cul to sources-dist.json
- (hobbyquaker) new object types user and group
- (hobbyquaker) iobroker setup: create user and group admin. Default password: iobroker
- (hobbyquaker) setup.js fixes
- (hobbyquaker) setup.js create multiple system objects
- (hobbyquaker) admin ui: instances
- (hobbyquaker) refactoring controller.js and setup.js
- (hobbyquaker) iobroker.js command line options
- (hobbyquaker) iobroker with shebang (needs chmod +x)
- (hobbyquaker) added dbdump.js
- (hobbyquaker) fixes and other stuff...
- (hobbyquaker) Javascript Script Engine
- (bluefox) Gruntfile.js
- (bluefox) SCHEMA.md
- (hobbyquaker) ctrl: instance mode schedule
- (hobbyquaker) iobroker.js add: set instanceObjects (new attribute in io-package.json)
- (hobbyquaker) added meta attribute to sources.json
- (hobbyquaker) added adapter yr to sources.json
- (hobbyquaker) fix Admin UI - handle IDs with spaces
- (hobbyquaker) download adapters via
iobroker.js add <adapter-name>
(has to be defined in conf/sources.json) - (hobbyquaker) automatically install node dependencies on
iobroker.js add
- (hobbyquaker) restructuring
- (hobbyquaker) history adapter
- (hobbyquaker) renamed adapter web to admin (this adapters purpose is to do only the admin-ui)
- (hobbyquaker) renamed adapter legacy to web (this adapter should provide a ccu.io-like webserver for easy porting of dashui, scriptgui, yahui, ...)
- (hobbyquaker) renamed adapter dummy to example
- (hobbyquaker) hm-rpc Adapter checks Datapoint-Type and warns if readonly
- (hobbyquaker) Admin-UI - gridStates update on stateChange
- (hobbyquaker) hm-rega Adapter
- (hobbyquaker) ctrl restarts crashed adapters automatically
- (hobbyquaker) Adapter web
- (hobbyquaker) Admin UI
- (hobbyquaker) Installation/instancing of adapters via
iobroker.js add
- (hobbyquaker) Adapter command line param instead of IPC
- (hobbyquaker) Config-file iobroker.json
- (hobbyquaker) first release