Class SmartPlugin

Die Klasse SmartPlugin implementiert die Basisklasse aller SmartPlugins. Die vorhandenen Methoden sind im Folgenden beschrieben.

Zusätzlich werden die Methoden der Klasse lib.utils.Utils vererbt.

class lib.model.smartplugin.SmartPlugin(**kwargs)[Quellcode]

Bases: SmartObject, Utils

The class SmartPlugin implements the base class of all smart-plugins. The implemented methods are described below.

In addition the methods implemented in lib.utils.Utils are inherited.

PLUGIN_VERSION = ''
ALLOW_MULTIINSTANCE = None
STOP_ON_ITEM_CHANGE = True
shtime = None

Variable containing a pointer to the SmartHomeNG time handling object; is initialized during loading of the plugin; :Warning: Don’t change it

logger = <Logger lib.model.smartplugin (WARNING)>
run()[Quellcode]

This method of the plugin is called to start the plugin

Note:

This method needs to be overwritten by the plugin implementation. Otherwise an error will be raised

stop()[Quellcode]

This method of the plugin is called to stop the plugin when SmartHomeNG shuts down

Note:

This method needs to be overwritten by the plugin implementation. Otherwise an error will be raised

alive = False
update_item(item, caller=None, source=None, dest=None)[Quellcode]

Item has been updated

This method is called, if the value of an item has been updated by SmartHomeNG. It should write the changed value out to the device (hardware/interface) that is managed by this plugin.

Method must be overwritten for the plugin to be able to react to item changes.

Parameter:
  • item – item to be updated towards the plugin

  • caller – if given it represents the callers name

  • source – if given it represents the source

  • dest – if given it represents the dest

Rückgabetyp:

None

parse_item(item)[Quellcode]

This method is used to parse the configuration of an item for this plugin. It is called for each item before the plugins are started (calling all run methods). Copy code to own function; calling via super() does not work without bending three arms…

Note:

This method should be overwritten by the plugin implementation.

Rückgabetyp:

Any

poll_device()[Quellcode]

periodically poll device (or do other things periodically)

Note:

This method can be overwritten by plugin implementation.

Rückgabetyp:

None

parse_logic(logic)[Quellcode]

This method is used to parse the configuration of a logic for this plugin. It is called for all plugins before the plugins are started (calling all run methods).

Note:

This method should to be overwritten by the plugin implementation.

Rückgabetyp:

None

deinit(items=[])[Quellcode]

This method „deinitializes“ the plugin, i.e. prepares for unloading. The plugin is stopped and all (or all provided) items are un-registered.

If the Plugin needs special code to be executed before it is unloaded, this method has to be overwritten with the code needed for de-initialization. Keep the original code or call super().deinit()…

If called without parameters, all registered items are unregistered. items is a list of items (or a single Item() object).

Rückgabetyp:

None

add_item(item, config_data_dict={}, mapping=None, updating=False)[Quellcode]

For items that are used/handled by a plugin, this method stores the configuration information that is individual for the plugin. The configuration information is/has to be stored in a dictionary

The configuration information can be retrieved later by a call to the method get_item_configdata(<item_path>)

If data is being received by the plugin, a mapping ( a ‚device-command‘ or matchstring) has to be specified as an optional 3rd parameter. This allows a reverse lookup. The method get_itemlist_for_mapping(<mapping>) returns a list of items for the items that have defined the <mapping>. In most cases, the list will have only one entry, but if multiple items should receive data from the same device (or command), the list can have more than one entry.

Calling this method for an item already stored in self._plg_item_dict can be used to change the „is_updating“ key to True, if it was False before and the updating parameter is True. Otherwise, nothing happens.

This method should be called from parse_item to register the item. If parse_item returns a reference to update_item, this method is called again by the Item instance itself to change the is_updating key.

Only available in SmartHomeNG versions v1.9.4 and up.

Parameter:
  • item (Item) – item

  • config_data_dict (dict) – Dictionary with the plugin-specific configuration information for the item

  • mapping (str) – String identifing the origin (source/kind) of received data (e.g. the address on a bus)

  • updating (bool) – Show if item updates from shng should be sent to the plugin

Rückgabe:

True, if the information has been added

