2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
<!DOCTYPE html>
<!-- [if IE 8]><html class="no - js lt - ie9" lang="en" > <![endif] -->
<!-- [if gt IE 8]><! --> < html class = "no-js" lang = "en" > <!-- <![endif] -->
< head >
< meta charset = "utf-8" >
< meta name = "viewport" content = "width=device-width, initial-scale=1.0" >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< title > Properties — CraftBeerPi 4.0 documentation< / title >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< link rel = "stylesheet" href = "_static/css/theme.css" type = "text/css" / >
< link rel = "stylesheet" href = "_static/pygments.css" type = "text/css" / >
< link rel = "index" title = "Index" href = "genindex.html" / >
< link rel = "search" title = "Search" href = "search.html" / >
< link rel = "prev" title = "Kettle" href = "kettle_controller.html" / >
< script src = "_static/js/modernizr.min.js" > < / script >
< / head >
< body class = "wy-body-for-nav" >
< div class = "wy-grid-for-nav" >
< nav data-toggle = "wy-nav-shift" class = "wy-nav-side" >
< div class = "wy-side-scroll" >
< div class = "wy-side-nav-search" >
< a href = "index.html" class = "icon icon-home" > CraftBeerPi
< / a >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< div role = "search" >
< form id = "rtd-search-form" class = "wy-form" action = "search.html" method = "get" >
< input type = "text" name = "q" placeholder = "Search docs" / >
< input type = "hidden" name = "check_keywords" value = "yes" / >
< input type = "hidden" name = "area" value = "default" / >
< / form >
< / div >
< / div >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< div class = "wy-menu wy-menu-vertical" data-spy = "affix" role = "navigation" aria-label = "main navigation" >
< ul class = "current" >
< li class = "toctree-l1" > < a class = "reference internal" href = "install.html" > Installation< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "core.html" > Core< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "actor.html" > Actor< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "sensor.html" > Sensor< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "step.html" > Brewing Step< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "kettle_controller.html" > Kettle< / a > < / li >
< li class = "toctree-l1 current" > < a class = "current reference internal" href = "#" > Properties< / a > < ul >
< li class = "toctree-l2" > < a class = "reference internal" href = "#custom-actor" > Custom Actor< / a > < / li >
< / ul >
< / li >
< / ul >
< / div >
< / div >
< / nav >
< section data-toggle = "wy-nav-shift" class = "wy-nav-content-wrap" >
< nav class = "wy-nav-top" aria-label = "top navigation" >
< i data-toggle = "wy-nav-top" class = "fa fa-bars" > < / i >
< a href = "index.html" > CraftBeerPi< / a >
< / nav >
< div class = "wy-nav-content" >
< div class = "rst-content" >
< div role = "navigation" aria-label = "breadcrumbs navigation" >
< ul class = "wy-breadcrumbs" >
< li > < a href = "index.html" > Docs< / a > » < / li >
< li > Properties< / li >
< li class = "wy-breadcrumbs-aside" >
< a href = "_sources/properties.rst.txt" rel = "nofollow" > View page source< / a >
< / li >
< / ul >
< hr / >
< / div >
< div role = "main" class = "document" itemscope = "itemscope" itemtype = "http://schema.org/Article" >
< div itemprop = "articleBody" >
2018-12-08 14:21:00 +01:00
< div class = "section" id = "properties" >
< h1 > Properties< a class = "headerlink" href = "#properties" title = "Permalink to this headline" > ¶< / a > < / h1 >
2018-12-09 22:20:33 +01:00
< p > Properties can be use in all extensions.
During the startup the server scans all extension for variables of type Property.
Theses properties are exposed to the user for configuration during run time.
For example the user can set the GPIO number or the 1Wire Id.< / p >
< p > Typical example how to use properties in an actor module.< / p >
< div class = "section" id = "custom-actor" >
< h2 > Custom Actor< a class = "headerlink" href = "#custom-actor" title = "Permalink to this headline" > ¶< / a > < / h2 >
< div class = "literal-block-wrapper docutils container" id = "init-py" >
< div class = "code-block-caption" > < span class = "caption-text" > __init__.py< / span > < a class = "headerlink" href = "#init-py" title = "Permalink to this code" > ¶< / a > < / div >
< div class = "highlight-python notranslate" > < table class = "highlighttable" > < tr > < td class = "linenos" > < div class = "linenodiv" > < pre > 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45< / pre > < / div > < / td > < td class = "code" > < div class = "highlight" > < pre > < span > < / span > < span class = "kn" > import< / span > < span class = "nn" > logging< / span >
< span class = "kn" > from< / span > < span class = "nn" > core.api< / span > < span class = "kn" > import< / span > < span class = "n" > CBPiActor< / span > < span class = "p" > ,< / span > < span class = "n" > Property< / span > < span class = "p" > ,< / span > < span class = "n" > action< / span >
< span class = "k" > class< / span > < span class = "nc" > CustomActor< / span > < span class = "p" > (< / span > < span class = "n" > CBPiActor< / span > < span class = "p" > ):< / span >
< span class = "c1" > # Custom property which can be configured by the user< / span >
< span class = "n" > gpio< / span > < span class = "o" > =< / span > < span class = "n" > Property< / span > < span class = "o" > .< / span > < span class = "n" > Number< / span > < span class = "p" > (< / span > < span class = "n" > label< / span > < span class = "o" > =< / span > < span class = "s2" > " Test" < / span > < span class = "p" > )< / span >
< span class = "nd" > @action< / span > < span class = "p" > (< / span > < span class = "n" > key< / span > < span class = "o" > =< / span > < span class = "s2" > " name" < / span > < span class = "p" > ,< / span > < span class = "n" > parameters< / span > < span class = "o" > =< / span > < span class = "p" > {})< / span >
< span class = "k" > def< / span > < span class = "nf" > myAction< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ):< / span >
< span class = "k" > pass< / span >
< span class = "k" > def< / span > < span class = "nf" > state< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ):< / span >
< span class = "nb" > super< / span > < span class = "p" > ()< / span > < span class = "o" > .< / span > < span class = "n" > state< / span > < span class = "p" > ()< / span >
< span class = "k" > def< / span > < span class = "nf" > off< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ):< / span >
< span class = "k" > print< / span > < span class = "p" > (< / span > < span class = "s2" > " OFF" < / span > < span class = "p" > ,< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > gpio< / span > < span class = "p" > )< / span >
< span class = "c1" > # Code to swtich the actor off goes here< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > state< / span > < span class = "o" > =< / span > < span class = "bp" > False< / span >
< span class = "k" > def< / span > < span class = "nf" > on< / span > < span class = "p" > (< / span > < span class = "bp" > self< / span > < span class = "p" > ,< / span > < span class = "n" > power< / span > < span class = "o" > =< / span > < span class = "mi" > 100< / span > < span class = "p" > ):< / span >
< span class = "k" > print< / span > < span class = "p" > (< / span > < span class = "s2" > " ON" < / span > < span class = "p" > ,< / span > < span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > gpio< / span > < span class = "p" > )< / span >
< span class = "c1" > # Code to swtich the actor on goes here< / span >
< span class = "bp" > self< / span > < span class = "o" > .< / span > < span class = "n" > state< / span > < span class = "o" > =< / span > < span class = "bp" > True< / span >
< span class = "k" > def< / span > < span class = "nf" > setup< / span > < span class = "p" > (< / span > < span class = "n" > cbpi< / span > < span class = "p" > ):< / span >
< span class = "sd" > ' ' ' < / span >
< span class = "sd" > This method is called by the server during startup < / span >
< span class = "sd" > Here you need to register your plugins at the server< / span >
< span class = "sd" > < / span >
< span class = "sd" > :param cbpi: the cbpi core < / span >
< span class = "sd" > :return: < / span >
< span class = "sd" > ' ' ' < / span >
< span class = "n" > cbpi< / span > < span class = "o" > .< / span > < span class = "n" > plugin< / span > < span class = "o" > .< / span > < span class = "n" > register< / span > < span class = "p" > (< / span > < span class = "s2" > " CustomActor" < / span > < span class = "p" > ,< / span > < span class = "n" > CustomActor< / span > < span class = "p" > )< / span >
< / pre > < / div >
< / td > < / tr > < / table > < / div >
< / div >
2018-12-08 14:21:00 +01:00
< dl class = "class" >
< dt id = "core.api.property.Property" >
< em class = "property" > class < / em > < code class = "descclassname" > core.api.property.< / code > < code class = "descname" > Property< / code > < a class = "headerlink" href = "#core.api.property.Property" title = "Permalink to this definition" > ¶< / a > < / dt >
2018-12-09 22:20:33 +01:00
< dd > < dl class = "class" >
2018-12-08 14:21:00 +01:00
< dt id = "core.api.property.Property.Actor" >
< em class = "property" > class < / em > < code class = "descname" > Actor< / code > < span class = "sig-paren" > (< / span > < em > label< / em > , < em > description=''< / em > < span class = "sig-paren" > )< / span > < a class = "headerlink" href = "#core.api.property.Property.Actor" title = "Permalink to this definition" > ¶< / a > < / dt >
2018-12-09 22:20:33 +01:00
< dd > < p > The user select an actor which is available in the system. The value of this variable will be the actor id< / p >
2018-12-08 14:21:00 +01:00
< / dd > < / dl >
< dl class = "class" >
< dt id = "core.api.property.Property.Kettle" >
< em class = "property" > class < / em > < code class = "descname" > Kettle< / code > < span class = "sig-paren" > (< / span > < em > label< / em > , < em > description=''< / em > < span class = "sig-paren" > )< / span > < a class = "headerlink" href = "#core.api.property.Property.Kettle" title = "Permalink to this definition" > ¶< / a > < / dt >
2018-12-09 22:20:33 +01:00
< dd > < p > The user select a kettle which is available in the system. The value of this variable will be the kettle id< / p >
2018-12-08 14:21:00 +01:00
< / dd > < / dl >
< dl class = "class" >
< dt id = "core.api.property.Property.Number" >
< em class = "property" > class < / em > < code class = "descname" > Number< / code > < span class = "sig-paren" > (< / span > < em > label< / em > , < em > configurable=False< / em > , < em > default_value=None< / em > , < em > unit=''< / em > , < em > description=''< / em > < span class = "sig-paren" > )< / span > < a class = "headerlink" href = "#core.api.property.Property.Number" title = "Permalink to this definition" > ¶< / a > < / dt >
2018-12-09 22:20:33 +01:00
< dd > < p > The user can set a number value< / p >
2018-12-08 14:21:00 +01:00
< / dd > < / dl >
< dl class = "class" >
< dt id = "core.api.property.Property.Select" >
< em class = "property" > class < / em > < code class = "descname" > Select< / code > < span class = "sig-paren" > (< / span > < em > label< / em > , < em > options< / em > , < em > description=''< / em > < span class = "sig-paren" > )< / span > < a class = "headerlink" href = "#core.api.property.Property.Select" title = "Permalink to this definition" > ¶< / a > < / dt >
2018-12-09 22:20:33 +01:00
< dd > < p > Select Property. The user can select value from list set as options parameter< / p >
2018-12-08 14:21:00 +01:00
< / dd > < / dl >
< dl class = "class" >
< dt id = "core.api.property.Property.Sensor" >
< em class = "property" > class < / em > < code class = "descname" > Sensor< / code > < span class = "sig-paren" > (< / span > < em > label< / em > , < em > description=''< / em > < span class = "sig-paren" > )< / span > < a class = "headerlink" href = "#core.api.property.Property.Sensor" title = "Permalink to this definition" > ¶< / a > < / dt >
2018-12-09 22:20:33 +01:00
< dd > < p > The user select a sensor which is available in the system. The value of this variable will be the sensor id< / p >
2018-12-08 14:21:00 +01:00
< / dd > < / dl >
< dl class = "class" >
< dt id = "core.api.property.Property.Text" >
< em class = "property" > class < / em > < code class = "descname" > Text< / code > < span class = "sig-paren" > (< / span > < em > label< / em > , < em > configurable=False< / em > , < em > default_value=''< / em > , < em > description=''< / em > < span class = "sig-paren" > )< / span > < a class = "headerlink" href = "#core.api.property.Property.Text" title = "Permalink to this definition" > ¶< / a > < / dt >
2018-12-09 22:20:33 +01:00
< dd > < p > The user can set a text value< / p >
2018-12-08 14:21:00 +01:00
< / dd > < / dl >
< / dd > < / dl >
2018-12-09 22:20:33 +01:00
< / div >
2018-12-08 14:21:00 +01:00
< / div >
2018-12-09 22:20:33 +01:00
< / div >
2018-12-08 14:21:00 +01:00
< / div >
2018-12-09 22:20:33 +01:00
< footer >
< div class = "rst-footer-buttons" role = "navigation" aria-label = "footer navigation" >
< a href = "kettle_controller.html" class = "btn btn-neutral" title = "Kettle" accesskey = "p" rel = "prev" > < span class = "fa fa-arrow-circle-left" > < / span > Previous< / a >
< / div >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< hr / >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< div role = "contentinfo" >
< p >
© Copyright 2018, Manuel Fritsch
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< / p >
< / div >
Built with < a href = "http://sphinx-doc.org/" > Sphinx< / a > using a < a href = "https://github.com/rtfd/sphinx_rtd_theme" > theme< / a > provided by < a href = "https://readthedocs.org" > Read the Docs< / a > .
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< / footer >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< / div >
< / div >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< / section >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< / div >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< script type = "text/javascript" id = "documentation_options" data-url_root = "./" src = "_static/documentation_options.js" > < / script >
< script type = "text/javascript" src = "_static/jquery.js" > < / script >
< script type = "text/javascript" src = "_static/underscore.js" > < / script >
< script type = "text/javascript" src = "_static/doctools.js" > < / script >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< script type = "text/javascript" src = "_static/js/theme.js" > < / script >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< script type = "text/javascript" >
jQuery(function () {
SphinxRtdTheme.Navigation.enable(true);
});
< / script >
2018-12-08 14:21:00 +01:00
2018-12-09 22:20:33 +01:00
< / body >
2018-12-08 14:21:00 +01:00
< / html >