Rückgabetyp:

bool

remove_item(item)[Quellcode]

Remove configuration data for an item (and remove the item from the mapping’s list

Parameter:

item (Item) – item to remove

Rückgabe:

True, if the information has been removed

Rückgabetyp:

bool

callerinfo(caller, source)[Quellcode]
Rückgabetyp:

str

register_updating(item)[Quellcode]

Mark item in self._plg_item_dict as registered in shng for updating (usually done by returning self.update_item from self.parse_item)

NOTE: Items are added to _plg_item_dict by the item class as updating

by default. This could only be used if items were added manually as non-updating first. Registering them as updating usually only occurs via parse_item(), which in turn makes the item class add the item as updating.

Parameter:

item (item) – item object

Rückgabetyp:

None

get_item_config(item)[Quellcode]

Returns the plugin-specific configuration information (config_data_dict) for the given item

Parameter:

item (item object or str) – item or item_path (str) to get config info for

Rückgabe:

dict with the configuration information for the given item

Rückgabetyp:

dict

get_item_mapping(item)[Quellcode]

Returns the plugin-specific mapping that was defined by add_item()

Only available in SmartHomeNG versions v1.9.4 and up.

Parameter:

item (item object or str) – item or item_path (str) to get config info for

Rückgabe:

mapping string for that item

Rückgabetyp:

str

get_item_mapping_list()[Quellcode]

Returns the plugin-specific mapping that was defined by add_item()

This method is implemented to support plugin development to be used with the eval syntax checker or the executor plugin

Only available in SmartHomeNG versions v1.10.0 and up.

Rückgabe:

mapping string for that item

Rückgabetyp:

list

get_item_path_list(filter_key='', filter_value='', mode='')[Quellcode]

Return list of stored item paths used by this plugin

Only available in SmartHomeNG versions v1.9.4 and up. Parameter ‚mode‘ only available in SmartHomeNG versions v1.10.0 and up.

Parameter:
  • filter_key (str) – key of the configdata dict used to filter

  • filter_value (str) – value for filtering item_path_list

  • mode (str) – Compare mode (‚start‘, ‚end‘) for comparing strings of different length, None oder ommitting does a standard compare

Rückgabetyp:

list

Rückgabe:

List of item pathes

get_item_list(filter_key='', filter_value='', mode='')[Quellcode]

Return list of stored items used by this plugin

Only available in SmartHomeNG versions v1.9.4 and up. Parameter ‚mode‘ only available in SmartHomeNG versions v1.10.0 and up.

Parameter:
  • filter_key (str) – key of the configdata dict used to filter

  • filter_value (str) – value for filtering item_path_list

  • mode (str) – Compare mode (‚start‘, ‚end‘) for comparing strings of different length, None oder ommitting does a standard compare

Rückgabetyp:

list

Rückgabe:

List of item objects

get_trigger_items()[Quellcode]

Return list of stored items which were marked as updating

Only available in SmartHomeNG versions v1.9.4 and up.

Rückgabetyp:

list

get_items_for_mapping(mapping)[Quellcode]

Returns a list of items that should receive data for the given mapping

Only available in SmartHomeNG versions v1.9.4 and up.

Parameter:

mapping (str) – mapping, for which the receiving items should be returned

Rückgabe:

List of items

Rückgabetyp:

list

get_mappings()[Quellcode]

Returns a list containing all mappings, which have items associated with it

Only available in SmartHomeNG versions v1.9.4 and up.

Rückgabe:

List of mappings

Rückgabetyp:

list

unparse_item(item)[Quellcode]

Ensure that changes to <item> are no longer propagated to this plugin

Parameter:

item (class Item) – item to unparse

Rückgabetyp:

bool

get_configname()[Quellcode]

return the name of the plugin instance as defined in plugin.yaml (section name)

Rückgabe:

name of the plugin instance as defined in plugin.yaml

Rückgabetyp:

str

get_shortname()[Quellcode]

return the shortname of the plugin (name of it’s directory)

Rückgabe:

shortname of the plugin

Rückgabetyp:

str

get_instance_name()[Quellcode]

Returns the name of this instance of the plugin

Rückgabe:

instance name

Rückgabetyp:

str

get_fullname()[Quellcode]

return the full name of the plugin (shortname & instancename)

Rückgabe:

full name of the plugin

Rückgabetyp:

str

get_classname()[Quellcode]

return the classname of the plugin

Rückgabe:

classname of the plugin

Rückgabetyp:

str

get_version(extended=False)[Quellcode]

Return plugin version

Parameter:

extended (bool) – If True, returned version string contains (pv) if not the latest version is loaded

Rückgabe:

plugin version

Rückgabetyp:

str

is_multi_instance_capable()[Quellcode]

Returns information if plugin is capable of multi instance handling

Rückgabe:

True: If multiinstance capable

Rückgabetyp:

bool

get_plugin_dir()[Quellcode]

return the directory where the pluing files are stored in

Rückgabe:

name of the directory

Rückgabetyp:

str

get_info()[Quellcode]

Returns a small plugin info like: class, version and instance name

Rückgabe:

plugin Info

Rückgabetyp:

str

get_parameter_value(parameter_name)[Quellcode]

Returns the configured value for the given parameter name

If the parameter is not defined, None is returned

Parameter:

parameter_name (str) – Name of the parameter for which the value should be retrieved

Rückgabe:

Configured value

Rückgabetyp:

depends on the type of the parameter definition

get_parameter_value_for_display(parameter_name)[Quellcode]

Returns the configured value for the given parameter name

If the parameter is not defined, None is returned If the parameter is marked as ‚hide‘, only ‚*‘s are returned

Parameter:

parameter_name (str) – Name of the parameter for which the value should be retrieved

Rückgabe:

Configured value

Rückgabetyp:

depends on the type of the parameter definition

update_config_section(param_dict)[Quellcode]

Update the config section of ../etc/plugin.yaml

Parameter:

param_dict (dict) – dict with the parameters that should be updated

Rückgabetyp:

None

Rückgabe:

get_loginstance()[Quellcode]

Returns a prefix for logmessages of multi instance capable plugins.

The result is an empty string, if the instancename is empty. Otherwise the result is a string containing the instance name preseeded by a ‚@‘ and traild by ‚: ‚.

This way it is easy to show the instance name in log messages. Just write

self.logger.info(self.get_loginstance()+“Your text“)

and the logmessage is preseeded by the instance name, if needed.

Rückgabe:

instance name for logstring

Rückgabetyp:

str

has_iattr(conf, attr)[Quellcode]

checks item configuration for an attribute

Parameter:
  • conf (str) – item configuration

  • attr (str) – attribute name

Rückgabetyp:

bool

Rückgabe:

True, if attribute is in item configuration

get_iattr_value(conf, attr, default=None)[Quellcode]

Returns value for an attribute from item config

Parameter default is only available in SmartHomeNG versions v1.10.0 and up.

Parameter:
  • conf (str) – item configuration

  • attr (str) – attribute name

  • default – Return-value, if attribute is not found

Rückgabetyp:

str

Rückgabe:

value of an attribute

set_attr_value(conf, attr, value)[Quellcode]

Set value for an attribute in item configuration

Parameter:
  • conf (str) – item configuration

  • attr (str) – attribute name

  • value (str) – value to set the atteibute to

Rückgabetyp:

None

get_sh()[Quellcode]

Return the main object of smarthomeNG (usually refered to as smarthome or sh) You can reference the main object of SmartHomeNG by using self.get_sh() in your plugin

Rückgabe:

the main object of smarthomeNG (usually refered to as smarthome or sh)

Rückgabetyp:

object

get_module(modulename)[Quellcode]

Test if module http is loaded and if loaded, return a handle to the module

Rückgabetyp:

object

path_join(path, dir)[Quellcode]

Join an existing path and a directory

now()[Quellcode]

Returns SmartHomeNGs current time (timezone aware)

scheduler_return_next(name)[Quellcode]
Rückgabetyp:

Any

scheduler_trigger(name, obj=None, by=None, source=None, value=None, dest=None, prio=3, dt=None)[Quellcode]

This methods triggers the scheduler entry for a plugin-scheduler

A plugin identification is added to the scheduler name

The parameters are identical to the scheduler.trigger method from lib.scheduler

Rückgabetyp:

None

scheduler_add(name, obj, prio=3, cron=None, cycle=None, value=None, offset=None, next=None)[Quellcode]

This methods adds a scheduler entry for a plugin-scheduler

A plugin identification is added to the scheduler name

The parameters are identical to the scheduler.add method from lib.scheduler

Rückgabetyp:

None

scheduler_change(name, **kwargs)[Quellcode]

This methods changes a scheduler entry of a plugin-scheduler

A plugin identification is added to the scheduler name

The parameters are identical to the scheduler.change method from lib.scheduler

Rückgabetyp:

None

scheduler_remove(name)[Quellcode]

This methods removes a scheduler entry of a plugin-scheduler

A plugin identifiction is added to the scheduler name

The parameters are identical to the scheduler.remove method from lib.scheduler

Rückgabetyp:

None

scheduler_get(name)[Quellcode]

This methods gets a scheduler entry of a plugin-scheduler

A plugin identifiction is added to the scheduler name

The parameters are identical to the scheduler.get method from lib.scheduler

Rückgabetyp:

dict

scheduler_get_all()[Quellcode]

This method returns a list of all added schedulers

scheduler_remove_all()[Quellcode]

This method removes all schedulers added by the plugin

asyncio_state()[Quellcode]
Returns the state of asyncio for the plugin
  • ‚unused‘ - If the plugin does not use asyncio (the start_asyncio method has not been successfully executed)

  • ‚running‘ - An active eventloop is beeing processed

  • ‚stopped‘ - There is no active eventloop

Rückgabetyp:

str

Rückgabe:

‚unused‘ | ‚running‘ | ‚stopped‘

start_asyncio(plugin_coro)[Quellcode]

Start the thread for the asyncio loop

The started asyncio thread sets up the asyncio environment and starts the eventloop. The given plugin_coro is added as the main task to the eventloop.

This routine is to be called from the plugin’s run() method

Parameter:

plugin_coro (Coroutine) – The asyncio coroutine which implements the async part of the plugin

Rückgabetyp:

None

stop_asyncio()[Quellcode]

stop the eventloop and the thread it is running in

This routine is to be called from the plugin’s stop() method.

Rückgabetyp:

None

run_asyncio_coro(coro, timeout=60, return_exeption=False)[Quellcode]

Run a coroutine in the eventloop of the plugin

When the asyncio eventloop of the plugin is running, this method can be used to add a coroutine to the eventloop from the part of the plugin which is thread operated. E.g.: This can be used in the plugins update_item() method to send data to the device through an asyncio package.

This method waits for the coroutine to be finished, to be able to return the result of the coroutine.

Parameter:
  • coro (Coroutine) – A coroutine that should be run in the eventloop of the asyncio-thread

  • return_exeption (bool) – If set to True, run_asyncio_coro returns exceptions instead of handling (logging) them itself

Rückgabetyp:

Any

return: The result of the coroutine

async wait_for_asyncio_termination()[Quellcode]

Wait for the command to stop the plugin_coro

This is used to block the plugin_coro until the plugin should be stopped.

When the plugin should be stopped, a string ‚STOP‘ is written into the queue

Rückgabetyp:

None

put_command_to_run_queue(command)[Quellcode]

Put an entry to the run-queue (if implemented in the plugin_coro)

Parameter:

command (str) – command to be executed by the plugin_coro

Rückgabetyp:

None

async get_command_from_run_queue()[Quellcode]

Get an entry from the run-queue

When the plugin should be stopped, a string ‚STOP‘ is written into the queue and the plugin_coro can check for the string ‚STOP‘ and terminate itself.

Rückgabetyp:

str

Rückgabe:

First command from the queue

async list_asyncio_tasks()[Quellcode]

Log a list of the tasks that are in the eventloop

The intention of this method is to support the plugin development/debugging. It can be called from the executor plugin or from the eval-syntax-checker of the admin gui

Rückgabetyp:

None

translate(txt, vars=None, block=None)[Quellcode]

Returns translated text for class SmartPlugin

init_webinterface(WebInterface=None)[Quellcode]

“ :rtype: bool

Initialize the web interface for this plugin

This method is only needed if the plugin is implementing a web interface