diff --git a/tag/3.5.0/_static/_sphinx_javascript_frameworks_compat.js b/tag/3.5.0/_static/_sphinx_javascript_frameworks_compat.js new file mode 100644 index 0000000..8141580 --- /dev/null +++ b/tag/3.5.0/_static/_sphinx_javascript_frameworks_compat.js @@ -0,0 +1,123 @@ +/* Compatability shim for jQuery and underscores.js. + * + * Copyright Sphinx contributors + * Released under the two clause BSD licence + */ + +/** + * small helper function to urldecode strings + * + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL + */ +jQuery.urldecode = function(x) { + if (!x) { + return x + } + return decodeURIComponent(x.replace(/\+/g, ' ')); +}; + +/** + * small helper function to urlencode strings + */ +jQuery.urlencode = encodeURIComponent; + +/** + * This function returns the parsed url parameters of the + * current request. Multiple values per key are supported, + * it will always return arrays of strings for the value parts. + */ +jQuery.getQueryParameters = function(s) { + if (typeof s === 'undefined') + s = document.location.search; + var parts = s.substr(s.indexOf('?') + 1).split('&'); + var result = {}; + for (var i = 0; i < parts.length; i++) { + var tmp = parts[i].split('=', 2); + var key = jQuery.urldecode(tmp[0]); + var value = jQuery.urldecode(tmp[1]); + if (key in result) + result[key].push(value); + else + result[key] = [value]; + } + return result; +}; + +/** + * highlight a given string on a jquery object by wrapping it in + * span elements with the given class name. + */ +jQuery.fn.highlightText = function(text, className) { + function highlight(node, addItems) { + if (node.nodeType === 3) { + var val = node.nodeValue; + var pos = val.toLowerCase().indexOf(text); + if (pos >= 0 && + !jQuery(node.parentNode).hasClass(className) && + !jQuery(node.parentNode).hasClass("nohighlight")) { + var span; + var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg"); + if (isInSVG) { + span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); + } else { + span = document.createElement("span"); + span.className = className; + } + span.appendChild(document.createTextNode(val.substr(pos, text.length))); + node.parentNode.insertBefore(span, node.parentNode.insertBefore( + document.createTextNode(val.substr(pos + text.length)), + node.nextSibling)); + node.nodeValue = val.substr(0, pos); + if (isInSVG) { + var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"); + var bbox = node.parentElement.getBBox(); + rect.x.baseVal.value = bbox.x; + rect.y.baseVal.value = bbox.y; + rect.width.baseVal.value = bbox.width; + rect.height.baseVal.value = bbox.height; + rect.setAttribute('class', className); + addItems.push({ + "parent": node.parentNode, + "target": rect}); + } + } + } + else if (!jQuery(node).is("button, select, textarea")) { + jQuery.each(node.childNodes, function() { + highlight(this, addItems); + }); + } + } + var addItems = []; + var result = this.each(function() { + highlight(this, addItems); + }); + for (var i = 0; i < addItems.length; ++i) { + jQuery(addItems[i].parent).before(addItems[i].target); + } + return result; +}; + +/* + * backward compatibility for jQuery.browser + * This will be supported until firefox bug is fixed. + */ +if (!jQuery.browser) { + jQuery.uaMatch = function(ua) { + ua = ua.toLowerCase(); + + var match = /(chrome)[ \/]([\w.]+)/.exec(ua) || + /(webkit)[ \/]([\w.]+)/.exec(ua) || + /(opera)(?:.*version|)[ \/]([\w.]+)/.exec(ua) || + /(msie) ([\w.]+)/.exec(ua) || + ua.indexOf("compatible") < 0 && /(mozilla)(?:.*? rv:([\w.]+)|)/.exec(ua) || + []; + + return { + browser: match[ 1 ] || "", + version: match[ 2 ] || "0" + }; + }; + jQuery.browser = {}; + jQuery.browser[jQuery.uaMatch(navigator.userAgent).browser] = true; +} diff --git a/tag/3.5.0/_static/antsibull-minimal.css b/tag/3.5.0/_static/antsibull-minimal.css new file mode 100644 index 0000000..5298b2b --- /dev/null +++ b/tag/3.5.0/_static/antsibull-minimal.css @@ -0,0 +1,4 @@ +@charset "UTF-8"; +/* Copyright (c) Ansible and contributors */ +/* GNU General Public License v3.0+ (see https://www.gnu.org/licenses/gpl-3.0.txt) */ +:root{--antsibull-links-background:#5bbdbf;--antsibull-links-background-active:#91d9db;--antsibull-links-focus-outline:#204748;--antsibull-links-text:#fff;--antsibull-table-background-header:#6ab0de;--antsibull-table-background-even:#e7f2fa;--antsibull-table-background-odd:#fff;--antsibull-table-border:#000;--antsibull-narrowtable-background:#e7f2fa;--antsibull-option-type:purple;--antsibull-option-elements:purple;--antsibull-option-required:red;--antsibull-option-version-added:#006400;--antsibull-option-aliases:#006400;--antsibull-option-default:blue;--antsibull-option-sample:blue;--antsibull-option-sample-header:#000;--antsibull-attribute-support-none:red;--antsibull-attribute-support-partial:#a5a500;--antsibull-attribute-support-full:green;--antsibull-attribute-support-na:inherit;--antsibull-deprecation-border:#000;--antsibull-deprecation-background:#eee;--antsibull-deprecation-color:#000}.ansible-links{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;justify-content:flex-start}.ansible-links>*{margin:2px 4px!important}.ansible-links>li{list-style:none!important}.ansible-links>li>p{display:inline}.ansible-links a{background-color:var(--antsibull-links-background);border-radius:3px;color:var(--antsibull-links-text);cursor:pointer;display:block;padding:4px 12px}.ansible-links a:active,.ansible-links a:focus,.ansible-links a:hover{background-color:var(--antsibull-links-background-active)}.ansible-links a:focus{outline:3px solid var(--antsibull-links-focus-outline)}table.documentation-table{border-bottom:1px solid var(--antsibull-table-border);border-right:1px solid var(--antsibull-table-border)}table.documentation-table th{background-color:var(--antsibull-table-background-header)}table.documentation-table td,table.documentation-table th{border-left:1px solid var(--antsibull-table-border);border-top:1px solid var(--antsibull-table-border);padding:4px}table.documentation-table td.elbow-placeholder{border-top:0;min-width:30px;width:30px}table.documentation-table td{vertical-align:top}table.documentation-table td:first-child{white-space:nowrap}table.documentation-table tr .ansibleOptionLink{display:inline-block}table.documentation-table tr .ansibleOptionLink:after{content:"🔗";opacity:0}table.documentation-table tr:hover .ansibleOptionLink:after{opacity:1}table.documentation-table tr:nth-child(odd){background-color:var(--antsibull-table-background-odd)}table.documentation-table tr:nth-child(2n){background-color:var(--antsibull-table-background-even)}table.ansible-option-table{border-color:var(--antsibull-table-border)!important;display:table;height:1px}table.ansible-option-table tr{height:100%}table.ansible-option-table td,table.ansible-option-table th{border-color:var(--antsibull-table-border)!important;border-bottom:none!important;vertical-align:top!important}table.ansible-option-table th>p{font-size:medium!important}table.ansible-option-table thead tr{background-color:var(--antsibull-table-background-header)}table.ansible-option-table tbody .row-odd td{background-color:var(--antsibull-table-background-odd)!important}table.ansible-option-table tbody .row-even td{background-color:var(--antsibull-table-background-even)!important}table.ansible-option-table ul>li>p{margin:0!important}table.ansible-option-table ul>li>div[class^=highlight]{margin-bottom:4px!important}table.ansible-option-table p.ansible-option-title{display:inline}table.ansible-option-table .ansible-option-type-line{font-size:small;margin-bottom:0}table.ansible-option-table .ansible-option-type{color:var(--antsibull-option-type)}table.ansible-option-table .ansible-option-elements{color:var(--antsibull-option-elements)}table.ansible-option-table .ansible-option-required{color:var(--antsibull-option-required)}table.ansible-option-table .ansible-option-versionadded{color:var(--antsibull-option-version-added);font-size:small}table.ansible-option-table .ansible-option-aliases{color:var(--antsibull-option-aliases);white-space:normal}table.ansible-option-table .ansible-option-line{margin-top:8px}table.ansible-option-table .ansible-option-choices-default-mark,table.ansible-option-table .ansible-option-default,table.ansible-option-table .ansible-option-default-bold{color:var(--antsibull-option-default)}table.ansible-option-table .ansible-option-sample{color:var(--antsibull-option-sample);word-wrap:break-word;word-break:break-all}table.ansible-option-table .ansible-option-sample-bold{color:var(--antsibull-option-sample-header)}table.ansible-option-table .ansible-attribute-support-none{color:var(--antsibull-attribute-support-none)}table.ansible-option-table .ansible-attribute-support-partial{color:var(--antsibull-attribute-support-partial)}table.ansible-option-table .ansible-attribute-support-full{color:var(--antsibull-attribute-support-full)}table.ansible-option-table .ansible-attribute-support-na{color:var(--antsibull-attribute-support-na)}table.ansible-option-table .ansibleOptionLink{display:inline-block}table.ansible-option-table .ansibleOptionLink:after{content:"🔗";opacity:0}table.ansible-option-table p{margin:0 0 8px}table.ansible-option-table tr:hover .ansibleOptionLink:after{opacity:1}table.ansible-option-table td{padding:0!important;white-space:normal}table.ansible-option-table td>div.ansible-option-cell{border-top:1px solid var(--antsibull-table-border);padding:8px 16px}table.ansible-option-table td:first-child{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;height:inherit;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}table.ansible-option-table td:first-child>div.ansible-option-cell{height:inherit;-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto;max-width:100%;white-space:nowrap}table.ansible-option-table .ansible-option-indent{border-right:1px solid var(--antsibull-table-border);margin-left:2em}table.ansible-option-table .ansible-attribute-support-label{display:none}@media (max-width:1200px){table.ansible-option-table{border:none!important;display:block;height:unset}table.ansible-option-table thead{display:none}table.ansible-option-table tbody,table.ansible-option-table td,table.ansible-option-table tr{border:none!important;display:block}table.ansible-option-table tbody .row-even td,table.ansible-option-table tbody .row-odd td{background-color:unset!important}table.ansible-option-table td>div.ansible-option-cell{border-top:none}table.ansible-option-table td:first-child>div.ansible-option-cell{background-color:var(--antsibull-narrowtable-background)!important}table.ansible-option-table td:not(:first-child){display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}table.ansible-option-table td:not(:first-child)>div.ansible-option-cell{margin-left:1em}table.ansible-option-table .ansible-option-indent,table.ansible-option-table .ansible-option-indent-desc{border:none;border-right:3px solid var(--antsibull-narrowtable-background);margin-left:1em}table.ansible-option-table .ansible-attribute-support-label{display:unset}}.ansible-version-added{font-style:italic}.ansible-option a.reference.external,.ansible-option a.reference.external:hover,.ansible-option a.reference.internal,.ansible-option a.reference.internal:hover,.ansible-option-value a.reference.external,.ansible-option-value a.reference.external:hover,.ansible-option-value a.reference.internal,.ansible-option-value a.reference.internal:hover,.ansible-return-value a.reference.external,.ansible-return-value a.reference.external:hover,.ansible-return-value a.reference.internal,.ansible-return-value a.reference.internal:hover{color:unset}.ansible-deprecation-marker{background-color:var(--antsibull-deprecation-background);border:2px solid var(--antsibull-deprecation-border);border-radius:1em;color:var(--antsibull-deprecation-color);padding:.2em .4em} \ No newline at end of file diff --git a/tag/3.5.0/_static/basic.css b/tag/3.5.0/_static/basic.css new file mode 100644 index 0000000..4738b2e --- /dev/null +++ b/tag/3.5.0/_static/basic.css @@ -0,0 +1,906 @@ +/* + * Sphinx stylesheet -- basic theme. + */ + +/* -- main layout ----------------------------------------------------------- */ + +div.clearer { + clear: both; +} + +div.section::after { + display: block; + content: ''; + clear: left; +} + +/* -- relbar ---------------------------------------------------------------- */ + +div.related { + width: 100%; + font-size: 90%; +} + +div.related h3 { + display: none; +} + +div.related ul { + margin: 0; + padding: 0 0 0 10px; + list-style: none; +} + +div.related li { + display: inline; +} + +div.related li.right { + float: right; + margin-right: 5px; +} + +/* -- sidebar --------------------------------------------------------------- */ + +div.sphinxsidebarwrapper { + padding: 10px 5px 0 10px; +} + +div.sphinxsidebar { + float: left; + width: 230px; + margin-left: -100%; + font-size: 90%; + word-wrap: break-word; + overflow-wrap : break-word; +} + +div.sphinxsidebar ul { + list-style: none; +} + +div.sphinxsidebar ul ul, +div.sphinxsidebar ul.want-points { + margin-left: 20px; + list-style: square; +} + +div.sphinxsidebar ul ul { + margin-top: 0; + margin-bottom: 0; +} + +div.sphinxsidebar form { + margin-top: 10px; +} + +div.sphinxsidebar input { + border: 1px solid #98dbcc; + font-family: sans-serif; + font-size: 1em; +} + +div.sphinxsidebar #searchbox form.search { + overflow: hidden; +} + +div.sphinxsidebar #searchbox input[type="text"] { + float: left; + width: 80%; + padding: 0.25em; + box-sizing: border-box; +} + +div.sphinxsidebar #searchbox input[type="submit"] { + float: left; + width: 20%; + border-left: none; + padding: 0.25em; + box-sizing: border-box; +} + + +img { + border: 0; + max-width: 100%; +} + +/* -- search page ----------------------------------------------------------- */ + +ul.search { + margin-top: 10px; +} + +ul.search li { + padding: 5px 0; +} + +ul.search li a { + font-weight: bold; +} + +ul.search li p.context { + color: #888; + margin: 2px 0 0 30px; + text-align: left; +} + +ul.keywordmatches li.goodmatch a { + font-weight: bold; +} + +/* -- index page ------------------------------------------------------------ */ + +table.contentstable { + width: 90%; + margin-left: auto; + margin-right: auto; +} + +table.contentstable p.biglink { + line-height: 150%; +} + +a.biglink { + font-size: 1.3em; +} + +span.linkdescr { + font-style: italic; + padding-top: 5px; + font-size: 90%; +} + +/* -- general index --------------------------------------------------------- */ + +table.indextable { + width: 100%; +} + +table.indextable td { + text-align: left; + vertical-align: top; +} + +table.indextable ul { + margin-top: 0; + margin-bottom: 0; + list-style-type: none; +} + +table.indextable > tbody > tr > td > ul { + padding-left: 0em; +} + +table.indextable tr.pcap { + height: 10px; +} + +table.indextable tr.cap { + margin-top: 10px; + background-color: #f2f2f2; +} + +img.toggler { + margin-right: 3px; + margin-top: 3px; + cursor: pointer; +} + +div.modindex-jumpbox { + border-top: 1px solid #ddd; + border-bottom: 1px solid #ddd; + margin: 1em 0 1em 0; + padding: 0.4em; +} + +div.genindex-jumpbox { + border-top: 1px solid #ddd; + border-bottom: 1px solid #ddd; + margin: 1em 0 1em 0; + padding: 0.4em; +} + +/* -- domain module index --------------------------------------------------- */ + +table.modindextable td { + padding: 2px; + border-collapse: collapse; +} + +/* -- general body styles --------------------------------------------------- */ + +div.body { + min-width: 360px; + max-width: 800px; +} + +div.body p, div.body dd, div.body li, div.body blockquote { + -moz-hyphens: auto; + -ms-hyphens: auto; + -webkit-hyphens: auto; + hyphens: auto; +} + +a.headerlink { + visibility: hidden; +} + +a:visited { + color: #551A8B; +} + +h1:hover > a.headerlink, +h2:hover > a.headerlink, +h3:hover > a.headerlink, +h4:hover > a.headerlink, +h5:hover > a.headerlink, +h6:hover > a.headerlink, +dt:hover > a.headerlink, +caption:hover > a.headerlink, +p.caption:hover > a.headerlink, +div.code-block-caption:hover > a.headerlink { + visibility: visible; +} + +div.body p.caption { + text-align: inherit; +} + +div.body td { + text-align: left; +} + +.first { + margin-top: 0 !important; +} + +p.rubric { + margin-top: 30px; + font-weight: bold; +} + +img.align-left, figure.align-left, .figure.align-left, object.align-left { + clear: left; + float: left; + margin-right: 1em; +} + +img.align-right, figure.align-right, .figure.align-right, object.align-right { + clear: right; + float: right; + margin-left: 1em; +} + +img.align-center, figure.align-center, .figure.align-center, object.align-center { + display: block; + margin-left: auto; + margin-right: auto; +} + +img.align-default, figure.align-default, .figure.align-default { + display: block; + margin-left: auto; + margin-right: auto; +} + +.align-left { + text-align: left; +} + +.align-center { + text-align: center; +} + +.align-default { + text-align: center; +} + +.align-right { + text-align: right; +} + +/* -- sidebars -------------------------------------------------------------- */ + +div.sidebar, +aside.sidebar { + margin: 0 0 0.5em 1em; + border: 1px solid #ddb; + padding: 7px; + background-color: #ffe; + width: 40%; + float: right; + clear: right; + overflow-x: auto; +} + +p.sidebar-title { + font-weight: bold; +} + +nav.contents, +aside.topic, +div.admonition, div.topic, blockquote { + clear: left; +} + +/* -- topics ---------------------------------------------------------------- */ + +nav.contents, +aside.topic, +div.topic { + border: 1px solid #ccc; + padding: 7px; + margin: 10px 0 10px 0; +} + +p.topic-title { + font-size: 1.1em; + font-weight: bold; + margin-top: 10px; +} + +/* -- admonitions ----------------------------------------------------------- */ + +div.admonition { + margin-top: 10px; + margin-bottom: 10px; + padding: 7px; +} + +div.admonition dt { + font-weight: bold; +} + +p.admonition-title { + margin: 0px 10px 5px 0px; + font-weight: bold; +} + +div.body p.centered { + text-align: center; + margin-top: 25px; +} + +/* -- content of sidebars/topics/admonitions -------------------------------- */ + +div.sidebar > :last-child, +aside.sidebar > :last-child, +nav.contents > :last-child, +aside.topic > :last-child, +div.topic > :last-child, +div.admonition > :last-child { + margin-bottom: 0; +} + +div.sidebar::after, +aside.sidebar::after, +nav.contents::after, +aside.topic::after, +div.topic::after, +div.admonition::after, +blockquote::after { + display: block; + content: ''; + clear: both; +} + +/* -- tables ---------------------------------------------------------------- */ + +table.docutils { + margin-top: 10px; + margin-bottom: 10px; + border: 0; + border-collapse: collapse; +} + +table.align-center { + margin-left: auto; + margin-right: auto; +} + +table.align-default { + margin-left: auto; + margin-right: auto; +} + +table caption span.caption-number { + font-style: italic; +} + +table caption span.caption-text { +} + +table.docutils td, table.docutils th { + padding: 1px 8px 1px 5px; + border-top: 0; + border-left: 0; + border-right: 0; + border-bottom: 1px solid #aaa; +} + +th { + text-align: left; + padding-right: 5px; +} + +table.citation { + border-left: solid 1px gray; + margin-left: 1px; +} + +table.citation td { + border-bottom: none; +} + +th > :first-child, +td > :first-child { + margin-top: 0px; +} + +th > :last-child, +td > :last-child { + margin-bottom: 0px; +} + +/* -- figures --------------------------------------------------------------- */ + +div.figure, figure { + margin: 0.5em; + padding: 0.5em; +} + +div.figure p.caption, figcaption { + padding: 0.3em; +} + +div.figure p.caption span.caption-number, +figcaption span.caption-number { + font-style: italic; +} + +div.figure p.caption span.caption-text, +figcaption span.caption-text { +} + +/* -- field list styles ----------------------------------------------------- */ + +table.field-list td, table.field-list th { + border: 0 !important; +} + +.field-list ul { + margin: 0; + padding-left: 1em; +} + +.field-list p { + margin: 0; +} + +.field-name { + -moz-hyphens: manual; + -ms-hyphens: manual; + -webkit-hyphens: manual; + hyphens: manual; +} + +/* -- hlist styles ---------------------------------------------------------- */ + +table.hlist { + margin: 1em 0; +} + +table.hlist td { + vertical-align: top; +} + +/* -- object description styles --------------------------------------------- */ + +.sig { + font-family: 'Consolas', 'Menlo', 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', monospace; +} + +.sig-name, code.descname { + background-color: transparent; + font-weight: bold; +} + +.sig-name { + font-size: 1.1em; +} + +code.descname { + font-size: 1.2em; +} + +.sig-prename, code.descclassname { + background-color: transparent; +} + +.optional { + font-size: 1.3em; +} + +.sig-paren { + font-size: larger; +} + +.sig-param.n { + font-style: italic; +} + +/* C++ specific styling */ + +.sig-inline.c-texpr, +.sig-inline.cpp-texpr { + font-family: unset; +} + +.sig.c .k, .sig.c .kt, +.sig.cpp .k, .sig.cpp .kt { + color: #0033B3; +} + +.sig.c .m, +.sig.cpp .m { + color: #1750EB; +} + +.sig.c .s, .sig.c .sc, +.sig.cpp .s, .sig.cpp .sc { + color: #067D17; +} + + +/* -- other body styles ----------------------------------------------------- */ + +ol.arabic { + list-style: decimal; +} + +ol.loweralpha { + list-style: lower-alpha; +} + +ol.upperalpha { + list-style: upper-alpha; +} + +ol.lowerroman { + list-style: lower-roman; +} + +ol.upperroman { + list-style: upper-roman; +} + +:not(li) > ol > li:first-child > :first-child, +:not(li) > ul > li:first-child > :first-child { + margin-top: 0px; +} + +:not(li) > ol > li:last-child > :last-child, +:not(li) > ul > li:last-child > :last-child { + margin-bottom: 0px; +} + +ol.simple ol p, +ol.simple ul p, +ul.simple ol p, +ul.simple ul p { + margin-top: 0; +} + +ol.simple > li:not(:first-child) > p, +ul.simple > li:not(:first-child) > p { + margin-top: 0; +} + +ol.simple p, +ul.simple p { + margin-bottom: 0; +} + +aside.footnote > span, +div.citation > span { + float: left; +} +aside.footnote > span:last-of-type, +div.citation > span:last-of-type { + padding-right: 0.5em; +} +aside.footnote > p { + margin-left: 2em; +} +div.citation > p { + margin-left: 4em; +} +aside.footnote > p:last-of-type, +div.citation > p:last-of-type { + margin-bottom: 0em; +} +aside.footnote > p:last-of-type:after, +div.citation > p:last-of-type:after { + content: ""; + clear: both; +} + +dl.field-list { + display: grid; + grid-template-columns: fit-content(30%) auto; +} + +dl.field-list > dt { + font-weight: bold; + word-break: break-word; + padding-left: 0.5em; + padding-right: 5px; +} + +dl.field-list > dd { + padding-left: 0.5em; + margin-top: 0em; + margin-left: 0em; + margin-bottom: 0em; +} + +dl { + margin-bottom: 15px; +} + +dd > :first-child { + margin-top: 0px; +} + +dd ul, dd table { + margin-bottom: 10px; +} + +dd { + margin-top: 3px; + margin-bottom: 10px; + margin-left: 30px; +} + +.sig dd { + margin-top: 0px; + margin-bottom: 0px; +} + +.sig dl { + margin-top: 0px; + margin-bottom: 0px; +} + +dl > dd:last-child, +dl > dd:last-child > :last-child { + margin-bottom: 0; +} + +dt:target, span.highlighted { + background-color: #fbe54e; +} + +rect.highlighted { + fill: #fbe54e; +} + +dl.glossary dt { + font-weight: bold; + font-size: 1.1em; +} + +.versionmodified { + font-style: italic; +} + +.system-message { + background-color: #fda; + padding: 5px; + border: 3px solid red; +} + +.footnote:target { + background-color: #ffa; +} + +.line-block { + display: block; + margin-top: 1em; + margin-bottom: 1em; +} + +.line-block .line-block { + margin-top: 0; + margin-bottom: 0; + margin-left: 1.5em; +} + +.guilabel, .menuselection { + font-family: sans-serif; +} + +.accelerator { + text-decoration: underline; +} + +.classifier { + font-style: oblique; +} + +.classifier:before { + font-style: normal; + margin: 0 0.5em; + content: ":"; + display: inline-block; +} + +abbr, acronym { + border-bottom: dotted 1px; + cursor: help; +} + +/* -- code displays --------------------------------------------------------- */ + +pre { + overflow: auto; + overflow-y: hidden; /* fixes display issues on Chrome browsers */ +} + +pre, div[class*="highlight-"] { + clear: both; +} + +span.pre { + -moz-hyphens: none; + -ms-hyphens: none; + -webkit-hyphens: none; + hyphens: none; + white-space: nowrap; +} + +div[class*="highlight-"] { + margin: 1em 0; +} + +td.linenos pre { + border: 0; + background-color: transparent; + color: #aaa; +} + +table.highlighttable { + display: block; +} + +table.highlighttable tbody { + display: block; +} + +table.highlighttable tr { + display: flex; +} + +table.highlighttable td { + margin: 0; + padding: 0; +} + +table.highlighttable td.linenos { + padding-right: 0.5em; +} + +table.highlighttable td.code { + flex: 1; + overflow: hidden; +} + +.highlight .hll { + display: block; +} + +div.highlight pre, +table.highlighttable pre { + margin: 0; +} + +div.code-block-caption + div { + margin-top: 0; +} + +div.code-block-caption { + margin-top: 1em; + padding: 2px 5px; + font-size: small; +} + +div.code-block-caption code { + background-color: transparent; +} + +table.highlighttable td.linenos, +span.linenos, +div.highlight span.gp { /* gp: Generic.Prompt */ + user-select: none; + -webkit-user-select: text; /* Safari fallback only */ + -webkit-user-select: none; /* Chrome/Safari */ + -moz-user-select: none; /* Firefox */ + -ms-user-select: none; /* IE10+ */ +} + +div.code-block-caption span.caption-number { + padding: 0.1em 0.3em; + font-style: italic; +} + +div.code-block-caption span.caption-text { +} + +div.literal-block-wrapper { + margin: 1em 0; +} + +code.xref, a code { + background-color: transparent; + font-weight: bold; +} + +h1 code, h2 code, h3 code, h4 code, h5 code, h6 code { + background-color: transparent; +} + +.viewcode-link { + float: right; +} + +.viewcode-back { + float: right; + font-family: sans-serif; +} + +div.viewcode-block:target { + margin: -1px -10px; + padding: 0 10px; +} + +/* -- math display ---------------------------------------------------------- */ + +img.math { + vertical-align: middle; +} + +div.body div.math p { + text-align: center; +} + +span.eqno { + float: right; +} + +span.eqno a.headerlink { + position: absolute; + z-index: 1; +} + +div.math:hover a.headerlink { + visibility: visible; +} + +/* -- printout stylesheet --------------------------------------------------- */ + +@media print { + div.document, + div.documentwrapper, + div.bodywrapper { + margin: 0 !important; + width: 100%; + } + + div.sphinxsidebar, + div.related, + div.footer, + #top-link { + display: none; + } +} \ No newline at end of file diff --git a/tag/3.5.0/_static/css/ansible.css b/tag/3.5.0/_static/css/ansible.css new file mode 100644 index 0000000..8ecc337 --- /dev/null +++ b/tag/3.5.0/_static/css/ansible.css @@ -0,0 +1,491 @@ +@import 'theme.css'; +/*! minified with http://css-minify.online-domain-tools.com/ - all comments + * must have ! to preserve during minifying with that tool */ +/*! Fix for read the docs theme: + * https://rackerlabs.github.io/docs-rackspace/tools/rtd-tables.html + */ +/*! override table width restrictions */ +@media screen and (min-width: 767px) { + /*! If we ever publish to read the docs, we need to use !important for + * these two styles as read the docs itself loads their theme in a way that + * we can't otherwise override it. + */ + .wy-table-responsive table td { + white-space: normal; + } + .wy-table-responsive { + overflow: visible; + } +} +/*! + * We use the class documentation-table for attribute tables where the first + * column is the name of an attribute and the second column is the description. + */ +/*! These tables look like this: + * + * Attribute Name Description + * -------------- ----------- + * **NAME** This is a multi-line description + * str/required that can span multiple lines + * added in x.y + * With multiple paragraphs + * -------------- ----------- + * + * **NAME** is given the class .value-name + * str is given the class .value-type + * / is given the class .value-separator + * required is given the class .value-required + * added in x.y is given the class .value-added-in + */ +/*! The extra .rst-content is so this will override rtd theme */ +.rst-content table.documentation-table td { + vertical-align: top; +} +table.documentation-table td:first-child { + white-space: nowrap; + vertical-align: top; +} +table.documentation-table td:first-child p:first-child { + font-weight: 700; + display: inline; +} +/*! This is now redundant with above position-based styling */ +/*! +table.documentation-table .value-name { + font-weight: bold; + display: inline; +} +*/ +table.documentation-table .value-type { + font-size: x-small; + color: purple; + display: inline; +} +table.documentation-table .value-separator { + font-size: x-small; + display: inline; +} +table.documentation-table .value-required { + font-size: x-small; + color: red; + display: inline; +} +.value-added-in { + font-size: x-small; + font-style: italic; + color: green; + display: inline; +} +/*! Ansible-specific CSS pulled out of rtd theme for 2.9 */ +.DocSiteProduct-header { + flex: 1; + -webkit-flex: 1; + padding: 10px 20px 20px; + display: flex; + display: -webkit-flex; + flex-direction: column; + -webkit-flex-direction: column; + align-items: center; + -webkit-align-items: center; + justify-content: flex-start; + -webkit-justify-content: flex-start; + margin-left: 20px; + margin-right: 20px; + text-decoration: none; + font-weight: 400; + font-family: "Open Sans", sans-serif; +} +.DocSiteProduct-header:active, +.DocSiteProduct-header:focus, +.DocSiteProduct-header:visited { + color: #fff; +} +.DocSiteProduct-header--core { + font-size: 25px; + background-color: #5bbdbf; + border: 2px solid #5bbdbf; + border-top-left-radius: 4px; + border-top-right-radius: 4px; + color: #fff; + padding-left: 2px; + margin-left: 2px; +} +.DocSiteProduct-headerAlign { + width: 100%; +} +.DocSiteProduct-logo { + width: 60px; + height: 60px; + margin-bottom: -9px; +} +.DocSiteProduct-logoText { + margin-top: 6px; + font-size: 25px; + text-align: left; +} +.DocSiteProduct-CheckVersionPara { + margin-left: 2px; + padding-bottom: 4px; + margin-right: 2px; + margin-bottom: 10px; +} +/*! Ansible color scheme */ +.wy-nav-top, +.wy-side-nav-search { + background-color: #5bbdbf; +} +.wy-menu-vertical header, +.wy-menu-vertical p.caption { + color: #5bbdbf; +} +.wy-menu-vertical a { + padding: 0; +} +.wy-menu-vertical a.reference.internal { + padding: 0.4045em 1.618em; +} +/*! Override sphinx rtd theme max-with of 800px */ +.wy-nav-content { + max-width: 100%; +} +/*! + * Override sphinx_rtd_theme - keeps left-nav from overwriting + * Documentation title + **/ +.wy-nav-side { + top: 45px; +} +/*! + * Ansible - changed absolute to relative to remove extraneous side scroll bar + **/ +.wy-grid-for-nav { + position: relative; +} +/*! Ansible narrow the search box */ +.wy-side-nav-search input[type="text"] { + width: 90%; + padding-left: 24px; +} +/*! Ansible - remove so highlight indenting is correct */ +.rst-content .highlighted { + padding: 0; +} +.DocSiteBanner { + display: flex; + display: -webkit-flex; + justify-content: center; + -webkit-justify-content: center; + flex-wrap: wrap; + -webkit-flex-wrap: wrap; + margin-bottom: 25px; +} +.DocSiteBanner-imgWrapper { + max-width: 100%; +} +td, +th { + min-width: 100px; +} +table { + overflow-x: auto; + max-width: 100%; +} +.documentation-table td, +.documentation-table th { + padding: 4px; + border-left: 1px solid #000; + border-top: 1px solid #000; +} +.documentation-table { + border-right: 1px solid #000; + border-bottom: 1px solid #000; +} +@media print { + * { + background: 0 0 !important; + color: #000 !important; + text-shadow: none !important; + filter: none !important; + -ms-filter: none !important; + } + #nav, + a, + a:visited { + text-decoration: underline; + } + a[href]:after { + content: " (" attr(href) ")"; + } + abbr[title]:after { + content: " (" attr(title) ")"; + } + .ir a:after, + a[href^="javascript:"]:after, + a[href^="#"]:after { + content: ""; + } + /*! Don't show links for images, or javascript/internal links */ + pre, + blockquote { + border: 0 solid #999; + page-break-inside: avoid; + } + thead { + display: table-header-group; + } + /*! h5bp.com/t */ + tr, + img { + page-break-inside: avoid; + } + img { + max-width: 100% !important; + } + @page { + margin: 0.5cm; + } + h2, + h3, + p { + orphans: 3; + widows: 3; + } + h2, + h3 { + page-break-after: avoid; + } + #google_image_div, + .DocSiteBanner { + display: none !important; + } +} +#sideBanner, +.DocSite-globalNav { + display: none; +} +.DocSite-sideNav { + display: block; + margin-bottom: 40px; +} +.DocSite-nav { + display: none; +} +.ansibleNav { + background: #000; + padding: 0 20px; + width: auto; + border-bottom: 1px solid #444; + font-size: 14px; + z-index: 1; +} +.ansibleNav ul { + list-style: none; + padding-left: 0; + margin-top: 0; +} +.ansibleNav ul li { + padding: 7px 0; + border-bottom: 1px solid #444; +} +.ansibleNav ul li:last-child { + border: none; +} +.ansibleNav ul li a { + color: #fff; + text-decoration: none; + text-transform: uppercase; + padding: 6px 0; +} +.ansibleNav ul li a:hover { + color: #5bbdbf; + background: 0 0; +} +h4 { + font-size: 105%; +} +h5 { + font-size: 90%; +} +h6 { + font-size: 80%; +} +@media screen and (min-width: 768px) { + .DocSite-globalNav { + display: block; + position: fixed; + } + #sideBanner { + display: block; + } + .DocSite-sideNav { + display: none; + } + .DocSite-nav { + flex: initial; + -webkit-flex: initial; + display: flex; + display: -webkit-flex; + flex-direction: row; + -webkit-flex-direction: row; + justify-content: flex-start; + -webkit-justify-content: flex-start; + padding: 15px; + background-color: #000; + text-decoration: none; + font-family: "Open Sans", sans-serif; + } + .DocSiteNav-logo { + width: 28px; + height: 28px; + margin-right: 8px; + margin-top: -6px; + position: fixed; + z-index: 1; + } + .DocSiteNav-title { + color: #fff; + font-size: 20px; + position: fixed; + margin-left: 40px; + margin-top: -4px; + z-index: 1; + } + .ansibleNav { + height: 45px; + width: 100%; + font-size: 13px; + padding: 0 60px 0 0; + } + .ansibleNav ul { + float: right; + display: flex; + flex-wrap: nowrap; + margin-top: 13px; + } + .ansibleNav ul li { + padding: 0; + border-bottom: none; + } + .ansibleNav ul li a { + color: #fff; + text-decoration: none; + text-transform: uppercase; + padding: 8px 13px; + } + h4 { + font-size: 105%; + } + h5 { + font-size: 90%; + } + h6 { + font-size: 80%; + } +} +@media screen and (min-width: 768px) { + #sideBanner, + .DocSite-globalNav { + display: block; + } + .DocSite-sideNav { + display: none; + } + .DocSite-nav { + flex: initial; + -webkit-flex: initial; + display: flex; + display: -webkit-flex; + flex-direction: row; + -webkit-flex-direction: row; + justify-content: flex-start; + -webkit-justify-content: flex-start; + padding: 15px; + background-color: #000; + text-decoration: none; + font-family: "Open Sans", sans-serif; + } + .DocSiteNav-logo { + width: 28px; + height: 28px; + margin-right: 8px; + margin-top: -6px; + position: fixed; + } + .DocSiteNav-title { + color: #fff; + font-size: 20px; + position: fixed; + margin-left: 40px; + margin-top: -4px; + } + .ansibleNav { + height: 45px; + font-size: 13px; + padding: 0 60px 0 0; + } + .ansibleNav ul { + float: right; + display: flex; + flex-wrap: nowrap; + margin-top: 13px; + } + .ansibleNav ul li { + padding: 0; + border-bottom: none; + } + .ansibleNav ul li a { + color: #fff; + text-decoration: none; + text-transform: uppercase; + padding: 8px 13px; + } + h4 { + font-size: 105%; + } + h5 { + font-size: 90%; + } + h6 { + font-size: 80%; + } +} +/* ansibleOptionLink is adapted from h1 .headerlink in sphinx_rtd_theme */ +/* This definition lives in the antsibull Sphinx extension; we update it here to use the icon from FontAwesome */ +/* https://github.com/ansible-community/antsibull-docs/blob/main/src/sphinx_antsibull_ext/css/antsibull-minimal.scss */ +tr .ansibleOptionLink::after { + content: "" !important; + font-family: FontAwesome; +} +tr .ansibleOptionLink { + font: normal normal normal 14px/1 FontAwesome; + text-rendering: auto; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; +} + +@media screen and (min-width: 767px) { + /* Move anchors a bit up so that they aren't hidden by the header bar */ + section [id] { + padding-top: 45px; + margin-top: -45px; + } + /* + * Without this, + * for example most links in the page's TOC aren't usable anymore, and tables + * sometimes overlap the text above + * */ + section a[id], section table[id] { + padding-top: 0; + margin-top: 0; + } +} + +/* Assure reading examples does not require horizontal scrolling */ +.rst-content div[class^="highlight"] pre { + white-space: pre-wrap; +} + +.rst-content dl dt { margin-bottom: 0; } + +/*! Make sure that environment variable links are blue */ +.rst-content code.xref.std-envvar { color: #2980b9; } diff --git a/tag/3.5.0/_static/css/badge_only.css b/tag/3.5.0/_static/css/badge_only.css new file mode 100644 index 0000000..88ba55b --- /dev/null +++ b/tag/3.5.0/_static/css/badge_only.css @@ -0,0 +1 @@ +.clearfix{*zoom:1}.clearfix:after,.clearfix:before{display:table;content:""}.clearfix:after{clear:both}@font-face{font-family:FontAwesome;font-style:normal;font-weight:400;src:url(fonts/fontawesome-webfont.eot?674f50d287a8c48dc19ba404d20fe713?#iefix) format("embedded-opentype"),url(fonts/fontawesome-webfont.woff2?af7ae505a9eed503f8b8e6982036873e) format("woff2"),url(fonts/fontawesome-webfont.woff?fee66e712a8a08eef5805a46892932ad) format("woff"),url(fonts/fontawesome-webfont.ttf?b06871f281fee6b241d60582ae9369b9) format("truetype"),url(fonts/fontawesome-webfont.svg?912ec66d7572ff821749319396470bde#FontAwesome) format("svg")}.fa:before{font-family:FontAwesome;font-style:normal;font-weight:400;line-height:1}.fa:before,a .fa{text-decoration:inherit}.fa:before,a .fa,li .fa{display:inline-block}li .fa-large:before{width:1.875em}ul.fas{list-style-type:none;margin-left:2em;text-indent:-.8em}ul.fas li .fa{width:.8em}ul.fas li .fa-large:before{vertical-align:baseline}.fa-book:before,.icon-book:before{content:"\f02d"}.fa-caret-down:before,.icon-caret-down:before{content:"\f0d7"}.fa-caret-up:before,.icon-caret-up:before{content:"\f0d8"}.fa-caret-left:before,.icon-caret-left:before{content:"\f0d9"}.fa-caret-right:before,.icon-caret-right:before{content:"\f0da"}.rst-versions{position:fixed;bottom:0;left:0;width:300px;color:#fcfcfc;background:#1f1d1d;font-family:Lato,proxima-nova,Helvetica Neue,Arial,sans-serif;z-index:400}.rst-versions a{color:#2980b9;text-decoration:none}.rst-versions .rst-badge-small{display:none}.rst-versions .rst-current-version{padding:12px;background-color:#272525;display:block;text-align:right;font-size:90%;cursor:pointer;color:#27ae60}.rst-versions .rst-current-version:after{clear:both;content:"";display:block}.rst-versions .rst-current-version .fa{color:#fcfcfc}.rst-versions .rst-current-version .fa-book,.rst-versions .rst-current-version .icon-book{float:left}.rst-versions .rst-current-version.rst-out-of-date{background-color:#e74c3c;color:#fff}.rst-versions .rst-current-version.rst-active-old-version{background-color:#f1c40f;color:#000}.rst-versions.shift-up{height:auto;max-height:100%;overflow-y:scroll}.rst-versions.shift-up .rst-other-versions{display:block}.rst-versions .rst-other-versions{font-size:90%;padding:12px;color:grey;display:none}.rst-versions .rst-other-versions hr{display:block;height:1px;border:0;margin:20px 0;padding:0;border-top:1px solid #413d3d}.rst-versions .rst-other-versions dd{display:inline-block;margin:0}.rst-versions .rst-other-versions dd a{display:inline-block;padding:6px;color:#fcfcfc}.rst-versions .rst-other-versions .rtd-current-item{font-weight:700}.rst-versions.rst-badge{width:auto;bottom:20px;right:20px;left:auto;border:none;max-width:300px;max-height:90%}.rst-versions.rst-badge .fa-book,.rst-versions.rst-badge .icon-book{float:none;line-height:30px}.rst-versions.rst-badge.shift-up .rst-current-version{text-align:right}.rst-versions.rst-badge.shift-up .rst-current-version .fa-book,.rst-versions.rst-badge.shift-up .rst-current-version .icon-book{float:left}.rst-versions.rst-badge>.rst-current-version{width:auto;height:30px;line-height:30px;padding:0 6px;display:block;text-align:center}@media screen and (max-width:768px){.rst-versions{width:85%;display:none}.rst-versions.shift{display:block}}#flyout-search-form{padding:6px} \ No newline at end of file diff --git a/tag/3.5.0/_static/css/fonts/Roboto-Slab-Bold.woff b/tag/3.5.0/_static/css/fonts/Roboto-Slab-Bold.woff new file mode 100644 index 0000000..6cb6000 Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/Roboto-Slab-Bold.woff differ diff --git a/tag/3.5.0/_static/css/fonts/Roboto-Slab-Bold.woff2 b/tag/3.5.0/_static/css/fonts/Roboto-Slab-Bold.woff2 new file mode 100644 index 0000000..7059e23 Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/Roboto-Slab-Bold.woff2 differ diff --git a/tag/3.5.0/_static/css/fonts/Roboto-Slab-Regular.woff b/tag/3.5.0/_static/css/fonts/Roboto-Slab-Regular.woff new file mode 100644 index 0000000..f815f63 Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/Roboto-Slab-Regular.woff differ diff --git a/tag/3.5.0/_static/css/fonts/Roboto-Slab-Regular.woff2 b/tag/3.5.0/_static/css/fonts/Roboto-Slab-Regular.woff2 new file mode 100644 index 0000000..f2c76e5 Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/Roboto-Slab-Regular.woff2 differ diff --git a/tag/3.5.0/_static/css/fonts/fontawesome-webfont.eot b/tag/3.5.0/_static/css/fonts/fontawesome-webfont.eot new file mode 100644 index 0000000..e9f60ca Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/fontawesome-webfont.eot differ diff --git a/tag/3.5.0/_static/css/fonts/fontawesome-webfont.svg b/tag/3.5.0/_static/css/fonts/fontawesome-webfont.svg new file mode 100644 index 0000000..855c845 --- /dev/null +++ b/tag/3.5.0/_static/css/fonts/fontawesome-webfont.svg @@ -0,0 +1,2671 @@ + + + + +Created by FontForge 20120731 at Mon Oct 24 17:37:40 2016 + By ,,, +Copyright Dave Gandy 2016. All rights reserved. + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/tag/3.5.0/_static/css/fonts/fontawesome-webfont.ttf b/tag/3.5.0/_static/css/fonts/fontawesome-webfont.ttf new file mode 100644 index 0000000..35acda2 Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/fontawesome-webfont.ttf differ diff --git a/tag/3.5.0/_static/css/fonts/fontawesome-webfont.woff b/tag/3.5.0/_static/css/fonts/fontawesome-webfont.woff new file mode 100644 index 0000000..400014a Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/fontawesome-webfont.woff differ diff --git a/tag/3.5.0/_static/css/fonts/fontawesome-webfont.woff2 b/tag/3.5.0/_static/css/fonts/fontawesome-webfont.woff2 new file mode 100644 index 0000000..4d13fc6 Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/fontawesome-webfont.woff2 differ diff --git a/tag/3.5.0/_static/css/fonts/lato-bold-italic.woff b/tag/3.5.0/_static/css/fonts/lato-bold-italic.woff new file mode 100644 index 0000000..88ad05b Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/lato-bold-italic.woff differ diff --git a/tag/3.5.0/_static/css/fonts/lato-bold-italic.woff2 b/tag/3.5.0/_static/css/fonts/lato-bold-italic.woff2 new file mode 100644 index 0000000..c4e3d80 Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/lato-bold-italic.woff2 differ diff --git a/tag/3.5.0/_static/css/fonts/lato-bold.woff b/tag/3.5.0/_static/css/fonts/lato-bold.woff new file mode 100644 index 0000000..c6dff51 Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/lato-bold.woff differ diff --git a/tag/3.5.0/_static/css/fonts/lato-bold.woff2 b/tag/3.5.0/_static/css/fonts/lato-bold.woff2 new file mode 100644 index 0000000..bb19504 Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/lato-bold.woff2 differ diff --git a/tag/3.5.0/_static/css/fonts/lato-normal-italic.woff b/tag/3.5.0/_static/css/fonts/lato-normal-italic.woff new file mode 100644 index 0000000..76114bc Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/lato-normal-italic.woff differ diff --git a/tag/3.5.0/_static/css/fonts/lato-normal-italic.woff2 b/tag/3.5.0/_static/css/fonts/lato-normal-italic.woff2 new file mode 100644 index 0000000..3404f37 Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/lato-normal-italic.woff2 differ diff --git a/tag/3.5.0/_static/css/fonts/lato-normal.woff b/tag/3.5.0/_static/css/fonts/lato-normal.woff new file mode 100644 index 0000000..ae1307f Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/lato-normal.woff differ diff --git a/tag/3.5.0/_static/css/fonts/lato-normal.woff2 b/tag/3.5.0/_static/css/fonts/lato-normal.woff2 new file mode 100644 index 0000000..3bf9843 Binary files /dev/null and b/tag/3.5.0/_static/css/fonts/lato-normal.woff2 differ diff --git a/tag/3.5.0/_static/css/rtd-ethical-ads.css b/tag/3.5.0/_static/css/rtd-ethical-ads.css new file mode 100644 index 0000000..a146003 --- /dev/null +++ b/tag/3.5.0/_static/css/rtd-ethical-ads.css @@ -0,0 +1,4 @@ +.ethical-sidebar, +.ethical-footer { + border-radius: 0 !important; +} diff --git a/tag/3.5.0/_static/css/theme.css b/tag/3.5.0/_static/css/theme.css new file mode 100644 index 0000000..0f14f10 --- /dev/null +++ b/tag/3.5.0/_static/css/theme.css @@ -0,0 +1,4 @@ +html{box-sizing:border-box}*,:after,:before{box-sizing:inherit}article,aside,details,figcaption,figure,footer,header,hgroup,nav,section{display:block}audio,canvas,video{display:inline-block;*display:inline;*zoom:1}[hidden],audio:not([controls]){display:none}*{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}html{font-size:100%;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}body{margin:0}a:active,a:hover{outline:0}abbr[title]{border-bottom:1px dotted}b,strong{font-weight:700}blockquote{margin:0}dfn{font-style:italic}ins{background:#ff9;text-decoration:none}ins,mark{color:#000}mark{background:#ff0;font-style:italic;font-weight:700}.rst-content code,.rst-content tt,code,kbd,pre,samp{font-family:monospace,serif;_font-family:courier new,monospace;font-size:1em}pre{white-space:pre}q{quotes:none}q:after,q:before{content:"";content:none}small{font-size:85%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sup{top:-.5em}sub{bottom:-.25em}dl,ol,ul{margin:0;padding:0;list-style:none;list-style-image:none}li{list-style:none}dd{margin:0}img{border:0;-ms-interpolation-mode:bicubic;vertical-align:middle;max-width:100%}svg:not(:root){overflow:hidden}figure,form{margin:0}label{cursor:pointer}button,input,select,textarea{font-size:100%;margin:0;vertical-align:baseline;*vertical-align:middle}button,input{line-height:normal}button,input[type=button],input[type=reset],input[type=submit]{cursor:pointer;-webkit-appearance:button;*overflow:visible}button[disabled],input[disabled]{cursor:default}input[type=search]{-webkit-appearance:textfield;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;box-sizing:content-box}textarea{resize:vertical}table{border-collapse:collapse;border-spacing:0}td{vertical-align:top}.chromeframe{margin:.2em 0;background:#ccc;color:#000;padding:.2em 0}.ir{display:block;border:0;text-indent:-999em;overflow:hidden;background-color:transparent;background-repeat:no-repeat;text-align:left;direction:ltr;*line-height:0}.ir br{display:none}.hidden{display:none!important;visibility:hidden}.visuallyhidden{border:0;clip:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px}.visuallyhidden.focusable:active,.visuallyhidden.focusable:focus{clip:auto;height:auto;margin:0;overflow:visible;position:static;width:auto}.invisible{visibility:hidden}.relative{position:relative}big,small{font-size:100%}@media print{body,html,section{background:none!important}*{box-shadow:none!important;text-shadow:none!important;filter:none!important;-ms-filter:none!important}a,a:visited{text-decoration:underline}.ir a:after,a[href^="#"]:after,a[href^="javascript:"]:after{content:""}blockquote,pre{page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}@page{margin:.5cm}.rst-content .toctree-wrapper>p.caption,h2,h3,p{orphans:3;widows:3}.rst-content .toctree-wrapper>p.caption,h2,h3{page-break-after:avoid}}.btn,.fa:before,.icon:before,.rst-content .admonition,.rst-content .admonition-title:before,.rst-content .admonition-todo,.rst-content .attention,.rst-content .caution,.rst-content .code-block-caption .headerlink:before,.rst-content .danger,.rst-content .eqno .headerlink:before,.rst-content .error,.rst-content .hint,.rst-content .important,.rst-content .note,.rst-content .seealso,.rst-content .tip,.rst-content .warning,.rst-content code.download span:first-child:before,.rst-content dl dt .headerlink:before,.rst-content h1 .headerlink:before,.rst-content h2 .headerlink:before,.rst-content h3 .headerlink:before,.rst-content h4 .headerlink:before,.rst-content h5 .headerlink:before,.rst-content h6 .headerlink:before,.rst-content p.caption .headerlink:before,.rst-content p .headerlink:before,.rst-content table>caption .headerlink:before,.rst-content tt.download span:first-child:before,.wy-alert,.wy-dropdown .caret:before,.wy-inline-validate.wy-inline-validate-danger .wy-input-context:before,.wy-inline-validate.wy-inline-validate-info .wy-input-context:before,.wy-inline-validate.wy-inline-validate-success .wy-input-context:before,.wy-inline-validate.wy-inline-validate-warning .wy-input-context:before,.wy-menu-vertical li.current>a button.toctree-expand:before,.wy-menu-vertical li.on a button.toctree-expand:before,.wy-menu-vertical li button.toctree-expand:before,input[type=color],input[type=date],input[type=datetime-local],input[type=datetime],input[type=email],input[type=month],input[type=number],input[type=password],input[type=search],input[type=tel],input[type=text],input[type=time],input[type=url],input[type=week],select,textarea{-webkit-font-smoothing:antialiased}.clearfix{*zoom:1}.clearfix:after,.clearfix:before{display:table;content:""}.clearfix:after{clear:both}/*! + * Font Awesome 4.7.0 by @davegandy - http://fontawesome.io - @fontawesome + * License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License) + */@font-face{font-family:FontAwesome;src:url(fonts/fontawesome-webfont.eot?674f50d287a8c48dc19ba404d20fe713);src:url(fonts/fontawesome-webfont.eot?674f50d287a8c48dc19ba404d20fe713?#iefix&v=4.7.0) format("embedded-opentype"),url(fonts/fontawesome-webfont.woff2?af7ae505a9eed503f8b8e6982036873e) format("woff2"),url(fonts/fontawesome-webfont.woff?fee66e712a8a08eef5805a46892932ad) format("woff"),url(fonts/fontawesome-webfont.ttf?b06871f281fee6b241d60582ae9369b9) format("truetype"),url(fonts/fontawesome-webfont.svg?912ec66d7572ff821749319396470bde#fontawesomeregular) format("svg");font-weight:400;font-style:normal}.fa,.icon,.rst-content .admonition-title,.rst-content .code-block-caption .headerlink,.rst-content .eqno .headerlink,.rst-content code.download span:first-child,.rst-content dl dt .headerlink,.rst-content h1 .headerlink,.rst-content h2 .headerlink,.rst-content h3 .headerlink,.rst-content h4 .headerlink,.rst-content h5 .headerlink,.rst-content h6 .headerlink,.rst-content p.caption .headerlink,.rst-content p .headerlink,.rst-content table>caption .headerlink,.rst-content tt.download span:first-child,.wy-menu-vertical li.current>a button.toctree-expand,.wy-menu-vertical li.on a button.toctree-expand,.wy-menu-vertical li button.toctree-expand{display:inline-block;font:normal normal normal 14px/1 FontAwesome;font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fa-lg{font-size:1.33333em;line-height:.75em;vertical-align:-15%}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-fw{width:1.28571em;text-align:center}.fa-ul{padding-left:0;margin-left:2.14286em;list-style-type:none}.fa-ul>li{position:relative}.fa-li{position:absolute;left:-2.14286em;width:2.14286em;top:.14286em;text-align:center}.fa-li.fa-lg{left:-1.85714em}.fa-border{padding:.2em .25em .15em;border:.08em solid #eee;border-radius:.1em}.fa-pull-left{float:left}.fa-pull-right{float:right}.fa-pull-left.icon,.fa.fa-pull-left,.rst-content .code-block-caption .fa-pull-left.headerlink,.rst-content .eqno .fa-pull-left.headerlink,.rst-content .fa-pull-left.admonition-title,.rst-content code.download span.fa-pull-left:first-child,.rst-content dl dt .fa-pull-left.headerlink,.rst-content h1 .fa-pull-left.headerlink,.rst-content h2 .fa-pull-left.headerlink,.rst-content h3 .fa-pull-left.headerlink,.rst-content h4 .fa-pull-left.headerlink,.rst-content h5 .fa-pull-left.headerlink,.rst-content h6 .fa-pull-left.headerlink,.rst-content p .fa-pull-left.headerlink,.rst-content table>caption .fa-pull-left.headerlink,.rst-content tt.download span.fa-pull-left:first-child,.wy-menu-vertical li.current>a button.fa-pull-left.toctree-expand,.wy-menu-vertical li.on a button.fa-pull-left.toctree-expand,.wy-menu-vertical li button.fa-pull-left.toctree-expand{margin-right:.3em}.fa-pull-right.icon,.fa.fa-pull-right,.rst-content .code-block-caption .fa-pull-right.headerlink,.rst-content .eqno .fa-pull-right.headerlink,.rst-content .fa-pull-right.admonition-title,.rst-content code.download span.fa-pull-right:first-child,.rst-content dl dt .fa-pull-right.headerlink,.rst-content h1 .fa-pull-right.headerlink,.rst-content h2 .fa-pull-right.headerlink,.rst-content h3 .fa-pull-right.headerlink,.rst-content h4 .fa-pull-right.headerlink,.rst-content h5 .fa-pull-right.headerlink,.rst-content h6 .fa-pull-right.headerlink,.rst-content p .fa-pull-right.headerlink,.rst-content table>caption .fa-pull-right.headerlink,.rst-content tt.download span.fa-pull-right:first-child,.wy-menu-vertical li.current>a button.fa-pull-right.toctree-expand,.wy-menu-vertical li.on a button.fa-pull-right.toctree-expand,.wy-menu-vertical li button.fa-pull-right.toctree-expand{margin-left:.3em}.pull-right{float:right}.pull-left{float:left}.fa.pull-left,.pull-left.icon,.rst-content .code-block-caption .pull-left.headerlink,.rst-content .eqno .pull-left.headerlink,.rst-content .pull-left.admonition-title,.rst-content code.download span.pull-left:first-child,.rst-content dl dt .pull-left.headerlink,.rst-content h1 .pull-left.headerlink,.rst-content h2 .pull-left.headerlink,.rst-content h3 .pull-left.headerlink,.rst-content h4 .pull-left.headerlink,.rst-content h5 .pull-left.headerlink,.rst-content h6 .pull-left.headerlink,.rst-content p .pull-left.headerlink,.rst-content table>caption .pull-left.headerlink,.rst-content tt.download span.pull-left:first-child,.wy-menu-vertical li.current>a button.pull-left.toctree-expand,.wy-menu-vertical li.on a button.pull-left.toctree-expand,.wy-menu-vertical li button.pull-left.toctree-expand{margin-right:.3em}.fa.pull-right,.pull-right.icon,.rst-content .code-block-caption .pull-right.headerlink,.rst-content .eqno .pull-right.headerlink,.rst-content .pull-right.admonition-title,.rst-content code.download span.pull-right:first-child,.rst-content dl dt .pull-right.headerlink,.rst-content h1 .pull-right.headerlink,.rst-content h2 .pull-right.headerlink,.rst-content h3 .pull-right.headerlink,.rst-content h4 .pull-right.headerlink,.rst-content h5 .pull-right.headerlink,.rst-content h6 .pull-right.headerlink,.rst-content p .pull-right.headerlink,.rst-content table>caption .pull-right.headerlink,.rst-content tt.download span.pull-right:first-child,.wy-menu-vertical li.current>a button.pull-right.toctree-expand,.wy-menu-vertical li.on a button.pull-right.toctree-expand,.wy-menu-vertical li button.pull-right.toctree-expand{margin-left:.3em}.fa-spin{-webkit-animation:fa-spin 2s linear infinite;animation:fa-spin 2s linear infinite}.fa-pulse{-webkit-animation:fa-spin 1s steps(8) infinite;animation:fa-spin 1s steps(8) infinite}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.fa-rotate-90{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=1)";-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2)";-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=3)";-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1)";-webkit-transform:scaleX(-1);-ms-transform:scaleX(-1);transform:scaleX(-1)}.fa-flip-vertical{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1)";-webkit-transform:scaleY(-1);-ms-transform:scaleY(-1);transform:scaleY(-1)}:root .fa-flip-horizontal,:root .fa-flip-vertical,:root .fa-rotate-90,:root .fa-rotate-180,:root .fa-rotate-270{filter:none}.fa-stack{position:relative;display:inline-block;width:2em;height:2em;line-height:2em;vertical-align:middle}.fa-stack-1x,.fa-stack-2x{position:absolute;left:0;width:100%;text-align:center}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:#fff}.fa-glass:before{content:""}.fa-music:before{content:""}.fa-search:before,.icon-search:before{content:""}.fa-envelope-o:before{content:""}.fa-heart:before{content:""}.fa-star:before{content:""}.fa-star-o:before{content:""}.fa-user:before{content:""}.fa-film:before{content:""}.fa-th-large:before{content:""}.fa-th:before{content:""}.fa-th-list:before{content:""}.fa-check:before{content:""}.fa-close:before,.fa-remove:before,.fa-times:before{content:""}.fa-search-plus:before{content:""}.fa-search-minus:before{content:""}.fa-power-off:before{content:""}.fa-signal:before{content:""}.fa-cog:before,.fa-gear:before{content:""}.fa-trash-o:before{content:""}.fa-home:before,.icon-home:before{content:""}.fa-file-o:before{content:""}.fa-clock-o:before{content:""}.fa-road:before{content:""}.fa-download:before,.rst-content code.download span:first-child:before,.rst-content tt.download span:first-child:before{content:""}.fa-arrow-circle-o-down:before{content:""}.fa-arrow-circle-o-up:before{content:""}.fa-inbox:before{content:""}.fa-play-circle-o:before{content:""}.fa-repeat:before,.fa-rotate-right:before{content:""}.fa-refresh:before{content:""}.fa-list-alt:before{content:""}.fa-lock:before{content:""}.fa-flag:before{content:""}.fa-headphones:before{content:""}.fa-volume-off:before{content:""}.fa-volume-down:before{content:""}.fa-volume-up:before{content:""}.fa-qrcode:before{content:""}.fa-barcode:before{content:""}.fa-tag:before{content:""}.fa-tags:before{content:""}.fa-book:before,.icon-book:before{content:""}.fa-bookmark:before{content:""}.fa-print:before{content:""}.fa-camera:before{content:""}.fa-font:before{content:""}.fa-bold:before{content:""}.fa-italic:before{content:""}.fa-text-height:before{content:""}.fa-text-width:before{content:""}.fa-align-left:before{content:""}.fa-align-center:before{content:""}.fa-align-right:before{content:""}.fa-align-justify:before{content:""}.fa-list:before{content:""}.fa-dedent:before,.fa-outdent:before{content:""}.fa-indent:before{content:""}.fa-video-camera:before{content:""}.fa-image:before,.fa-photo:before,.fa-picture-o:before{content:""}.fa-pencil:before{content:""}.fa-map-marker:before{content:""}.fa-adjust:before{content:""}.fa-tint:before{content:""}.fa-edit:before,.fa-pencil-square-o:before{content:""}.fa-share-square-o:before{content:""}.fa-check-square-o:before{content:""}.fa-arrows:before{content:""}.fa-step-backward:before{content:""}.fa-fast-backward:before{content:""}.fa-backward:before{content:""}.fa-play:before{content:""}.fa-pause:before{content:""}.fa-stop:before{content:""}.fa-forward:before{content:""}.fa-fast-forward:before{content:""}.fa-step-forward:before{content:""}.fa-eject:before{content:""}.fa-chevron-left:before{content:""}.fa-chevron-right:before{content:""}.fa-plus-circle:before{content:""}.fa-minus-circle:before{content:""}.fa-times-circle:before,.wy-inline-validate.wy-inline-validate-danger .wy-input-context:before{content:""}.fa-check-circle:before,.wy-inline-validate.wy-inline-validate-success .wy-input-context:before{content:""}.fa-question-circle:before{content:""}.fa-info-circle:before{content:""}.fa-crosshairs:before{content:""}.fa-times-circle-o:before{content:""}.fa-check-circle-o:before{content:""}.fa-ban:before{content:""}.fa-arrow-left:before{content:""}.fa-arrow-right:before{content:""}.fa-arrow-up:before{content:""}.fa-arrow-down:before{content:""}.fa-mail-forward:before,.fa-share:before{content:""}.fa-expand:before{content:""}.fa-compress:before{content:""}.fa-plus:before{content:""}.fa-minus:before{content:""}.fa-asterisk:before{content:""}.fa-exclamation-circle:before,.rst-content .admonition-title:before,.wy-inline-validate.wy-inline-validate-info .wy-input-context:before,.wy-inline-validate.wy-inline-validate-warning .wy-input-context:before{content:""}.fa-gift:before{content:""}.fa-leaf:before{content:""}.fa-fire:before,.icon-fire:before{content:""}.fa-eye:before{content:""}.fa-eye-slash:before{content:""}.fa-exclamation-triangle:before,.fa-warning:before{content:""}.fa-plane:before{content:""}.fa-calendar:before{content:""}.fa-random:before{content:""}.fa-comment:before{content:""}.fa-magnet:before{content:""}.fa-chevron-up:before{content:""}.fa-chevron-down:before{content:""}.fa-retweet:before{content:""}.fa-shopping-cart:before{content:""}.fa-folder:before{content:""}.fa-folder-open:before{content:""}.fa-arrows-v:before{content:""}.fa-arrows-h:before{content:""}.fa-bar-chart-o:before,.fa-bar-chart:before{content:""}.fa-twitter-square:before{content:""}.fa-facebook-square:before{content:""}.fa-camera-retro:before{content:""}.fa-key:before{content:""}.fa-cogs:before,.fa-gears:before{content:""}.fa-comments:before{content:""}.fa-thumbs-o-up:before{content:""}.fa-thumbs-o-down:before{content:""}.fa-star-half:before{content:""}.fa-heart-o:before{content:""}.fa-sign-out:before{content:""}.fa-linkedin-square:before{content:""}.fa-thumb-tack:before{content:""}.fa-external-link:before{content:""}.fa-sign-in:before{content:""}.fa-trophy:before{content:""}.fa-github-square:before{content:""}.fa-upload:before{content:""}.fa-lemon-o:before{content:""}.fa-phone:before{content:""}.fa-square-o:before{content:""}.fa-bookmark-o:before{content:""}.fa-phone-square:before{content:""}.fa-twitter:before{content:""}.fa-facebook-f:before,.fa-facebook:before{content:""}.fa-github:before,.icon-github:before{content:""}.fa-unlock:before{content:""}.fa-credit-card:before{content:""}.fa-feed:before,.fa-rss:before{content:""}.fa-hdd-o:before{content:""}.fa-bullhorn:before{content:""}.fa-bell:before{content:""}.fa-certificate:before{content:""}.fa-hand-o-right:before{content:""}.fa-hand-o-left:before{content:""}.fa-hand-o-up:before{content:""}.fa-hand-o-down:before{content:""}.fa-arrow-circle-left:before,.icon-circle-arrow-left:before{content:""}.fa-arrow-circle-right:before,.icon-circle-arrow-right:before{content:""}.fa-arrow-circle-up:before{content:""}.fa-arrow-circle-down:before{content:""}.fa-globe:before{content:""}.fa-wrench:before{content:""}.fa-tasks:before{content:""}.fa-filter:before{content:""}.fa-briefcase:before{content:""}.fa-arrows-alt:before{content:""}.fa-group:before,.fa-users:before{content:""}.fa-chain:before,.fa-link:before,.icon-link:before{content:""}.fa-cloud:before{content:""}.fa-flask:before{content:""}.fa-cut:before,.fa-scissors:before{content:""}.fa-copy:before,.fa-files-o:before{content:""}.fa-paperclip:before{content:""}.fa-floppy-o:before,.fa-save:before{content:""}.fa-square:before{content:""}.fa-bars:before,.fa-navicon:before,.fa-reorder:before{content:""}.fa-list-ul:before{content:""}.fa-list-ol:before{content:""}.fa-strikethrough:before{content:""}.fa-underline:before{content:""}.fa-table:before{content:""}.fa-magic:before{content:""}.fa-truck:before{content:""}.fa-pinterest:before{content:""}.fa-pinterest-square:before{content:""}.fa-google-plus-square:before{content:""}.fa-google-plus:before{content:""}.fa-money:before{content:""}.fa-caret-down:before,.icon-caret-down:before,.wy-dropdown .caret:before{content:""}.fa-caret-up:before{content:""}.fa-caret-left:before{content:""}.fa-caret-right:before{content:""}.fa-columns:before{content:""}.fa-sort:before,.fa-unsorted:before{content:""}.fa-sort-desc:before,.fa-sort-down:before{content:""}.fa-sort-asc:before,.fa-sort-up:before{content:""}.fa-envelope:before{content:""}.fa-linkedin:before{content:""}.fa-rotate-left:before,.fa-undo:before{content:""}.fa-gavel:before,.fa-legal:before{content:""}.fa-dashboard:before,.fa-tachometer:before{content:""}.fa-comment-o:before{content:""}.fa-comments-o:before{content:""}.fa-bolt:before,.fa-flash:before{content:""}.fa-sitemap:before{content:""}.fa-umbrella:before{content:""}.fa-clipboard:before,.fa-paste:before{content:""}.fa-lightbulb-o:before{content:""}.fa-exchange:before{content:""}.fa-cloud-download:before{content:""}.fa-cloud-upload:before{content:""}.fa-user-md:before{content:""}.fa-stethoscope:before{content:""}.fa-suitcase:before{content:""}.fa-bell-o:before{content:""}.fa-coffee:before{content:""}.fa-cutlery:before{content:""}.fa-file-text-o:before{content:""}.fa-building-o:before{content:""}.fa-hospital-o:before{content:""}.fa-ambulance:before{content:""}.fa-medkit:before{content:""}.fa-fighter-jet:before{content:""}.fa-beer:before{content:""}.fa-h-square:before{content:""}.fa-plus-square:before{content:""}.fa-angle-double-left:before{content:""}.fa-angle-double-right:before{content:""}.fa-angle-double-up:before{content:""}.fa-angle-double-down:before{content:""}.fa-angle-left:before{content:""}.fa-angle-right:before{content:""}.fa-angle-up:before{content:""}.fa-angle-down:before{content:""}.fa-desktop:before{content:""}.fa-laptop:before{content:""}.fa-tablet:before{content:""}.fa-mobile-phone:before,.fa-mobile:before{content:""}.fa-circle-o:before{content:""}.fa-quote-left:before{content:""}.fa-quote-right:before{content:""}.fa-spinner:before{content:""}.fa-circle:before{content:""}.fa-mail-reply:before,.fa-reply:before{content:""}.fa-github-alt:before{content:""}.fa-folder-o:before{content:""}.fa-folder-open-o:before{content:""}.fa-smile-o:before{content:""}.fa-frown-o:before{content:""}.fa-meh-o:before{content:""}.fa-gamepad:before{content:""}.fa-keyboard-o:before{content:""}.fa-flag-o:before{content:""}.fa-flag-checkered:before{content:""}.fa-terminal:before{content:""}.fa-code:before{content:""}.fa-mail-reply-all:before,.fa-reply-all:before{content:""}.fa-star-half-empty:before,.fa-star-half-full:before,.fa-star-half-o:before{content:""}.fa-location-arrow:before{content:""}.fa-crop:before{content:""}.fa-code-fork:before{content:""}.fa-chain-broken:before,.fa-unlink:before{content:""}.fa-question:before{content:""}.fa-info:before{content:""}.fa-exclamation:before{content:""}.fa-superscript:before{content:""}.fa-subscript:before{content:""}.fa-eraser:before{content:""}.fa-puzzle-piece:before{content:""}.fa-microphone:before{content:""}.fa-microphone-slash:before{content:""}.fa-shield:before{content:""}.fa-calendar-o:before{content:""}.fa-fire-extinguisher:before{content:""}.fa-rocket:before{content:""}.fa-maxcdn:before{content:""}.fa-chevron-circle-left:before{content:""}.fa-chevron-circle-right:before{content:""}.fa-chevron-circle-up:before{content:""}.fa-chevron-circle-down:before{content:""}.fa-html5:before{content:""}.fa-css3:before{content:""}.fa-anchor:before{content:""}.fa-unlock-alt:before{content:""}.fa-bullseye:before{content:""}.fa-ellipsis-h:before{content:""}.fa-ellipsis-v:before{content:""}.fa-rss-square:before{content:""}.fa-play-circle:before{content:""}.fa-ticket:before{content:""}.fa-minus-square:before{content:""}.fa-minus-square-o:before,.wy-menu-vertical li.current>a button.toctree-expand:before,.wy-menu-vertical li.on a button.toctree-expand:before{content:""}.fa-level-up:before{content:""}.fa-level-down:before{content:""}.fa-check-square:before{content:""}.fa-pencil-square:before{content:""}.fa-external-link-square:before{content:""}.fa-share-square:before{content:""}.fa-compass:before{content:""}.fa-caret-square-o-down:before,.fa-toggle-down:before{content:""}.fa-caret-square-o-up:before,.fa-toggle-up:before{content:""}.fa-caret-square-o-right:before,.fa-toggle-right:before{content:""}.fa-eur:before,.fa-euro:before{content:""}.fa-gbp:before{content:""}.fa-dollar:before,.fa-usd:before{content:""}.fa-inr:before,.fa-rupee:before{content:""}.fa-cny:before,.fa-jpy:before,.fa-rmb:before,.fa-yen:before{content:""}.fa-rouble:before,.fa-rub:before,.fa-ruble:before{content:""}.fa-krw:before,.fa-won:before{content:""}.fa-bitcoin:before,.fa-btc:before{content:""}.fa-file:before{content:""}.fa-file-text:before{content:""}.fa-sort-alpha-asc:before{content:""}.fa-sort-alpha-desc:before{content:""}.fa-sort-amount-asc:before{content:""}.fa-sort-amount-desc:before{content:""}.fa-sort-numeric-asc:before{content:""}.fa-sort-numeric-desc:before{content:""}.fa-thumbs-up:before{content:""}.fa-thumbs-down:before{content:""}.fa-youtube-square:before{content:""}.fa-youtube:before{content:""}.fa-xing:before{content:""}.fa-xing-square:before{content:""}.fa-youtube-play:before{content:""}.fa-dropbox:before{content:""}.fa-stack-overflow:before{content:""}.fa-instagram:before{content:""}.fa-flickr:before{content:""}.fa-adn:before{content:""}.fa-bitbucket:before,.icon-bitbucket:before{content:""}.fa-bitbucket-square:before{content:""}.fa-tumblr:before{content:""}.fa-tumblr-square:before{content:""}.fa-long-arrow-down:before{content:""}.fa-long-arrow-up:before{content:""}.fa-long-arrow-left:before{content:""}.fa-long-arrow-right:before{content:""}.fa-apple:before{content:""}.fa-windows:before{content:""}.fa-android:before{content:""}.fa-linux:before{content:""}.fa-dribbble:before{content:""}.fa-skype:before{content:""}.fa-foursquare:before{content:""}.fa-trello:before{content:""}.fa-female:before{content:""}.fa-male:before{content:""}.fa-gittip:before,.fa-gratipay:before{content:""}.fa-sun-o:before{content:""}.fa-moon-o:before{content:""}.fa-archive:before{content:""}.fa-bug:before{content:""}.fa-vk:before{content:""}.fa-weibo:before{content:""}.fa-renren:before{content:""}.fa-pagelines:before{content:""}.fa-stack-exchange:before{content:""}.fa-arrow-circle-o-right:before{content:""}.fa-arrow-circle-o-left:before{content:""}.fa-caret-square-o-left:before,.fa-toggle-left:before{content:""}.fa-dot-circle-o:before{content:""}.fa-wheelchair:before{content:""}.fa-vimeo-square:before{content:""}.fa-try:before,.fa-turkish-lira:before{content:""}.fa-plus-square-o:before,.wy-menu-vertical li button.toctree-expand:before{content:""}.fa-space-shuttle:before{content:""}.fa-slack:before{content:""}.fa-envelope-square:before{content:""}.fa-wordpress:before{content:""}.fa-openid:before{content:""}.fa-bank:before,.fa-institution:before,.fa-university:before{content:""}.fa-graduation-cap:before,.fa-mortar-board:before{content:""}.fa-yahoo:before{content:""}.fa-google:before{content:""}.fa-reddit:before{content:""}.fa-reddit-square:before{content:""}.fa-stumbleupon-circle:before{content:""}.fa-stumbleupon:before{content:""}.fa-delicious:before{content:""}.fa-digg:before{content:""}.fa-pied-piper-pp:before{content:""}.fa-pied-piper-alt:before{content:""}.fa-drupal:before{content:""}.fa-joomla:before{content:""}.fa-language:before{content:""}.fa-fax:before{content:""}.fa-building:before{content:""}.fa-child:before{content:""}.fa-paw:before{content:""}.fa-spoon:before{content:""}.fa-cube:before{content:""}.fa-cubes:before{content:""}.fa-behance:before{content:""}.fa-behance-square:before{content:""}.fa-steam:before{content:""}.fa-steam-square:before{content:""}.fa-recycle:before{content:""}.fa-automobile:before,.fa-car:before{content:""}.fa-cab:before,.fa-taxi:before{content:""}.fa-tree:before{content:""}.fa-spotify:before{content:""}.fa-deviantart:before{content:""}.fa-soundcloud:before{content:""}.fa-database:before{content:""}.fa-file-pdf-o:before{content:""}.fa-file-word-o:before{content:""}.fa-file-excel-o:before{content:""}.fa-file-powerpoint-o:before{content:""}.fa-file-image-o:before,.fa-file-photo-o:before,.fa-file-picture-o:before{content:""}.fa-file-archive-o:before,.fa-file-zip-o:before{content:""}.fa-file-audio-o:before,.fa-file-sound-o:before{content:""}.fa-file-movie-o:before,.fa-file-video-o:before{content:""}.fa-file-code-o:before{content:""}.fa-vine:before{content:""}.fa-codepen:before{content:""}.fa-jsfiddle:before{content:""}.fa-life-bouy:before,.fa-life-buoy:before,.fa-life-ring:before,.fa-life-saver:before,.fa-support:before{content:""}.fa-circle-o-notch:before{content:""}.fa-ra:before,.fa-rebel:before,.fa-resistance:before{content:""}.fa-empire:before,.fa-ge:before{content:""}.fa-git-square:before{content:""}.fa-git:before{content:""}.fa-hacker-news:before,.fa-y-combinator-square:before,.fa-yc-square:before{content:""}.fa-tencent-weibo:before{content:""}.fa-qq:before{content:""}.fa-wechat:before,.fa-weixin:before{content:""}.fa-paper-plane:before,.fa-send:before{content:""}.fa-paper-plane-o:before,.fa-send-o:before{content:""}.fa-history:before{content:""}.fa-circle-thin:before{content:""}.fa-header:before{content:""}.fa-paragraph:before{content:""}.fa-sliders:before{content:""}.fa-share-alt:before{content:""}.fa-share-alt-square:before{content:""}.fa-bomb:before{content:""}.fa-futbol-o:before,.fa-soccer-ball-o:before{content:""}.fa-tty:before{content:""}.fa-binoculars:before{content:""}.fa-plug:before{content:""}.fa-slideshare:before{content:""}.fa-twitch:before{content:""}.fa-yelp:before{content:""}.fa-newspaper-o:before{content:""}.fa-wifi:before{content:""}.fa-calculator:before{content:""}.fa-paypal:before{content:""}.fa-google-wallet:before{content:""}.fa-cc-visa:before{content:""}.fa-cc-mastercard:before{content:""}.fa-cc-discover:before{content:""}.fa-cc-amex:before{content:""}.fa-cc-paypal:before{content:""}.fa-cc-stripe:before{content:""}.fa-bell-slash:before{content:""}.fa-bell-slash-o:before{content:""}.fa-trash:before{content:""}.fa-copyright:before{content:""}.fa-at:before{content:""}.fa-eyedropper:before{content:""}.fa-paint-brush:before{content:""}.fa-birthday-cake:before{content:""}.fa-area-chart:before{content:""}.fa-pie-chart:before{content:""}.fa-line-chart:before{content:""}.fa-lastfm:before{content:""}.fa-lastfm-square:before{content:""}.fa-toggle-off:before{content:""}.fa-toggle-on:before{content:""}.fa-bicycle:before{content:""}.fa-bus:before{content:""}.fa-ioxhost:before{content:""}.fa-angellist:before{content:""}.fa-cc:before{content:""}.fa-ils:before,.fa-shekel:before,.fa-sheqel:before{content:""}.fa-meanpath:before{content:""}.fa-buysellads:before{content:""}.fa-connectdevelop:before{content:""}.fa-dashcube:before{content:""}.fa-forumbee:before{content:""}.fa-leanpub:before{content:""}.fa-sellsy:before{content:""}.fa-shirtsinbulk:before{content:""}.fa-simplybuilt:before{content:""}.fa-skyatlas:before{content:""}.fa-cart-plus:before{content:""}.fa-cart-arrow-down:before{content:""}.fa-diamond:before{content:""}.fa-ship:before{content:""}.fa-user-secret:before{content:""}.fa-motorcycle:before{content:""}.fa-street-view:before{content:""}.fa-heartbeat:before{content:""}.fa-venus:before{content:""}.fa-mars:before{content:""}.fa-mercury:before{content:""}.fa-intersex:before,.fa-transgender:before{content:""}.fa-transgender-alt:before{content:""}.fa-venus-double:before{content:""}.fa-mars-double:before{content:""}.fa-venus-mars:before{content:""}.fa-mars-stroke:before{content:""}.fa-mars-stroke-v:before{content:""}.fa-mars-stroke-h:before{content:""}.fa-neuter:before{content:""}.fa-genderless:before{content:""}.fa-facebook-official:before{content:""}.fa-pinterest-p:before{content:""}.fa-whatsapp:before{content:""}.fa-server:before{content:""}.fa-user-plus:before{content:""}.fa-user-times:before{content:""}.fa-bed:before,.fa-hotel:before{content:""}.fa-viacoin:before{content:""}.fa-train:before{content:""}.fa-subway:before{content:""}.fa-medium:before{content:""}.fa-y-combinator:before,.fa-yc:before{content:""}.fa-optin-monster:before{content:""}.fa-opencart:before{content:""}.fa-expeditedssl:before{content:""}.fa-battery-4:before,.fa-battery-full:before,.fa-battery:before{content:""}.fa-battery-3:before,.fa-battery-three-quarters:before{content:""}.fa-battery-2:before,.fa-battery-half:before{content:""}.fa-battery-1:before,.fa-battery-quarter:before{content:""}.fa-battery-0:before,.fa-battery-empty:before{content:""}.fa-mouse-pointer:before{content:""}.fa-i-cursor:before{content:""}.fa-object-group:before{content:""}.fa-object-ungroup:before{content:""}.fa-sticky-note:before{content:""}.fa-sticky-note-o:before{content:""}.fa-cc-jcb:before{content:""}.fa-cc-diners-club:before{content:""}.fa-clone:before{content:""}.fa-balance-scale:before{content:""}.fa-hourglass-o:before{content:""}.fa-hourglass-1:before,.fa-hourglass-start:before{content:""}.fa-hourglass-2:before,.fa-hourglass-half:before{content:""}.fa-hourglass-3:before,.fa-hourglass-end:before{content:""}.fa-hourglass:before{content:""}.fa-hand-grab-o:before,.fa-hand-rock-o:before{content:""}.fa-hand-paper-o:before,.fa-hand-stop-o:before{content:""}.fa-hand-scissors-o:before{content:""}.fa-hand-lizard-o:before{content:""}.fa-hand-spock-o:before{content:""}.fa-hand-pointer-o:before{content:""}.fa-hand-peace-o:before{content:""}.fa-trademark:before{content:""}.fa-registered:before{content:""}.fa-creative-commons:before{content:""}.fa-gg:before{content:""}.fa-gg-circle:before{content:""}.fa-tripadvisor:before{content:""}.fa-odnoklassniki:before{content:""}.fa-odnoklassniki-square:before{content:""}.fa-get-pocket:before{content:""}.fa-wikipedia-w:before{content:""}.fa-safari:before{content:""}.fa-chrome:before{content:""}.fa-firefox:before{content:""}.fa-opera:before{content:""}.fa-internet-explorer:before{content:""}.fa-television:before,.fa-tv:before{content:""}.fa-contao:before{content:""}.fa-500px:before{content:""}.fa-amazon:before{content:""}.fa-calendar-plus-o:before{content:""}.fa-calendar-minus-o:before{content:""}.fa-calendar-times-o:before{content:""}.fa-calendar-check-o:before{content:""}.fa-industry:before{content:""}.fa-map-pin:before{content:""}.fa-map-signs:before{content:""}.fa-map-o:before{content:""}.fa-map:before{content:""}.fa-commenting:before{content:""}.fa-commenting-o:before{content:""}.fa-houzz:before{content:""}.fa-vimeo:before{content:""}.fa-black-tie:before{content:""}.fa-fonticons:before{content:""}.fa-reddit-alien:before{content:""}.fa-edge:before{content:""}.fa-credit-card-alt:before{content:""}.fa-codiepie:before{content:""}.fa-modx:before{content:""}.fa-fort-awesome:before{content:""}.fa-usb:before{content:""}.fa-product-hunt:before{content:""}.fa-mixcloud:before{content:""}.fa-scribd:before{content:""}.fa-pause-circle:before{content:""}.fa-pause-circle-o:before{content:""}.fa-stop-circle:before{content:""}.fa-stop-circle-o:before{content:""}.fa-shopping-bag:before{content:""}.fa-shopping-basket:before{content:""}.fa-hashtag:before{content:""}.fa-bluetooth:before{content:""}.fa-bluetooth-b:before{content:""}.fa-percent:before{content:""}.fa-gitlab:before,.icon-gitlab:before{content:""}.fa-wpbeginner:before{content:""}.fa-wpforms:before{content:""}.fa-envira:before{content:""}.fa-universal-access:before{content:""}.fa-wheelchair-alt:before{content:""}.fa-question-circle-o:before{content:""}.fa-blind:before{content:""}.fa-audio-description:before{content:""}.fa-volume-control-phone:before{content:""}.fa-braille:before{content:""}.fa-assistive-listening-systems:before{content:""}.fa-american-sign-language-interpreting:before,.fa-asl-interpreting:before{content:""}.fa-deaf:before,.fa-deafness:before,.fa-hard-of-hearing:before{content:""}.fa-glide:before{content:""}.fa-glide-g:before{content:""}.fa-sign-language:before,.fa-signing:before{content:""}.fa-low-vision:before{content:""}.fa-viadeo:before{content:""}.fa-viadeo-square:before{content:""}.fa-snapchat:before{content:""}.fa-snapchat-ghost:before{content:""}.fa-snapchat-square:before{content:""}.fa-pied-piper:before{content:""}.fa-first-order:before{content:""}.fa-yoast:before{content:""}.fa-themeisle:before{content:""}.fa-google-plus-circle:before,.fa-google-plus-official:before{content:""}.fa-fa:before,.fa-font-awesome:before{content:""}.fa-handshake-o:before{content:""}.fa-envelope-open:before{content:""}.fa-envelope-open-o:before{content:""}.fa-linode:before{content:""}.fa-address-book:before{content:""}.fa-address-book-o:before{content:""}.fa-address-card:before,.fa-vcard:before{content:""}.fa-address-card-o:before,.fa-vcard-o:before{content:""}.fa-user-circle:before{content:""}.fa-user-circle-o:before{content:""}.fa-user-o:before{content:""}.fa-id-badge:before{content:""}.fa-drivers-license:before,.fa-id-card:before{content:""}.fa-drivers-license-o:before,.fa-id-card-o:before{content:""}.fa-quora:before{content:""}.fa-free-code-camp:before{content:""}.fa-telegram:before{content:""}.fa-thermometer-4:before,.fa-thermometer-full:before,.fa-thermometer:before{content:""}.fa-thermometer-3:before,.fa-thermometer-three-quarters:before{content:""}.fa-thermometer-2:before,.fa-thermometer-half:before{content:""}.fa-thermometer-1:before,.fa-thermometer-quarter:before{content:""}.fa-thermometer-0:before,.fa-thermometer-empty:before{content:""}.fa-shower:before{content:""}.fa-bath:before,.fa-bathtub:before,.fa-s15:before{content:""}.fa-podcast:before{content:""}.fa-window-maximize:before{content:""}.fa-window-minimize:before{content:""}.fa-window-restore:before{content:""}.fa-times-rectangle:before,.fa-window-close:before{content:""}.fa-times-rectangle-o:before,.fa-window-close-o:before{content:""}.fa-bandcamp:before{content:""}.fa-grav:before{content:""}.fa-etsy:before{content:""}.fa-imdb:before{content:""}.fa-ravelry:before{content:""}.fa-eercast:before{content:""}.fa-microchip:before{content:""}.fa-snowflake-o:before{content:""}.fa-superpowers:before{content:""}.fa-wpexplorer:before{content:""}.fa-meetup:before{content:""}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}.fa,.icon,.rst-content .admonition-title,.rst-content .code-block-caption .headerlink,.rst-content .eqno .headerlink,.rst-content code.download span:first-child,.rst-content dl dt .headerlink,.rst-content h1 .headerlink,.rst-content h2 .headerlink,.rst-content h3 .headerlink,.rst-content h4 .headerlink,.rst-content h5 .headerlink,.rst-content h6 .headerlink,.rst-content p.caption .headerlink,.rst-content p .headerlink,.rst-content table>caption .headerlink,.rst-content tt.download span:first-child,.wy-dropdown .caret,.wy-inline-validate.wy-inline-validate-danger .wy-input-context,.wy-inline-validate.wy-inline-validate-info .wy-input-context,.wy-inline-validate.wy-inline-validate-success .wy-input-context,.wy-inline-validate.wy-inline-validate-warning .wy-input-context,.wy-menu-vertical li.current>a button.toctree-expand,.wy-menu-vertical li.on a button.toctree-expand,.wy-menu-vertical li button.toctree-expand{font-family:inherit}.fa:before,.icon:before,.rst-content .admonition-title:before,.rst-content .code-block-caption .headerlink:before,.rst-content .eqno .headerlink:before,.rst-content code.download span:first-child:before,.rst-content dl dt .headerlink:before,.rst-content h1 .headerlink:before,.rst-content h2 .headerlink:before,.rst-content h3 .headerlink:before,.rst-content h4 .headerlink:before,.rst-content h5 .headerlink:before,.rst-content h6 .headerlink:before,.rst-content p.caption .headerlink:before,.rst-content p .headerlink:before,.rst-content table>caption .headerlink:before,.rst-content tt.download span:first-child:before,.wy-dropdown .caret:before,.wy-inline-validate.wy-inline-validate-danger .wy-input-context:before,.wy-inline-validate.wy-inline-validate-info .wy-input-context:before,.wy-inline-validate.wy-inline-validate-success .wy-input-context:before,.wy-inline-validate.wy-inline-validate-warning .wy-input-context:before,.wy-menu-vertical li.current>a button.toctree-expand:before,.wy-menu-vertical li.on a button.toctree-expand:before,.wy-menu-vertical li button.toctree-expand:before{font-family:FontAwesome;display:inline-block;font-style:normal;font-weight:400;line-height:1;text-decoration:inherit}.rst-content .code-block-caption a .headerlink,.rst-content .eqno a .headerlink,.rst-content a .admonition-title,.rst-content code.download a span:first-child,.rst-content dl dt a .headerlink,.rst-content h1 a .headerlink,.rst-content h2 a .headerlink,.rst-content h3 a .headerlink,.rst-content h4 a .headerlink,.rst-content h5 a .headerlink,.rst-content h6 a .headerlink,.rst-content p.caption a .headerlink,.rst-content p a .headerlink,.rst-content table>caption a .headerlink,.rst-content tt.download a span:first-child,.wy-menu-vertical li.current>a button.toctree-expand,.wy-menu-vertical li.on a button.toctree-expand,.wy-menu-vertical li a button.toctree-expand,a .fa,a .icon,a .rst-content .admonition-title,a .rst-content .code-block-caption .headerlink,a .rst-content .eqno .headerlink,a .rst-content code.download span:first-child,a .rst-content dl dt .headerlink,a .rst-content h1 .headerlink,a .rst-content h2 .headerlink,a .rst-content h3 .headerlink,a .rst-content h4 .headerlink,a .rst-content h5 .headerlink,a .rst-content h6 .headerlink,a .rst-content p.caption .headerlink,a .rst-content p .headerlink,a .rst-content table>caption .headerlink,a .rst-content tt.download span:first-child,a .wy-menu-vertical li button.toctree-expand{display:inline-block;text-decoration:inherit}.btn .fa,.btn .icon,.btn .rst-content .admonition-title,.btn .rst-content .code-block-caption .headerlink,.btn .rst-content .eqno .headerlink,.btn .rst-content code.download span:first-child,.btn .rst-content dl dt .headerlink,.btn .rst-content h1 .headerlink,.btn .rst-content h2 .headerlink,.btn .rst-content h3 .headerlink,.btn .rst-content h4 .headerlink,.btn .rst-content h5 .headerlink,.btn .rst-content h6 .headerlink,.btn .rst-content p .headerlink,.btn .rst-content table>caption .headerlink,.btn .rst-content tt.download span:first-child,.btn .wy-menu-vertical li.current>a button.toctree-expand,.btn .wy-menu-vertical li.on a button.toctree-expand,.btn .wy-menu-vertical li button.toctree-expand,.nav .fa,.nav .icon,.nav .rst-content .admonition-title,.nav .rst-content .code-block-caption .headerlink,.nav .rst-content .eqno .headerlink,.nav .rst-content code.download span:first-child,.nav .rst-content dl dt .headerlink,.nav .rst-content h1 .headerlink,.nav .rst-content h2 .headerlink,.nav .rst-content h3 .headerlink,.nav .rst-content h4 .headerlink,.nav .rst-content h5 .headerlink,.nav .rst-content h6 .headerlink,.nav .rst-content p .headerlink,.nav .rst-content table>caption .headerlink,.nav .rst-content tt.download span:first-child,.nav .wy-menu-vertical li.current>a button.toctree-expand,.nav .wy-menu-vertical li.on a button.toctree-expand,.nav .wy-menu-vertical li button.toctree-expand,.rst-content .btn .admonition-title,.rst-content .code-block-caption .btn .headerlink,.rst-content .code-block-caption .nav .headerlink,.rst-content .eqno .btn .headerlink,.rst-content .eqno .nav .headerlink,.rst-content .nav .admonition-title,.rst-content code.download .btn span:first-child,.rst-content code.download .nav span:first-child,.rst-content dl dt .btn .headerlink,.rst-content dl dt .nav .headerlink,.rst-content h1 .btn .headerlink,.rst-content h1 .nav .headerlink,.rst-content h2 .btn .headerlink,.rst-content h2 .nav .headerlink,.rst-content h3 .btn .headerlink,.rst-content h3 .nav .headerlink,.rst-content h4 .btn .headerlink,.rst-content h4 .nav .headerlink,.rst-content h5 .btn .headerlink,.rst-content h5 .nav .headerlink,.rst-content h6 .btn .headerlink,.rst-content h6 .nav .headerlink,.rst-content p .btn .headerlink,.rst-content p .nav .headerlink,.rst-content table>caption .btn .headerlink,.rst-content table>caption .nav .headerlink,.rst-content tt.download .btn span:first-child,.rst-content tt.download .nav span:first-child,.wy-menu-vertical li .btn button.toctree-expand,.wy-menu-vertical li.current>a .btn button.toctree-expand,.wy-menu-vertical li.current>a .nav button.toctree-expand,.wy-menu-vertical li .nav button.toctree-expand,.wy-menu-vertical li.on a .btn button.toctree-expand,.wy-menu-vertical li.on a .nav button.toctree-expand{display:inline}.btn .fa-large.icon,.btn .fa.fa-large,.btn .rst-content .code-block-caption .fa-large.headerlink,.btn .rst-content .eqno .fa-large.headerlink,.btn .rst-content .fa-large.admonition-title,.btn .rst-content code.download span.fa-large:first-child,.btn .rst-content dl dt .fa-large.headerlink,.btn .rst-content h1 .fa-large.headerlink,.btn .rst-content h2 .fa-large.headerlink,.btn .rst-content h3 .fa-large.headerlink,.btn .rst-content h4 .fa-large.headerlink,.btn .rst-content h5 .fa-large.headerlink,.btn .rst-content h6 .fa-large.headerlink,.btn .rst-content p .fa-large.headerlink,.btn .rst-content table>caption .fa-large.headerlink,.btn .rst-content tt.download span.fa-large:first-child,.btn .wy-menu-vertical li button.fa-large.toctree-expand,.nav .fa-large.icon,.nav .fa.fa-large,.nav .rst-content .code-block-caption .fa-large.headerlink,.nav .rst-content .eqno .fa-large.headerlink,.nav .rst-content .fa-large.admonition-title,.nav .rst-content code.download span.fa-large:first-child,.nav .rst-content dl dt .fa-large.headerlink,.nav .rst-content h1 .fa-large.headerlink,.nav .rst-content h2 .fa-large.headerlink,.nav .rst-content h3 .fa-large.headerlink,.nav .rst-content h4 .fa-large.headerlink,.nav .rst-content h5 .fa-large.headerlink,.nav .rst-content h6 .fa-large.headerlink,.nav .rst-content p .fa-large.headerlink,.nav .rst-content table>caption .fa-large.headerlink,.nav .rst-content tt.download span.fa-large:first-child,.nav .wy-menu-vertical li button.fa-large.toctree-expand,.rst-content .btn .fa-large.admonition-title,.rst-content .code-block-caption .btn .fa-large.headerlink,.rst-content .code-block-caption .nav .fa-large.headerlink,.rst-content .eqno .btn .fa-large.headerlink,.rst-content .eqno .nav .fa-large.headerlink,.rst-content .nav .fa-large.admonition-title,.rst-content code.download .btn span.fa-large:first-child,.rst-content code.download .nav span.fa-large:first-child,.rst-content dl dt .btn .fa-large.headerlink,.rst-content dl dt .nav .fa-large.headerlink,.rst-content h1 .btn .fa-large.headerlink,.rst-content h1 .nav .fa-large.headerlink,.rst-content h2 .btn .fa-large.headerlink,.rst-content h2 .nav .fa-large.headerlink,.rst-content h3 .btn .fa-large.headerlink,.rst-content h3 .nav .fa-large.headerlink,.rst-content h4 .btn .fa-large.headerlink,.rst-content h4 .nav .fa-large.headerlink,.rst-content h5 .btn .fa-large.headerlink,.rst-content h5 .nav .fa-large.headerlink,.rst-content h6 .btn .fa-large.headerlink,.rst-content h6 .nav .fa-large.headerlink,.rst-content p .btn .fa-large.headerlink,.rst-content p .nav .fa-large.headerlink,.rst-content table>caption .btn .fa-large.headerlink,.rst-content table>caption .nav .fa-large.headerlink,.rst-content tt.download .btn span.fa-large:first-child,.rst-content tt.download .nav span.fa-large:first-child,.wy-menu-vertical li .btn button.fa-large.toctree-expand,.wy-menu-vertical li .nav button.fa-large.toctree-expand{line-height:.9em}.btn .fa-spin.icon,.btn .fa.fa-spin,.btn .rst-content .code-block-caption .fa-spin.headerlink,.btn .rst-content .eqno .fa-spin.headerlink,.btn .rst-content .fa-spin.admonition-title,.btn .rst-content code.download span.fa-spin:first-child,.btn .rst-content dl dt .fa-spin.headerlink,.btn .rst-content h1 .fa-spin.headerlink,.btn .rst-content h2 .fa-spin.headerlink,.btn .rst-content h3 .fa-spin.headerlink,.btn .rst-content h4 .fa-spin.headerlink,.btn .rst-content h5 .fa-spin.headerlink,.btn .rst-content h6 .fa-spin.headerlink,.btn .rst-content p .fa-spin.headerlink,.btn .rst-content table>caption .fa-spin.headerlink,.btn .rst-content tt.download span.fa-spin:first-child,.btn .wy-menu-vertical li button.fa-spin.toctree-expand,.nav .fa-spin.icon,.nav .fa.fa-spin,.nav .rst-content .code-block-caption .fa-spin.headerlink,.nav .rst-content .eqno .fa-spin.headerlink,.nav .rst-content .fa-spin.admonition-title,.nav .rst-content code.download span.fa-spin:first-child,.nav .rst-content dl dt .fa-spin.headerlink,.nav .rst-content h1 .fa-spin.headerlink,.nav .rst-content h2 .fa-spin.headerlink,.nav .rst-content h3 .fa-spin.headerlink,.nav .rst-content h4 .fa-spin.headerlink,.nav .rst-content h5 .fa-spin.headerlink,.nav .rst-content h6 .fa-spin.headerlink,.nav .rst-content p .fa-spin.headerlink,.nav .rst-content table>caption .fa-spin.headerlink,.nav .rst-content tt.download span.fa-spin:first-child,.nav .wy-menu-vertical li button.fa-spin.toctree-expand,.rst-content .btn .fa-spin.admonition-title,.rst-content .code-block-caption .btn .fa-spin.headerlink,.rst-content .code-block-caption .nav .fa-spin.headerlink,.rst-content .eqno .btn .fa-spin.headerlink,.rst-content .eqno .nav .fa-spin.headerlink,.rst-content .nav .fa-spin.admonition-title,.rst-content code.download .btn span.fa-spin:first-child,.rst-content code.download .nav span.fa-spin:first-child,.rst-content dl dt .btn .fa-spin.headerlink,.rst-content dl dt .nav .fa-spin.headerlink,.rst-content h1 .btn .fa-spin.headerlink,.rst-content h1 .nav .fa-spin.headerlink,.rst-content h2 .btn .fa-spin.headerlink,.rst-content h2 .nav .fa-spin.headerlink,.rst-content h3 .btn .fa-spin.headerlink,.rst-content h3 .nav .fa-spin.headerlink,.rst-content h4 .btn .fa-spin.headerlink,.rst-content h4 .nav .fa-spin.headerlink,.rst-content h5 .btn .fa-spin.headerlink,.rst-content h5 .nav .fa-spin.headerlink,.rst-content h6 .btn .fa-spin.headerlink,.rst-content h6 .nav .fa-spin.headerlink,.rst-content p .btn .fa-spin.headerlink,.rst-content p .nav .fa-spin.headerlink,.rst-content table>caption .btn .fa-spin.headerlink,.rst-content table>caption .nav .fa-spin.headerlink,.rst-content tt.download .btn span.fa-spin:first-child,.rst-content tt.download .nav span.fa-spin:first-child,.wy-menu-vertical li .btn button.fa-spin.toctree-expand,.wy-menu-vertical li .nav button.fa-spin.toctree-expand{display:inline-block}.btn.fa:before,.btn.icon:before,.rst-content .btn.admonition-title:before,.rst-content .code-block-caption .btn.headerlink:before,.rst-content .eqno .btn.headerlink:before,.rst-content code.download span.btn:first-child:before,.rst-content dl dt .btn.headerlink:before,.rst-content h1 .btn.headerlink:before,.rst-content h2 .btn.headerlink:before,.rst-content h3 .btn.headerlink:before,.rst-content h4 .btn.headerlink:before,.rst-content h5 .btn.headerlink:before,.rst-content h6 .btn.headerlink:before,.rst-content p .btn.headerlink:before,.rst-content table>caption .btn.headerlink:before,.rst-content tt.download span.btn:first-child:before,.wy-menu-vertical li button.btn.toctree-expand:before{opacity:.5;-webkit-transition:opacity .05s ease-in;-moz-transition:opacity .05s ease-in;transition:opacity .05s ease-in}.btn.fa:hover:before,.btn.icon:hover:before,.rst-content .btn.admonition-title:hover:before,.rst-content .code-block-caption .btn.headerlink:hover:before,.rst-content .eqno .btn.headerlink:hover:before,.rst-content code.download span.btn:first-child:hover:before,.rst-content dl dt .btn.headerlink:hover:before,.rst-content h1 .btn.headerlink:hover:before,.rst-content h2 .btn.headerlink:hover:before,.rst-content h3 .btn.headerlink:hover:before,.rst-content h4 .btn.headerlink:hover:before,.rst-content h5 .btn.headerlink:hover:before,.rst-content h6 .btn.headerlink:hover:before,.rst-content p .btn.headerlink:hover:before,.rst-content table>caption .btn.headerlink:hover:before,.rst-content tt.download span.btn:first-child:hover:before,.wy-menu-vertical li button.btn.toctree-expand:hover:before{opacity:1}.btn-mini .fa:before,.btn-mini .icon:before,.btn-mini .rst-content .admonition-title:before,.btn-mini .rst-content .code-block-caption .headerlink:before,.btn-mini .rst-content .eqno .headerlink:before,.btn-mini .rst-content code.download span:first-child:before,.btn-mini .rst-content dl dt .headerlink:before,.btn-mini .rst-content h1 .headerlink:before,.btn-mini .rst-content h2 .headerlink:before,.btn-mini .rst-content h3 .headerlink:before,.btn-mini .rst-content h4 .headerlink:before,.btn-mini .rst-content h5 .headerlink:before,.btn-mini .rst-content h6 .headerlink:before,.btn-mini .rst-content p .headerlink:before,.btn-mini .rst-content table>caption .headerlink:before,.btn-mini .rst-content tt.download span:first-child:before,.btn-mini .wy-menu-vertical li button.toctree-expand:before,.rst-content .btn-mini .admonition-title:before,.rst-content .code-block-caption .btn-mini .headerlink:before,.rst-content .eqno .btn-mini .headerlink:before,.rst-content code.download .btn-mini span:first-child:before,.rst-content dl dt .btn-mini .headerlink:before,.rst-content h1 .btn-mini .headerlink:before,.rst-content h2 .btn-mini .headerlink:before,.rst-content h3 .btn-mini .headerlink:before,.rst-content h4 .btn-mini .headerlink:before,.rst-content h5 .btn-mini .headerlink:before,.rst-content h6 .btn-mini .headerlink:before,.rst-content p .btn-mini .headerlink:before,.rst-content table>caption .btn-mini .headerlink:before,.rst-content tt.download .btn-mini span:first-child:before,.wy-menu-vertical li .btn-mini button.toctree-expand:before{font-size:14px;vertical-align:-15%}.rst-content .admonition,.rst-content .admonition-todo,.rst-content .attention,.rst-content .caution,.rst-content .danger,.rst-content .error,.rst-content .hint,.rst-content .important,.rst-content .note,.rst-content .seealso,.rst-content .tip,.rst-content .warning,.wy-alert{padding:12px;line-height:24px;margin-bottom:24px;background:#e7f2fa}.rst-content .admonition-title,.wy-alert-title{font-weight:700;display:block;color:#fff;background:#6ab0de;padding:6px 12px;margin:-12px -12px 12px}.rst-content .danger,.rst-content .error,.rst-content .wy-alert-danger.admonition,.rst-content .wy-alert-danger.admonition-todo,.rst-content .wy-alert-danger.attention,.rst-content .wy-alert-danger.caution,.rst-content .wy-alert-danger.hint,.rst-content .wy-alert-danger.important,.rst-content .wy-alert-danger.note,.rst-content .wy-alert-danger.seealso,.rst-content .wy-alert-danger.tip,.rst-content .wy-alert-danger.warning,.wy-alert.wy-alert-danger{background:#fdf3f2}.rst-content .danger .admonition-title,.rst-content .danger .wy-alert-title,.rst-content .error .admonition-title,.rst-content .error .wy-alert-title,.rst-content .wy-alert-danger.admonition-todo .admonition-title,.rst-content .wy-alert-danger.admonition-todo .wy-alert-title,.rst-content .wy-alert-danger.admonition .admonition-title,.rst-content .wy-alert-danger.admonition .wy-alert-title,.rst-content .wy-alert-danger.attention .admonition-title,.rst-content .wy-alert-danger.attention .wy-alert-title,.rst-content .wy-alert-danger.caution .admonition-title,.rst-content .wy-alert-danger.caution .wy-alert-title,.rst-content .wy-alert-danger.hint .admonition-title,.rst-content .wy-alert-danger.hint .wy-alert-title,.rst-content .wy-alert-danger.important .admonition-title,.rst-content .wy-alert-danger.important .wy-alert-title,.rst-content .wy-alert-danger.note .admonition-title,.rst-content .wy-alert-danger.note .wy-alert-title,.rst-content .wy-alert-danger.seealso .admonition-title,.rst-content .wy-alert-danger.seealso .wy-alert-title,.rst-content .wy-alert-danger.tip .admonition-title,.rst-content .wy-alert-danger.tip .wy-alert-title,.rst-content .wy-alert-danger.warning .admonition-title,.rst-content .wy-alert-danger.warning .wy-alert-title,.rst-content .wy-alert.wy-alert-danger .admonition-title,.wy-alert.wy-alert-danger .rst-content .admonition-title,.wy-alert.wy-alert-danger .wy-alert-title{background:#f29f97}.rst-content .admonition-todo,.rst-content .attention,.rst-content .caution,.rst-content .warning,.rst-content .wy-alert-warning.admonition,.rst-content .wy-alert-warning.danger,.rst-content .wy-alert-warning.error,.rst-content .wy-alert-warning.hint,.rst-content .wy-alert-warning.important,.rst-content .wy-alert-warning.note,.rst-content .wy-alert-warning.seealso,.rst-content .wy-alert-warning.tip,.wy-alert.wy-alert-warning{background:#ffedcc}.rst-content .admonition-todo .admonition-title,.rst-content .admonition-todo .wy-alert-title,.rst-content .attention .admonition-title,.rst-content .attention .wy-alert-title,.rst-content .caution .admonition-title,.rst-content .caution .wy-alert-title,.rst-content .warning .admonition-title,.rst-content .warning .wy-alert-title,.rst-content .wy-alert-warning.admonition .admonition-title,.rst-content .wy-alert-warning.admonition .wy-alert-title,.rst-content .wy-alert-warning.danger .admonition-title,.rst-content .wy-alert-warning.danger .wy-alert-title,.rst-content .wy-alert-warning.error .admonition-title,.rst-content .wy-alert-warning.error .wy-alert-title,.rst-content .wy-alert-warning.hint .admonition-title,.rst-content .wy-alert-warning.hint .wy-alert-title,.rst-content .wy-alert-warning.important .admonition-title,.rst-content .wy-alert-warning.important .wy-alert-title,.rst-content .wy-alert-warning.note .admonition-title,.rst-content .wy-alert-warning.note .wy-alert-title,.rst-content .wy-alert-warning.seealso .admonition-title,.rst-content .wy-alert-warning.seealso .wy-alert-title,.rst-content .wy-alert-warning.tip .admonition-title,.rst-content .wy-alert-warning.tip .wy-alert-title,.rst-content .wy-alert.wy-alert-warning .admonition-title,.wy-alert.wy-alert-warning .rst-content .admonition-title,.wy-alert.wy-alert-warning .wy-alert-title{background:#f0b37e}.rst-content .note,.rst-content .seealso,.rst-content .wy-alert-info.admonition,.rst-content .wy-alert-info.admonition-todo,.rst-content .wy-alert-info.attention,.rst-content .wy-alert-info.caution,.rst-content .wy-alert-info.danger,.rst-content .wy-alert-info.error,.rst-content .wy-alert-info.hint,.rst-content .wy-alert-info.important,.rst-content .wy-alert-info.tip,.rst-content .wy-alert-info.warning,.wy-alert.wy-alert-info{background:#e7f2fa}.rst-content .note .admonition-title,.rst-content .note .wy-alert-title,.rst-content .seealso .admonition-title,.rst-content .seealso .wy-alert-title,.rst-content .wy-alert-info.admonition-todo .admonition-title,.rst-content .wy-alert-info.admonition-todo .wy-alert-title,.rst-content .wy-alert-info.admonition .admonition-title,.rst-content .wy-alert-info.admonition .wy-alert-title,.rst-content .wy-alert-info.attention .admonition-title,.rst-content .wy-alert-info.attention .wy-alert-title,.rst-content .wy-alert-info.caution .admonition-title,.rst-content .wy-alert-info.caution .wy-alert-title,.rst-content .wy-alert-info.danger .admonition-title,.rst-content .wy-alert-info.danger .wy-alert-title,.rst-content .wy-alert-info.error .admonition-title,.rst-content .wy-alert-info.error .wy-alert-title,.rst-content .wy-alert-info.hint .admonition-title,.rst-content .wy-alert-info.hint .wy-alert-title,.rst-content .wy-alert-info.important .admonition-title,.rst-content .wy-alert-info.important .wy-alert-title,.rst-content .wy-alert-info.tip .admonition-title,.rst-content .wy-alert-info.tip .wy-alert-title,.rst-content .wy-alert-info.warning .admonition-title,.rst-content .wy-alert-info.warning .wy-alert-title,.rst-content .wy-alert.wy-alert-info .admonition-title,.wy-alert.wy-alert-info .rst-content .admonition-title,.wy-alert.wy-alert-info .wy-alert-title{background:#6ab0de}.rst-content .hint,.rst-content .important,.rst-content .tip,.rst-content .wy-alert-success.admonition,.rst-content .wy-alert-success.admonition-todo,.rst-content .wy-alert-success.attention,.rst-content .wy-alert-success.caution,.rst-content .wy-alert-success.danger,.rst-content .wy-alert-success.error,.rst-content .wy-alert-success.note,.rst-content .wy-alert-success.seealso,.rst-content .wy-alert-success.warning,.wy-alert.wy-alert-success{background:#dbfaf4}.rst-content .hint .admonition-title,.rst-content .hint .wy-alert-title,.rst-content .important .admonition-title,.rst-content .important .wy-alert-title,.rst-content .tip .admonition-title,.rst-content .tip .wy-alert-title,.rst-content .wy-alert-success.admonition-todo .admonition-title,.rst-content .wy-alert-success.admonition-todo .wy-alert-title,.rst-content .wy-alert-success.admonition .admonition-title,.rst-content .wy-alert-success.admonition .wy-alert-title,.rst-content .wy-alert-success.attention .admonition-title,.rst-content .wy-alert-success.attention .wy-alert-title,.rst-content .wy-alert-success.caution .admonition-title,.rst-content .wy-alert-success.caution .wy-alert-title,.rst-content .wy-alert-success.danger .admonition-title,.rst-content .wy-alert-success.danger .wy-alert-title,.rst-content .wy-alert-success.error .admonition-title,.rst-content .wy-alert-success.error .wy-alert-title,.rst-content .wy-alert-success.note .admonition-title,.rst-content .wy-alert-success.note .wy-alert-title,.rst-content .wy-alert-success.seealso .admonition-title,.rst-content .wy-alert-success.seealso .wy-alert-title,.rst-content .wy-alert-success.warning .admonition-title,.rst-content .wy-alert-success.warning .wy-alert-title,.rst-content .wy-alert.wy-alert-success .admonition-title,.wy-alert.wy-alert-success .rst-content .admonition-title,.wy-alert.wy-alert-success .wy-alert-title{background:#1abc9c}.rst-content .wy-alert-neutral.admonition,.rst-content .wy-alert-neutral.admonition-todo,.rst-content .wy-alert-neutral.attention,.rst-content .wy-alert-neutral.caution,.rst-content .wy-alert-neutral.danger,.rst-content .wy-alert-neutral.error,.rst-content .wy-alert-neutral.hint,.rst-content .wy-alert-neutral.important,.rst-content .wy-alert-neutral.note,.rst-content .wy-alert-neutral.seealso,.rst-content .wy-alert-neutral.tip,.rst-content .wy-alert-neutral.warning,.wy-alert.wy-alert-neutral{background:#f3f6f6}.rst-content .wy-alert-neutral.admonition-todo .admonition-title,.rst-content .wy-alert-neutral.admonition-todo .wy-alert-title,.rst-content .wy-alert-neutral.admonition .admonition-title,.rst-content .wy-alert-neutral.admonition .wy-alert-title,.rst-content .wy-alert-neutral.attention .admonition-title,.rst-content .wy-alert-neutral.attention .wy-alert-title,.rst-content .wy-alert-neutral.caution .admonition-title,.rst-content .wy-alert-neutral.caution .wy-alert-title,.rst-content .wy-alert-neutral.danger .admonition-title,.rst-content .wy-alert-neutral.danger .wy-alert-title,.rst-content .wy-alert-neutral.error .admonition-title,.rst-content .wy-alert-neutral.error .wy-alert-title,.rst-content .wy-alert-neutral.hint .admonition-title,.rst-content .wy-alert-neutral.hint .wy-alert-title,.rst-content .wy-alert-neutral.important .admonition-title,.rst-content .wy-alert-neutral.important .wy-alert-title,.rst-content .wy-alert-neutral.note .admonition-title,.rst-content .wy-alert-neutral.note .wy-alert-title,.rst-content .wy-alert-neutral.seealso .admonition-title,.rst-content .wy-alert-neutral.seealso .wy-alert-title,.rst-content .wy-alert-neutral.tip .admonition-title,.rst-content .wy-alert-neutral.tip .wy-alert-title,.rst-content .wy-alert-neutral.warning .admonition-title,.rst-content .wy-alert-neutral.warning .wy-alert-title,.rst-content .wy-alert.wy-alert-neutral .admonition-title,.wy-alert.wy-alert-neutral .rst-content .admonition-title,.wy-alert.wy-alert-neutral .wy-alert-title{color:#404040;background:#e1e4e5}.rst-content .wy-alert-neutral.admonition-todo a,.rst-content .wy-alert-neutral.admonition a,.rst-content .wy-alert-neutral.attention a,.rst-content .wy-alert-neutral.caution a,.rst-content .wy-alert-neutral.danger a,.rst-content .wy-alert-neutral.error a,.rst-content .wy-alert-neutral.hint a,.rst-content .wy-alert-neutral.important a,.rst-content .wy-alert-neutral.note a,.rst-content .wy-alert-neutral.seealso a,.rst-content .wy-alert-neutral.tip a,.rst-content .wy-alert-neutral.warning a,.wy-alert.wy-alert-neutral a{color:#2980b9}.rst-content .admonition-todo p:last-child,.rst-content .admonition p:last-child,.rst-content .attention p:last-child,.rst-content .caution p:last-child,.rst-content .danger p:last-child,.rst-content .error p:last-child,.rst-content .hint p:last-child,.rst-content .important p:last-child,.rst-content .note p:last-child,.rst-content .seealso p:last-child,.rst-content .tip p:last-child,.rst-content .warning p:last-child,.wy-alert p:last-child{margin-bottom:0}.wy-tray-container{position:fixed;bottom:0;left:0;z-index:600}.wy-tray-container li{display:block;width:300px;background:transparent;color:#fff;text-align:center;box-shadow:0 5px 5px 0 rgba(0,0,0,.1);padding:0 24px;min-width:20%;opacity:0;height:0;line-height:56px;overflow:hidden;-webkit-transition:all .3s ease-in;-moz-transition:all .3s ease-in;transition:all .3s ease-in}.wy-tray-container li.wy-tray-item-success{background:#27ae60}.wy-tray-container li.wy-tray-item-info{background:#2980b9}.wy-tray-container li.wy-tray-item-warning{background:#e67e22}.wy-tray-container li.wy-tray-item-danger{background:#e74c3c}.wy-tray-container li.on{opacity:1;height:56px}@media screen and (max-width:768px){.wy-tray-container{bottom:auto;top:0;width:100%}.wy-tray-container li{width:100%}}button{font-size:100%;margin:0;vertical-align:baseline;*vertical-align:middle;cursor:pointer;line-height:normal;-webkit-appearance:button;*overflow:visible}button::-moz-focus-inner,input::-moz-focus-inner{border:0;padding:0}button[disabled]{cursor:default}.btn{display:inline-block;border-radius:2px;line-height:normal;white-space:nowrap;text-align:center;cursor:pointer;font-size:100%;padding:6px 12px 8px;color:#fff;border:1px solid rgba(0,0,0,.1);background-color:#27ae60;text-decoration:none;font-weight:400;font-family:Lato,proxima-nova,Helvetica Neue,Arial,sans-serif;box-shadow:inset 0 1px 2px -1px hsla(0,0%,100%,.5),inset 0 -2px 0 0 rgba(0,0,0,.1);outline-none:false;vertical-align:middle;*display:inline;zoom:1;-webkit-user-drag:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-transition:all .1s linear;-moz-transition:all .1s linear;transition:all .1s linear}.btn-hover{background:#2e8ece;color:#fff}.btn:hover{background:#2cc36b;color:#fff}.btn:focus{background:#2cc36b;outline:0}.btn:active{box-shadow:inset 0 -1px 0 0 rgba(0,0,0,.05),inset 0 2px 0 0 rgba(0,0,0,.1);padding:8px 12px 6px}.btn:visited{color:#fff}.btn-disabled,.btn-disabled:active,.btn-disabled:focus,.btn-disabled:hover,.btn:disabled{background-image:none;filter:progid:DXImageTransform.Microsoft.gradient(enabled = false);filter:alpha(opacity=40);opacity:.4;cursor:not-allowed;box-shadow:none}.btn::-moz-focus-inner{padding:0;border:0}.btn-small{font-size:80%}.btn-info{background-color:#2980b9!important}.btn-info:hover{background-color:#2e8ece!important}.btn-neutral{background-color:#f3f6f6!important;color:#404040!important}.btn-neutral:hover{background-color:#e5ebeb!important;color:#404040}.btn-neutral:visited{color:#404040!important}.btn-success{background-color:#27ae60!important}.btn-success:hover{background-color:#295!important}.btn-danger{background-color:#e74c3c!important}.btn-danger:hover{background-color:#ea6153!important}.btn-warning{background-color:#e67e22!important}.btn-warning:hover{background-color:#e98b39!important}.btn-invert{background-color:#222}.btn-invert:hover{background-color:#2f2f2f!important}.btn-link{background-color:transparent!important;color:#2980b9;box-shadow:none;border-color:transparent!important}.btn-link:active,.btn-link:hover{background-color:transparent!important;color:#409ad5!important;box-shadow:none}.btn-link:visited{color:#9b59b6}.wy-btn-group .btn,.wy-control .btn{vertical-align:middle}.wy-btn-group{margin-bottom:24px;*zoom:1}.wy-btn-group:after,.wy-btn-group:before{display:table;content:""}.wy-btn-group:after{clear:both}.wy-dropdown{position:relative;display:inline-block}.wy-dropdown-active .wy-dropdown-menu{display:block}.wy-dropdown-menu{position:absolute;left:0;display:none;float:left;top:100%;min-width:100%;background:#fcfcfc;z-index:100;border:1px solid #cfd7dd;box-shadow:0 2px 2px 0 rgba(0,0,0,.1);padding:12px}.wy-dropdown-menu>dd>a{display:block;clear:both;color:#404040;white-space:nowrap;font-size:90%;padding:0 12px;cursor:pointer}.wy-dropdown-menu>dd>a:hover{background:#2980b9;color:#fff}.wy-dropdown-menu>dd.divider{border-top:1px solid #cfd7dd;margin:6px 0}.wy-dropdown-menu>dd.search{padding-bottom:12px}.wy-dropdown-menu>dd.search input[type=search]{width:100%}.wy-dropdown-menu>dd.call-to-action{background:#e3e3e3;text-transform:uppercase;font-weight:500;font-size:80%}.wy-dropdown-menu>dd.call-to-action:hover{background:#e3e3e3}.wy-dropdown-menu>dd.call-to-action .btn{color:#fff}.wy-dropdown.wy-dropdown-up .wy-dropdown-menu{bottom:100%;top:auto;left:auto;right:0}.wy-dropdown.wy-dropdown-bubble .wy-dropdown-menu{background:#fcfcfc;margin-top:2px}.wy-dropdown.wy-dropdown-bubble .wy-dropdown-menu a{padding:6px 12px}.wy-dropdown.wy-dropdown-bubble .wy-dropdown-menu a:hover{background:#2980b9;color:#fff}.wy-dropdown.wy-dropdown-left .wy-dropdown-menu{right:0;left:auto;text-align:right}.wy-dropdown-arrow:before{content:" ";border-bottom:5px solid #f5f5f5;border-left:5px solid transparent;border-right:5px solid transparent;position:absolute;display:block;top:-4px;left:50%;margin-left:-3px}.wy-dropdown-arrow.wy-dropdown-arrow-left:before{left:11px}.wy-form-stacked select{display:block}.wy-form-aligned .wy-help-inline,.wy-form-aligned input,.wy-form-aligned label,.wy-form-aligned select,.wy-form-aligned textarea{display:inline-block;*display:inline;*zoom:1;vertical-align:middle}.wy-form-aligned .wy-control-group>label{display:inline-block;vertical-align:middle;width:10em;margin:6px 12px 0 0;float:left}.wy-form-aligned .wy-control{float:left}.wy-form-aligned .wy-control label{display:block}.wy-form-aligned .wy-control select{margin-top:6px}fieldset{margin:0}fieldset,legend{border:0;padding:0}legend{width:100%;white-space:normal;margin-bottom:24px;font-size:150%;*margin-left:-7px}label,legend{display:block}label{margin:0 0 .3125em;color:#333;font-size:90%}input,select,textarea{font-size:100%;margin:0;vertical-align:baseline;*vertical-align:middle}.wy-control-group{margin-bottom:24px;max-width:1200px;margin-left:auto;margin-right:auto;*zoom:1}.wy-control-group:after,.wy-control-group:before{display:table;content:""}.wy-control-group:after{clear:both}.wy-control-group.wy-control-group-required>label:after{content:" *";color:#e74c3c}.wy-control-group .wy-form-full,.wy-control-group .wy-form-halves,.wy-control-group .wy-form-thirds{padding-bottom:12px}.wy-control-group .wy-form-full input[type=color],.wy-control-group .wy-form-full input[type=date],.wy-control-group .wy-form-full input[type=datetime-local],.wy-control-group .wy-form-full input[type=datetime],.wy-control-group .wy-form-full input[type=email],.wy-control-group .wy-form-full input[type=month],.wy-control-group .wy-form-full input[type=number],.wy-control-group .wy-form-full input[type=password],.wy-control-group .wy-form-full input[type=search],.wy-control-group .wy-form-full input[type=tel],.wy-control-group .wy-form-full input[type=text],.wy-control-group .wy-form-full input[type=time],.wy-control-group .wy-form-full input[type=url],.wy-control-group .wy-form-full input[type=week],.wy-control-group .wy-form-full select,.wy-control-group .wy-form-halves input[type=color],.wy-control-group .wy-form-halves input[type=date],.wy-control-group .wy-form-halves input[type=datetime-local],.wy-control-group .wy-form-halves input[type=datetime],.wy-control-group .wy-form-halves input[type=email],.wy-control-group .wy-form-halves input[type=month],.wy-control-group .wy-form-halves input[type=number],.wy-control-group .wy-form-halves input[type=password],.wy-control-group .wy-form-halves input[type=search],.wy-control-group .wy-form-halves input[type=tel],.wy-control-group .wy-form-halves input[type=text],.wy-control-group .wy-form-halves input[type=time],.wy-control-group .wy-form-halves input[type=url],.wy-control-group .wy-form-halves input[type=week],.wy-control-group .wy-form-halves select,.wy-control-group .wy-form-thirds input[type=color],.wy-control-group .wy-form-thirds input[type=date],.wy-control-group .wy-form-thirds input[type=datetime-local],.wy-control-group .wy-form-thirds input[type=datetime],.wy-control-group .wy-form-thirds input[type=email],.wy-control-group .wy-form-thirds input[type=month],.wy-control-group .wy-form-thirds input[type=number],.wy-control-group .wy-form-thirds input[type=password],.wy-control-group .wy-form-thirds input[type=search],.wy-control-group .wy-form-thirds input[type=tel],.wy-control-group .wy-form-thirds input[type=text],.wy-control-group .wy-form-thirds input[type=time],.wy-control-group .wy-form-thirds input[type=url],.wy-control-group .wy-form-thirds input[type=week],.wy-control-group .wy-form-thirds select{width:100%}.wy-control-group .wy-form-full{float:left;display:block;width:100%;margin-right:0}.wy-control-group .wy-form-full:last-child{margin-right:0}.wy-control-group .wy-form-halves{float:left;display:block;margin-right:2.35765%;width:48.82117%}.wy-control-group .wy-form-halves:last-child,.wy-control-group .wy-form-halves:nth-of-type(2n){margin-right:0}.wy-control-group .wy-form-halves:nth-of-type(odd){clear:left}.wy-control-group .wy-form-thirds{float:left;display:block;margin-right:2.35765%;width:31.76157%}.wy-control-group .wy-form-thirds:last-child,.wy-control-group .wy-form-thirds:nth-of-type(3n){margin-right:0}.wy-control-group .wy-form-thirds:nth-of-type(3n+1){clear:left}.wy-control-group.wy-control-group-no-input .wy-control,.wy-control-no-input{margin:6px 0 0;font-size:90%}.wy-control-no-input{display:inline-block}.wy-control-group.fluid-input input[type=color],.wy-control-group.fluid-input input[type=date],.wy-control-group.fluid-input input[type=datetime-local],.wy-control-group.fluid-input input[type=datetime],.wy-control-group.fluid-input input[type=email],.wy-control-group.fluid-input input[type=month],.wy-control-group.fluid-input input[type=number],.wy-control-group.fluid-input input[type=password],.wy-control-group.fluid-input input[type=search],.wy-control-group.fluid-input input[type=tel],.wy-control-group.fluid-input input[type=text],.wy-control-group.fluid-input input[type=time],.wy-control-group.fluid-input input[type=url],.wy-control-group.fluid-input input[type=week]{width:100%}.wy-form-message-inline{padding-left:.3em;color:#666;font-size:90%}.wy-form-message{display:block;color:#999;font-size:70%;margin-top:.3125em;font-style:italic}.wy-form-message p{font-size:inherit;font-style:italic;margin-bottom:6px}.wy-form-message p:last-child{margin-bottom:0}input{line-height:normal}input[type=button],input[type=reset],input[type=submit]{-webkit-appearance:button;cursor:pointer;font-family:Lato,proxima-nova,Helvetica Neue,Arial,sans-serif;*overflow:visible}input[type=color],input[type=date],input[type=datetime-local],input[type=datetime],input[type=email],input[type=month],input[type=number],input[type=password],input[type=search],input[type=tel],input[type=text],input[type=time],input[type=url],input[type=week]{-webkit-appearance:none;padding:6px;display:inline-block;border:1px solid #ccc;font-size:80%;font-family:Lato,proxima-nova,Helvetica Neue,Arial,sans-serif;box-shadow:inset 0 1px 3px #ddd;border-radius:0;-webkit-transition:border .3s linear;-moz-transition:border .3s linear;transition:border .3s linear}input[type=datetime-local]{padding:.34375em .625em}input[disabled]{cursor:default}input[type=checkbox],input[type=radio]{padding:0;margin-right:.3125em;*height:13px;*width:13px}input[type=checkbox],input[type=radio],input[type=search]{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}input[type=color]:focus,input[type=date]:focus,input[type=datetime-local]:focus,input[type=datetime]:focus,input[type=email]:focus,input[type=month]:focus,input[type=number]:focus,input[type=password]:focus,input[type=search]:focus,input[type=tel]:focus,input[type=text]:focus,input[type=time]:focus,input[type=url]:focus,input[type=week]:focus{outline:0;outline:thin dotted\9;border-color:#333}input.no-focus:focus{border-color:#ccc!important}input[type=checkbox]:focus,input[type=file]:focus,input[type=radio]:focus{outline:thin dotted #333;outline:1px auto #129fea}input[type=color][disabled],input[type=date][disabled],input[type=datetime-local][disabled],input[type=datetime][disabled],input[type=email][disabled],input[type=month][disabled],input[type=number][disabled],input[type=password][disabled],input[type=search][disabled],input[type=tel][disabled],input[type=text][disabled],input[type=time][disabled],input[type=url][disabled],input[type=week][disabled]{cursor:not-allowed;background-color:#fafafa}input:focus:invalid,select:focus:invalid,textarea:focus:invalid{color:#e74c3c;border:1px solid #e74c3c}input:focus:invalid:focus,select:focus:invalid:focus,textarea:focus:invalid:focus{border-color:#e74c3c}input[type=checkbox]:focus:invalid:focus,input[type=file]:focus:invalid:focus,input[type=radio]:focus:invalid:focus{outline-color:#e74c3c}input.wy-input-large{padding:12px;font-size:100%}textarea{overflow:auto;vertical-align:top;width:100%;font-family:Lato,proxima-nova,Helvetica Neue,Arial,sans-serif}select,textarea{padding:.5em .625em;display:inline-block;border:1px solid #ccc;font-size:80%;box-shadow:inset 0 1px 3px #ddd;-webkit-transition:border .3s linear;-moz-transition:border .3s linear;transition:border .3s linear}select{border:1px solid #ccc;background-color:#fff}select[multiple]{height:auto}select:focus,textarea:focus{outline:0}input[readonly],select[disabled],select[readonly],textarea[disabled],textarea[readonly]{cursor:not-allowed;background-color:#fafafa}input[type=checkbox][disabled],input[type=radio][disabled]{cursor:not-allowed}.wy-checkbox,.wy-radio{margin:6px 0;color:#404040;display:block}.wy-checkbox input,.wy-radio input{vertical-align:baseline}.wy-form-message-inline{display:inline-block;*display:inline;*zoom:1;vertical-align:middle}.wy-input-prefix,.wy-input-suffix{white-space:nowrap;padding:6px}.wy-input-prefix .wy-input-context,.wy-input-suffix .wy-input-context{line-height:27px;padding:0 8px;display:inline-block;font-size:80%;background-color:#f3f6f6;border:1px solid #ccc;color:#999}.wy-input-suffix .wy-input-context{border-left:0}.wy-input-prefix .wy-input-context{border-right:0}.wy-switch{position:relative;display:block;height:24px;margin-top:12px;cursor:pointer}.wy-switch:before{left:0;top:0;width:36px;height:12px;background:#ccc}.wy-switch:after,.wy-switch:before{position:absolute;content:"";display:block;border-radius:4px;-webkit-transition:all .2s ease-in-out;-moz-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.wy-switch:after{width:18px;height:18px;background:#999;left:-3px;top:-3px}.wy-switch span{position:absolute;left:48px;display:block;font-size:12px;color:#ccc;line-height:1}.wy-switch.active:before{background:#1e8449}.wy-switch.active:after{left:24px;background:#27ae60}.wy-switch.disabled{cursor:not-allowed;opacity:.8}.wy-control-group.wy-control-group-error .wy-form-message,.wy-control-group.wy-control-group-error>label{color:#e74c3c}.wy-control-group.wy-control-group-error input[type=color],.wy-control-group.wy-control-group-error input[type=date],.wy-control-group.wy-control-group-error input[type=datetime-local],.wy-control-group.wy-control-group-error input[type=datetime],.wy-control-group.wy-control-group-error input[type=email],.wy-control-group.wy-control-group-error input[type=month],.wy-control-group.wy-control-group-error input[type=number],.wy-control-group.wy-control-group-error input[type=password],.wy-control-group.wy-control-group-error input[type=search],.wy-control-group.wy-control-group-error input[type=tel],.wy-control-group.wy-control-group-error input[type=text],.wy-control-group.wy-control-group-error input[type=time],.wy-control-group.wy-control-group-error input[type=url],.wy-control-group.wy-control-group-error input[type=week],.wy-control-group.wy-control-group-error textarea{border:1px solid #e74c3c}.wy-inline-validate{white-space:nowrap}.wy-inline-validate .wy-input-context{padding:.5em .625em;display:inline-block;font-size:80%}.wy-inline-validate.wy-inline-validate-success .wy-input-context{color:#27ae60}.wy-inline-validate.wy-inline-validate-danger .wy-input-context{color:#e74c3c}.wy-inline-validate.wy-inline-validate-warning .wy-input-context{color:#e67e22}.wy-inline-validate.wy-inline-validate-info .wy-input-context{color:#2980b9}.rotate-90{-webkit-transform:rotate(90deg);-moz-transform:rotate(90deg);-ms-transform:rotate(90deg);-o-transform:rotate(90deg);transform:rotate(90deg)}.rotate-180{-webkit-transform:rotate(180deg);-moz-transform:rotate(180deg);-ms-transform:rotate(180deg);-o-transform:rotate(180deg);transform:rotate(180deg)}.rotate-270{-webkit-transform:rotate(270deg);-moz-transform:rotate(270deg);-ms-transform:rotate(270deg);-o-transform:rotate(270deg);transform:rotate(270deg)}.mirror{-webkit-transform:scaleX(-1);-moz-transform:scaleX(-1);-ms-transform:scaleX(-1);-o-transform:scaleX(-1);transform:scaleX(-1)}.mirror.rotate-90{-webkit-transform:scaleX(-1) rotate(90deg);-moz-transform:scaleX(-1) rotate(90deg);-ms-transform:scaleX(-1) rotate(90deg);-o-transform:scaleX(-1) rotate(90deg);transform:scaleX(-1) rotate(90deg)}.mirror.rotate-180{-webkit-transform:scaleX(-1) rotate(180deg);-moz-transform:scaleX(-1) rotate(180deg);-ms-transform:scaleX(-1) rotate(180deg);-o-transform:scaleX(-1) rotate(180deg);transform:scaleX(-1) rotate(180deg)}.mirror.rotate-270{-webkit-transform:scaleX(-1) rotate(270deg);-moz-transform:scaleX(-1) rotate(270deg);-ms-transform:scaleX(-1) rotate(270deg);-o-transform:scaleX(-1) rotate(270deg);transform:scaleX(-1) rotate(270deg)}@media only screen and (max-width:480px){.wy-form button[type=submit]{margin:.7em 0 0}.wy-form input[type=color],.wy-form input[type=date],.wy-form input[type=datetime-local],.wy-form input[type=datetime],.wy-form input[type=email],.wy-form input[type=month],.wy-form input[type=number],.wy-form input[type=password],.wy-form input[type=search],.wy-form input[type=tel],.wy-form input[type=text],.wy-form input[type=time],.wy-form input[type=url],.wy-form input[type=week],.wy-form label{margin-bottom:.3em;display:block}.wy-form input[type=color],.wy-form input[type=date],.wy-form input[type=datetime-local],.wy-form input[type=datetime],.wy-form input[type=email],.wy-form input[type=month],.wy-form input[type=number],.wy-form input[type=password],.wy-form input[type=search],.wy-form input[type=tel],.wy-form input[type=time],.wy-form input[type=url],.wy-form input[type=week]{margin-bottom:0}.wy-form-aligned .wy-control-group label{margin-bottom:.3em;text-align:left;display:block;width:100%}.wy-form-aligned .wy-control{margin:1.5em 0 0}.wy-form-message,.wy-form-message-inline,.wy-form .wy-help-inline{display:block;font-size:80%;padding:6px 0}}@media screen and (max-width:768px){.tablet-hide{display:none}}@media screen and (max-width:480px){.mobile-hide{display:none}}.float-left{float:left}.float-right{float:right}.full-width{width:100%}.rst-content table.docutils,.rst-content table.field-list,.wy-table{border-collapse:collapse;border-spacing:0;empty-cells:show;margin-bottom:24px}.rst-content table.docutils caption,.rst-content table.field-list caption,.wy-table caption{color:#000;font:italic 85%/1 arial,sans-serif;padding:1em 0;text-align:center}.rst-content table.docutils td,.rst-content table.docutils th,.rst-content table.field-list td,.rst-content table.field-list th,.wy-table td,.wy-table th{font-size:90%;margin:0;overflow:visible;padding:8px 16px}.rst-content table.docutils td:first-child,.rst-content table.docutils th:first-child,.rst-content table.field-list td:first-child,.rst-content table.field-list th:first-child,.wy-table td:first-child,.wy-table th:first-child{border-left-width:0}.rst-content table.docutils thead,.rst-content table.field-list thead,.wy-table thead{color:#000;text-align:left;vertical-align:bottom;white-space:nowrap}.rst-content table.docutils thead th,.rst-content table.field-list thead th,.wy-table thead th{font-weight:700;border-bottom:2px solid #e1e4e5}.rst-content table.docutils td,.rst-content table.field-list td,.wy-table td{background-color:transparent;vertical-align:middle}.rst-content table.docutils td p,.rst-content table.field-list td p,.wy-table td p{line-height:18px}.rst-content table.docutils td p:last-child,.rst-content table.field-list td p:last-child,.wy-table td p:last-child{margin-bottom:0}.rst-content table.docutils .wy-table-cell-min,.rst-content table.field-list .wy-table-cell-min,.wy-table .wy-table-cell-min{width:1%;padding-right:0}.rst-content table.docutils .wy-table-cell-min input[type=checkbox],.rst-content table.field-list .wy-table-cell-min input[type=checkbox],.wy-table .wy-table-cell-min input[type=checkbox]{margin:0}.wy-table-secondary{color:grey;font-size:90%}.wy-table-tertiary{color:grey;font-size:80%}.rst-content table.docutils:not(.field-list) tr:nth-child(2n-1) td,.wy-table-backed,.wy-table-odd td,.wy-table-striped tr:nth-child(2n-1) td{background-color:#f3f6f6}.rst-content table.docutils,.wy-table-bordered-all{border:1px solid #e1e4e5}.rst-content table.docutils td,.wy-table-bordered-all td{border-bottom:1px solid #e1e4e5;border-left:1px solid #e1e4e5}.rst-content table.docutils tbody>tr:last-child td,.wy-table-bordered-all tbody>tr:last-child td{border-bottom-width:0}.wy-table-bordered{border:1px solid #e1e4e5}.wy-table-bordered-rows td{border-bottom:1px solid #e1e4e5}.wy-table-bordered-rows tbody>tr:last-child td{border-bottom-width:0}.wy-table-horizontal td,.wy-table-horizontal th{border-width:0 0 1px;border-bottom:1px solid #e1e4e5}.wy-table-horizontal tbody>tr:last-child td{border-bottom-width:0}.wy-table-responsive{margin-bottom:24px;max-width:100%;overflow:auto}.wy-table-responsive table{margin-bottom:0!important}.wy-table-responsive table td,.wy-table-responsive table th{white-space:nowrap}a{color:#2980b9;text-decoration:none;cursor:pointer}a:hover{color:#3091d1}a:visited{color:#9b59b6}html{height:100%}body,html{overflow-x:hidden}body{font-family:Lato,proxima-nova,Helvetica Neue,Arial,sans-serif;font-weight:400;color:#404040;min-height:100%;background:#edf0f2}.wy-text-left{text-align:left}.wy-text-center{text-align:center}.wy-text-right{text-align:right}.wy-text-large{font-size:120%}.wy-text-normal{font-size:100%}.wy-text-small,small{font-size:80%}.wy-text-strike{text-decoration:line-through}.wy-text-warning{color:#e67e22!important}a.wy-text-warning:hover{color:#eb9950!important}.wy-text-info{color:#2980b9!important}a.wy-text-info:hover{color:#409ad5!important}.wy-text-success{color:#27ae60!important}a.wy-text-success:hover{color:#36d278!important}.wy-text-danger{color:#e74c3c!important}a.wy-text-danger:hover{color:#ed7669!important}.wy-text-neutral{color:#404040!important}a.wy-text-neutral:hover{color:#595959!important}.rst-content .toctree-wrapper>p.caption,h1,h2,h3,h4,h5,h6,legend{margin-top:0;font-weight:700;font-family:Roboto Slab,ff-tisa-web-pro,Georgia,Arial,sans-serif}p{line-height:24px;font-size:16px;margin:0 0 24px}h1{font-size:175%}.rst-content .toctree-wrapper>p.caption,h2{font-size:150%}h3{font-size:125%}h4{font-size:115%}h5{font-size:110%}h6{font-size:100%}hr{display:block;height:1px;border:0;border-top:1px solid #e1e4e5;margin:24px 0;padding:0}.rst-content code,.rst-content tt,code{white-space:nowrap;max-width:100%;background:#fff;border:1px solid #e1e4e5;font-size:75%;padding:0 5px;font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,Courier,monospace;color:#e74c3c;overflow-x:auto}.rst-content tt.code-large,code.code-large{font-size:90%}.rst-content .section ul,.rst-content .toctree-wrapper ul,.rst-content section ul,.wy-plain-list-disc,article ul{list-style:disc;line-height:24px;margin-bottom:24px}.rst-content .section ul li,.rst-content .toctree-wrapper ul li,.rst-content section ul li,.wy-plain-list-disc li,article ul li{list-style:disc;margin-left:24px}.rst-content .section ul li p:last-child,.rst-content .section ul li ul,.rst-content .toctree-wrapper ul li p:last-child,.rst-content .toctree-wrapper ul li ul,.rst-content section ul li p:last-child,.rst-content section ul li ul,.wy-plain-list-disc li p:last-child,.wy-plain-list-disc li ul,article ul li p:last-child,article ul li ul{margin-bottom:0}.rst-content .section ul li li,.rst-content .toctree-wrapper ul li li,.rst-content section ul li li,.wy-plain-list-disc li li,article ul li li{list-style:circle}.rst-content .section ul li li li,.rst-content .toctree-wrapper ul li li li,.rst-content section ul li li li,.wy-plain-list-disc li li li,article ul li li li{list-style:square}.rst-content .section ul li ol li,.rst-content .toctree-wrapper ul li ol li,.rst-content section ul li ol li,.wy-plain-list-disc li ol li,article ul li ol li{list-style:decimal}.rst-content .section ol,.rst-content .section ol.arabic,.rst-content .toctree-wrapper ol,.rst-content .toctree-wrapper ol.arabic,.rst-content section ol,.rst-content section ol.arabic,.wy-plain-list-decimal,article ol{list-style:decimal;line-height:24px;margin-bottom:24px}.rst-content .section ol.arabic li,.rst-content .section ol li,.rst-content .toctree-wrapper ol.arabic li,.rst-content .toctree-wrapper ol li,.rst-content section ol.arabic li,.rst-content section ol li,.wy-plain-list-decimal li,article ol li{list-style:decimal;margin-left:24px}.rst-content .section ol.arabic li ul,.rst-content .section ol li p:last-child,.rst-content .section ol li ul,.rst-content .toctree-wrapper ol.arabic li ul,.rst-content .toctree-wrapper ol li p:last-child,.rst-content .toctree-wrapper ol li ul,.rst-content section ol.arabic li ul,.rst-content section ol li p:last-child,.rst-content section ol li ul,.wy-plain-list-decimal li p:last-child,.wy-plain-list-decimal li ul,article ol li p:last-child,article ol li ul{margin-bottom:0}.rst-content .section ol.arabic li ul li,.rst-content .section ol li ul li,.rst-content .toctree-wrapper ol.arabic li ul li,.rst-content .toctree-wrapper ol li ul li,.rst-content section ol.arabic li ul li,.rst-content section ol li ul li,.wy-plain-list-decimal li ul li,article ol li ul li{list-style:disc}.wy-breadcrumbs{*zoom:1}.wy-breadcrumbs:after,.wy-breadcrumbs:before{display:table;content:""}.wy-breadcrumbs:after{clear:both}.wy-breadcrumbs>li{display:inline-block;padding-top:5px}.wy-breadcrumbs>li.wy-breadcrumbs-aside{float:right}.rst-content .wy-breadcrumbs>li code,.rst-content .wy-breadcrumbs>li tt,.wy-breadcrumbs>li .rst-content tt,.wy-breadcrumbs>li code{all:inherit;color:inherit}.breadcrumb-item:before{content:"/";color:#bbb;font-size:13px;padding:0 6px 0 3px}.wy-breadcrumbs-extra{margin-bottom:0;color:#b3b3b3;font-size:80%;display:inline-block}@media screen and (max-width:480px){.wy-breadcrumbs-extra,.wy-breadcrumbs li.wy-breadcrumbs-aside{display:none}}@media print{.wy-breadcrumbs li.wy-breadcrumbs-aside{display:none}}html{font-size:16px}.wy-affix{position:fixed;top:1.618em}.wy-menu a:hover{text-decoration:none}.wy-menu-horiz{*zoom:1}.wy-menu-horiz:after,.wy-menu-horiz:before{display:table;content:""}.wy-menu-horiz:after{clear:both}.wy-menu-horiz li,.wy-menu-horiz ul{display:inline-block}.wy-menu-horiz li:hover{background:hsla(0,0%,100%,.1)}.wy-menu-horiz li.divide-left{border-left:1px solid #404040}.wy-menu-horiz li.divide-right{border-right:1px solid #404040}.wy-menu-horiz a{height:32px;display:inline-block;line-height:32px;padding:0 16px}.wy-menu-vertical{width:300px}.wy-menu-vertical header,.wy-menu-vertical p.caption{color:#55a5d9;height:32px;line-height:32px;padding:0 1.618em;margin:12px 0 0;display:block;font-weight:700;text-transform:uppercase;font-size:85%;white-space:nowrap}.wy-menu-vertical ul{margin-bottom:0}.wy-menu-vertical li.divide-top{border-top:1px solid #404040}.wy-menu-vertical li.divide-bottom{border-bottom:1px solid #404040}.wy-menu-vertical li.current{background:#e3e3e3}.wy-menu-vertical li.current a{color:grey;border-right:1px solid #c9c9c9;padding:.4045em 2.427em}.wy-menu-vertical li.current a:hover{background:#d6d6d6}.rst-content .wy-menu-vertical li tt,.wy-menu-vertical li .rst-content tt,.wy-menu-vertical li code{border:none;background:inherit;color:inherit;padding-left:0;padding-right:0}.wy-menu-vertical li button.toctree-expand{display:block;float:left;margin-left:-1.2em;line-height:18px;color:#4d4d4d;border:none;background:none;padding:0}.wy-menu-vertical li.current>a,.wy-menu-vertical li.on a{color:#404040;font-weight:700;position:relative;background:#fcfcfc;border:none;padding:.4045em 1.618em}.wy-menu-vertical li.current>a:hover,.wy-menu-vertical li.on a:hover{background:#fcfcfc}.wy-menu-vertical li.current>a:hover button.toctree-expand,.wy-menu-vertical li.on a:hover button.toctree-expand{color:grey}.wy-menu-vertical li.current>a button.toctree-expand,.wy-menu-vertical li.on a button.toctree-expand{display:block;line-height:18px;color:#333}.wy-menu-vertical li.toctree-l1.current>a{border-bottom:1px solid #c9c9c9;border-top:1px solid #c9c9c9}.wy-menu-vertical .toctree-l1.current .toctree-l2>ul,.wy-menu-vertical .toctree-l2.current .toctree-l3>ul,.wy-menu-vertical .toctree-l3.current .toctree-l4>ul,.wy-menu-vertical .toctree-l4.current .toctree-l5>ul,.wy-menu-vertical .toctree-l5.current .toctree-l6>ul,.wy-menu-vertical .toctree-l6.current .toctree-l7>ul,.wy-menu-vertical .toctree-l7.current .toctree-l8>ul,.wy-menu-vertical .toctree-l8.current .toctree-l9>ul,.wy-menu-vertical .toctree-l9.current .toctree-l10>ul,.wy-menu-vertical .toctree-l10.current .toctree-l11>ul{display:none}.wy-menu-vertical .toctree-l1.current .current.toctree-l2>ul,.wy-menu-vertical .toctree-l2.current .current.toctree-l3>ul,.wy-menu-vertical .toctree-l3.current .current.toctree-l4>ul,.wy-menu-vertical .toctree-l4.current .current.toctree-l5>ul,.wy-menu-vertical .toctree-l5.current .current.toctree-l6>ul,.wy-menu-vertical .toctree-l6.current .current.toctree-l7>ul,.wy-menu-vertical .toctree-l7.current .current.toctree-l8>ul,.wy-menu-vertical .toctree-l8.current .current.toctree-l9>ul,.wy-menu-vertical .toctree-l9.current .current.toctree-l10>ul,.wy-menu-vertical .toctree-l10.current .current.toctree-l11>ul{display:block}.wy-menu-vertical li.toctree-l3,.wy-menu-vertical li.toctree-l4{font-size:.9em}.wy-menu-vertical li.toctree-l2 a,.wy-menu-vertical li.toctree-l3 a,.wy-menu-vertical li.toctree-l4 a,.wy-menu-vertical li.toctree-l5 a,.wy-menu-vertical li.toctree-l6 a,.wy-menu-vertical li.toctree-l7 a,.wy-menu-vertical li.toctree-l8 a,.wy-menu-vertical li.toctree-l9 a,.wy-menu-vertical li.toctree-l10 a{color:#404040}.wy-menu-vertical li.toctree-l2 a:hover button.toctree-expand,.wy-menu-vertical li.toctree-l3 a:hover button.toctree-expand,.wy-menu-vertical li.toctree-l4 a:hover button.toctree-expand,.wy-menu-vertical li.toctree-l5 a:hover button.toctree-expand,.wy-menu-vertical li.toctree-l6 a:hover button.toctree-expand,.wy-menu-vertical li.toctree-l7 a:hover button.toctree-expand,.wy-menu-vertical li.toctree-l8 a:hover button.toctree-expand,.wy-menu-vertical li.toctree-l9 a:hover button.toctree-expand,.wy-menu-vertical li.toctree-l10 a:hover button.toctree-expand{color:grey}.wy-menu-vertical li.toctree-l2.current li.toctree-l3>a,.wy-menu-vertical li.toctree-l3.current li.toctree-l4>a,.wy-menu-vertical li.toctree-l4.current li.toctree-l5>a,.wy-menu-vertical li.toctree-l5.current li.toctree-l6>a,.wy-menu-vertical li.toctree-l6.current li.toctree-l7>a,.wy-menu-vertical li.toctree-l7.current li.toctree-l8>a,.wy-menu-vertical li.toctree-l8.current li.toctree-l9>a,.wy-menu-vertical li.toctree-l9.current li.toctree-l10>a,.wy-menu-vertical li.toctree-l10.current li.toctree-l11>a{display:block}.wy-menu-vertical li.toctree-l2.current>a{padding:.4045em 2.427em}.wy-menu-vertical li.toctree-l2.current li.toctree-l3>a{padding:.4045em 1.618em .4045em 4.045em}.wy-menu-vertical li.toctree-l3.current>a{padding:.4045em 4.045em}.wy-menu-vertical li.toctree-l3.current li.toctree-l4>a{padding:.4045em 1.618em .4045em 5.663em}.wy-menu-vertical li.toctree-l4.current>a{padding:.4045em 5.663em}.wy-menu-vertical li.toctree-l4.current li.toctree-l5>a{padding:.4045em 1.618em .4045em 7.281em}.wy-menu-vertical li.toctree-l5.current>a{padding:.4045em 7.281em}.wy-menu-vertical li.toctree-l5.current li.toctree-l6>a{padding:.4045em 1.618em .4045em 8.899em}.wy-menu-vertical li.toctree-l6.current>a{padding:.4045em 8.899em}.wy-menu-vertical li.toctree-l6.current li.toctree-l7>a{padding:.4045em 1.618em .4045em 10.517em}.wy-menu-vertical li.toctree-l7.current>a{padding:.4045em 10.517em}.wy-menu-vertical li.toctree-l7.current li.toctree-l8>a{padding:.4045em 1.618em .4045em 12.135em}.wy-menu-vertical li.toctree-l8.current>a{padding:.4045em 12.135em}.wy-menu-vertical li.toctree-l8.current li.toctree-l9>a{padding:.4045em 1.618em .4045em 13.753em}.wy-menu-vertical li.toctree-l9.current>a{padding:.4045em 13.753em}.wy-menu-vertical li.toctree-l9.current li.toctree-l10>a{padding:.4045em 1.618em .4045em 15.371em}.wy-menu-vertical li.toctree-l10.current>a{padding:.4045em 15.371em}.wy-menu-vertical li.toctree-l10.current li.toctree-l11>a{padding:.4045em 1.618em .4045em 16.989em}.wy-menu-vertical li.toctree-l2.current>a,.wy-menu-vertical li.toctree-l2.current li.toctree-l3>a{background:#c9c9c9}.wy-menu-vertical li.toctree-l2 button.toctree-expand{color:#a3a3a3}.wy-menu-vertical li.toctree-l3.current>a,.wy-menu-vertical li.toctree-l3.current li.toctree-l4>a{background:#bdbdbd}.wy-menu-vertical li.toctree-l3 button.toctree-expand{color:#969696}.wy-menu-vertical li.current ul{display:block}.wy-menu-vertical li ul{margin-bottom:0;display:none}.wy-menu-vertical li ul li a{margin-bottom:0;color:#d9d9d9;font-weight:400}.wy-menu-vertical a{line-height:18px;padding:.4045em 1.618em;display:block;position:relative;font-size:90%;color:#d9d9d9}.wy-menu-vertical a:hover{background-color:#4e4a4a;cursor:pointer}.wy-menu-vertical a:hover button.toctree-expand{color:#d9d9d9}.wy-menu-vertical a:active{background-color:#2980b9;cursor:pointer;color:#fff}.wy-menu-vertical a:active button.toctree-expand{color:#fff}.wy-side-nav-search{display:block;width:300px;padding:.809em;margin-bottom:.809em;z-index:200;background-color:#2980b9;text-align:center;color:#fcfcfc}.wy-side-nav-search input[type=text]{width:100%;border-radius:50px;padding:6px 12px;border-color:#2472a4}.wy-side-nav-search img{display:block;margin:auto auto .809em;height:45px;width:45px;background-color:#2980b9;padding:5px;border-radius:100%}.wy-side-nav-search .wy-dropdown>a,.wy-side-nav-search>a{color:#fcfcfc;font-size:100%;font-weight:700;display:inline-block;padding:4px 6px;margin-bottom:.809em;max-width:100%}.wy-side-nav-search .wy-dropdown>a:hover,.wy-side-nav-search .wy-dropdown>aactive,.wy-side-nav-search .wy-dropdown>afocus,.wy-side-nav-search>a:hover,.wy-side-nav-search>aactive,.wy-side-nav-search>afocus{background:hsla(0,0%,100%,.1)}.wy-side-nav-search .wy-dropdown>a img.logo,.wy-side-nav-search>a img.logo{display:block;margin:0 auto;height:auto;width:auto;border-radius:0;max-width:100%;background:transparent}.wy-side-nav-search .wy-dropdown>a.icon,.wy-side-nav-search>a.icon{display:block}.wy-side-nav-search .wy-dropdown>a.icon img.logo,.wy-side-nav-search>a.icon img.logo{margin-top:.85em}.wy-side-nav-search>div.switch-menus{position:relative;display:block;margin-top:-.4045em;margin-bottom:.809em;font-weight:400;color:hsla(0,0%,100%,.3)}.wy-side-nav-search>div.switch-menus>div.language-switch,.wy-side-nav-search>div.switch-menus>div.version-switch{display:inline-block;padding:.2em}.wy-side-nav-search>div.switch-menus>div.language-switch select,.wy-side-nav-search>div.switch-menus>div.version-switch select{display:inline-block;margin-right:-2rem;padding-right:2rem;max-width:240px;text-align-last:center;background:none;border:none;border-radius:0;box-shadow:none;font-family:Lato,proxima-nova,Helvetica Neue,Arial,sans-serif;font-size:1em;font-weight:400;color:hsla(0,0%,100%,.3);cursor:pointer;appearance:none;-webkit-appearance:none;-moz-appearance:none}.wy-side-nav-search>div.switch-menus>div.language-switch select:active,.wy-side-nav-search>div.switch-menus>div.language-switch select:focus,.wy-side-nav-search>div.switch-menus>div.language-switch select:hover,.wy-side-nav-search>div.switch-menus>div.version-switch select:active,.wy-side-nav-search>div.switch-menus>div.version-switch select:focus,.wy-side-nav-search>div.switch-menus>div.version-switch select:hover{background:hsla(0,0%,100%,.1);color:hsla(0,0%,100%,.5)}.wy-side-nav-search>div.switch-menus>div.language-switch select option,.wy-side-nav-search>div.switch-menus>div.version-switch select option{color:#000}.wy-side-nav-search>div.switch-menus>div.language-switch:has(>select):after,.wy-side-nav-search>div.switch-menus>div.version-switch:has(>select):after{display:inline-block;width:1.5em;height:100%;padding:.1em;content:"\f0d7";font-size:1em;line-height:1.2em;font-family:FontAwesome;text-align:center;pointer-events:none;box-sizing:border-box}.wy-nav .wy-menu-vertical header{color:#2980b9}.wy-nav .wy-menu-vertical a{color:#b3b3b3}.wy-nav .wy-menu-vertical a:hover{background-color:#2980b9;color:#fff}[data-menu-wrap]{-webkit-transition:all .2s ease-in;-moz-transition:all .2s ease-in;transition:all .2s ease-in;position:absolute;opacity:1;width:100%;opacity:0}[data-menu-wrap].move-center{left:0;right:auto;opacity:1}[data-menu-wrap].move-left{right:auto;left:-100%;opacity:0}[data-menu-wrap].move-right{right:-100%;left:auto;opacity:0}.wy-body-for-nav{background:#fcfcfc}.wy-grid-for-nav{position:absolute;width:100%;height:100%}.wy-nav-side{position:fixed;top:0;bottom:0;left:0;padding-bottom:2em;width:300px;overflow-x:hidden;overflow-y:hidden;min-height:100%;color:#9b9b9b;background:#343131;z-index:200}.wy-side-scroll{width:320px;position:relative;overflow-x:hidden;overflow-y:scroll;height:100%}.wy-nav-top{display:none;background:#2980b9;color:#fff;padding:.4045em .809em;position:relative;line-height:50px;text-align:center;font-size:100%;*zoom:1}.wy-nav-top:after,.wy-nav-top:before{display:table;content:""}.wy-nav-top:after{clear:both}.wy-nav-top a{color:#fff;font-weight:700}.wy-nav-top img{margin-right:12px;height:45px;width:45px;background-color:#2980b9;padding:5px;border-radius:100%}.wy-nav-top i{font-size:30px;float:left;cursor:pointer;padding-top:inherit}.wy-nav-content-wrap{margin-left:300px;background:#fcfcfc;min-height:100%}.wy-nav-content{padding:1.618em 3.236em;height:100%;max-width:800px;margin:auto}.wy-body-mask{position:fixed;width:100%;height:100%;background:rgba(0,0,0,.2);display:none;z-index:499}.wy-body-mask.on{display:block}footer{color:grey}footer p{margin-bottom:12px}.rst-content footer span.commit tt,footer span.commit .rst-content tt,footer span.commit code{padding:0;font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,Courier,monospace;font-size:1em;background:none;border:none;color:grey}.rst-footer-buttons{*zoom:1}.rst-footer-buttons:after,.rst-footer-buttons:before{width:100%;display:table;content:""}.rst-footer-buttons:after{clear:both}.rst-breadcrumbs-buttons{margin-top:12px;*zoom:1}.rst-breadcrumbs-buttons:after,.rst-breadcrumbs-buttons:before{display:table;content:""}.rst-breadcrumbs-buttons:after{clear:both}#search-results .search li{margin-bottom:24px;border-bottom:1px solid #e1e4e5;padding-bottom:24px}#search-results .search li:first-child{border-top:1px solid #e1e4e5;padding-top:24px}#search-results .search li a{font-size:120%;margin-bottom:12px;display:inline-block}#search-results .context{color:grey;font-size:90%}.genindextable li>ul{margin-left:24px}@media screen and (max-width:768px){.wy-body-for-nav{background:#fcfcfc}.wy-nav-top{display:block}.wy-nav-side{left:-300px}.wy-nav-side.shift{width:85%;left:0}.wy-menu.wy-menu-vertical,.wy-side-nav-search,.wy-side-scroll{width:auto}.wy-nav-content-wrap{margin-left:0}.wy-nav-content-wrap .wy-nav-content{padding:1.618em}.wy-nav-content-wrap.shift{position:fixed;min-width:100%;left:85%;top:0;height:100%;overflow:hidden}}@media screen and (min-width:1100px){.wy-nav-content-wrap{background:rgba(0,0,0,.05)}.wy-nav-content{margin:0;background:#fcfcfc}}@media print{.rst-versions,.wy-nav-side,footer{display:none}.wy-nav-content-wrap{margin-left:0}}.rst-versions{position:fixed;bottom:0;left:0;width:300px;color:#fcfcfc;background:#1f1d1d;font-family:Lato,proxima-nova,Helvetica Neue,Arial,sans-serif;z-index:400}.rst-versions a{color:#2980b9;text-decoration:none}.rst-versions .rst-badge-small{display:none}.rst-versions .rst-current-version{padding:12px;background-color:#272525;display:block;text-align:right;font-size:90%;cursor:pointer;color:#27ae60;*zoom:1}.rst-versions .rst-current-version:after,.rst-versions .rst-current-version:before{display:table;content:""}.rst-versions .rst-current-version:after{clear:both}.rst-content .code-block-caption .rst-versions .rst-current-version .headerlink,.rst-content .eqno .rst-versions .rst-current-version .headerlink,.rst-content .rst-versions .rst-current-version .admonition-title,.rst-content code.download .rst-versions .rst-current-version span:first-child,.rst-content dl dt .rst-versions .rst-current-version .headerlink,.rst-content h1 .rst-versions .rst-current-version .headerlink,.rst-content h2 .rst-versions .rst-current-version .headerlink,.rst-content h3 .rst-versions .rst-current-version .headerlink,.rst-content h4 .rst-versions .rst-current-version .headerlink,.rst-content h5 .rst-versions .rst-current-version .headerlink,.rst-content h6 .rst-versions .rst-current-version .headerlink,.rst-content p .rst-versions .rst-current-version .headerlink,.rst-content table>caption .rst-versions .rst-current-version .headerlink,.rst-content tt.download .rst-versions .rst-current-version span:first-child,.rst-versions .rst-current-version .fa,.rst-versions .rst-current-version .icon,.rst-versions .rst-current-version .rst-content .admonition-title,.rst-versions .rst-current-version .rst-content .code-block-caption .headerlink,.rst-versions .rst-current-version .rst-content .eqno .headerlink,.rst-versions .rst-current-version .rst-content code.download span:first-child,.rst-versions .rst-current-version .rst-content dl dt .headerlink,.rst-versions .rst-current-version .rst-content h1 .headerlink,.rst-versions .rst-current-version .rst-content h2 .headerlink,.rst-versions .rst-current-version .rst-content h3 .headerlink,.rst-versions .rst-current-version .rst-content h4 .headerlink,.rst-versions .rst-current-version .rst-content h5 .headerlink,.rst-versions .rst-current-version .rst-content h6 .headerlink,.rst-versions .rst-current-version .rst-content p .headerlink,.rst-versions .rst-current-version .rst-content table>caption .headerlink,.rst-versions .rst-current-version .rst-content tt.download span:first-child,.rst-versions .rst-current-version .wy-menu-vertical li button.toctree-expand,.wy-menu-vertical li .rst-versions .rst-current-version button.toctree-expand{color:#fcfcfc}.rst-versions .rst-current-version .fa-book,.rst-versions .rst-current-version .icon-book{float:left}.rst-versions .rst-current-version.rst-out-of-date{background-color:#e74c3c;color:#fff}.rst-versions .rst-current-version.rst-active-old-version{background-color:#f1c40f;color:#000}.rst-versions.shift-up{height:auto;max-height:100%;overflow-y:scroll}.rst-versions.shift-up .rst-other-versions{display:block}.rst-versions .rst-other-versions{font-size:90%;padding:12px;color:grey;display:none}.rst-versions .rst-other-versions hr{display:block;height:1px;border:0;margin:20px 0;padding:0;border-top:1px solid #413d3d}.rst-versions .rst-other-versions dd{display:inline-block;margin:0}.rst-versions .rst-other-versions dd a{display:inline-block;padding:6px;color:#fcfcfc}.rst-versions .rst-other-versions .rtd-current-item{font-weight:700}.rst-versions.rst-badge{width:auto;bottom:20px;right:20px;left:auto;border:none;max-width:300px;max-height:90%}.rst-versions.rst-badge .fa-book,.rst-versions.rst-badge .icon-book{float:none;line-height:30px}.rst-versions.rst-badge.shift-up .rst-current-version{text-align:right}.rst-versions.rst-badge.shift-up .rst-current-version .fa-book,.rst-versions.rst-badge.shift-up .rst-current-version .icon-book{float:left}.rst-versions.rst-badge>.rst-current-version{width:auto;height:30px;line-height:30px;padding:0 6px;display:block;text-align:center}@media screen and (max-width:768px){.rst-versions{width:85%;display:none}.rst-versions.shift{display:block}}#flyout-search-form{padding:6px}.rst-content .toctree-wrapper>p.caption,.rst-content h1,.rst-content h2,.rst-content h3,.rst-content h4,.rst-content h5,.rst-content h6{margin-bottom:24px}.rst-content img{max-width:100%;height:auto}.rst-content div.figure,.rst-content figure{margin-bottom:24px}.rst-content div.figure .caption-text,.rst-content figure .caption-text{font-style:italic}.rst-content div.figure p:last-child.caption,.rst-content figure p:last-child.caption{margin-bottom:0}.rst-content div.figure.align-center,.rst-content figure.align-center{text-align:center}.rst-content .section>a>img,.rst-content .section>img,.rst-content section>a>img,.rst-content section>img{margin-bottom:24px}.rst-content abbr[title]{text-decoration:none}.rst-content.style-external-links a.reference.external:after{font-family:FontAwesome;content:"\f08e";color:#b3b3b3;vertical-align:super;font-size:60%;margin:0 .2em}.rst-content blockquote{margin-left:24px;line-height:24px;margin-bottom:24px}.rst-content pre.literal-block{white-space:pre;margin:0;padding:12px;font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,Courier,monospace;display:block;overflow:auto}.rst-content div[class^=highlight],.rst-content pre.literal-block{border:1px solid #e1e4e5;overflow-x:auto;margin:1px 0 24px}.rst-content div[class^=highlight] div[class^=highlight],.rst-content pre.literal-block div[class^=highlight]{padding:0;border:none;margin:0}.rst-content div[class^=highlight] td.code{width:100%}.rst-content .linenodiv pre{border-right:1px solid #e6e9ea;margin:0;padding:12px;font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,Courier,monospace;user-select:none;pointer-events:none}.rst-content div[class^=highlight] pre{white-space:pre;margin:0;padding:12px;display:block;overflow:auto}.rst-content div[class^=highlight] pre .hll{display:block;margin:0 -12px;padding:0 12px}.rst-content .linenodiv pre,.rst-content div[class^=highlight] pre,.rst-content pre.literal-block{font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,Courier,monospace;font-size:12px;line-height:1.4}.rst-content div.highlight .gp,.rst-content div.highlight span.linenos{user-select:none;pointer-events:none}.rst-content div.highlight span.linenos{display:inline-block;padding-left:0;padding-right:12px;margin-right:12px;border-right:1px solid #e6e9ea}.rst-content .code-block-caption{font-style:italic;font-size:85%;line-height:1;padding:1em 0;text-align:center}@media print{.rst-content .codeblock,.rst-content div[class^=highlight],.rst-content div[class^=highlight] pre{white-space:pre-wrap}}.rst-content .admonition,.rst-content .admonition-todo,.rst-content .attention,.rst-content .caution,.rst-content .danger,.rst-content .error,.rst-content .hint,.rst-content .important,.rst-content .note,.rst-content .seealso,.rst-content .tip,.rst-content .warning{clear:both}.rst-content .admonition-todo .last,.rst-content .admonition-todo>:last-child,.rst-content .admonition .last,.rst-content .admonition>:last-child,.rst-content .attention .last,.rst-content .attention>:last-child,.rst-content .caution .last,.rst-content .caution>:last-child,.rst-content .danger .last,.rst-content .danger>:last-child,.rst-content .error .last,.rst-content .error>:last-child,.rst-content .hint .last,.rst-content .hint>:last-child,.rst-content .important .last,.rst-content .important>:last-child,.rst-content .note .last,.rst-content .note>:last-child,.rst-content .seealso .last,.rst-content .seealso>:last-child,.rst-content .tip .last,.rst-content .tip>:last-child,.rst-content .warning .last,.rst-content .warning>:last-child{margin-bottom:0}.rst-content .admonition-title:before{margin-right:4px}.rst-content .admonition table{border-color:rgba(0,0,0,.1)}.rst-content .admonition table td,.rst-content .admonition table th{background:transparent!important;border-color:rgba(0,0,0,.1)!important}.rst-content .section ol.loweralpha,.rst-content .section ol.loweralpha>li,.rst-content .toctree-wrapper ol.loweralpha,.rst-content .toctree-wrapper ol.loweralpha>li,.rst-content section ol.loweralpha,.rst-content section ol.loweralpha>li{list-style:lower-alpha}.rst-content .section ol.upperalpha,.rst-content .section ol.upperalpha>li,.rst-content .toctree-wrapper ol.upperalpha,.rst-content .toctree-wrapper ol.upperalpha>li,.rst-content section ol.upperalpha,.rst-content section ol.upperalpha>li{list-style:upper-alpha}.rst-content .section ol li>*,.rst-content .section ul li>*,.rst-content .toctree-wrapper ol li>*,.rst-content .toctree-wrapper ul li>*,.rst-content section ol li>*,.rst-content section ul li>*{margin-top:12px;margin-bottom:12px}.rst-content .section ol li>:first-child,.rst-content .section ul li>:first-child,.rst-content .toctree-wrapper ol li>:first-child,.rst-content .toctree-wrapper ul li>:first-child,.rst-content section ol li>:first-child,.rst-content section ul li>:first-child{margin-top:0}.rst-content .section ol li>p,.rst-content .section ol li>p:last-child,.rst-content .section ul li>p,.rst-content .section ul li>p:last-child,.rst-content .toctree-wrapper ol li>p,.rst-content .toctree-wrapper ol li>p:last-child,.rst-content .toctree-wrapper ul li>p,.rst-content .toctree-wrapper ul li>p:last-child,.rst-content section ol li>p,.rst-content section ol li>p:last-child,.rst-content section ul li>p,.rst-content section ul li>p:last-child{margin-bottom:12px}.rst-content .section ol li>p:only-child,.rst-content .section ol li>p:only-child:last-child,.rst-content .section ul li>p:only-child,.rst-content .section ul li>p:only-child:last-child,.rst-content .toctree-wrapper ol li>p:only-child,.rst-content .toctree-wrapper ol li>p:only-child:last-child,.rst-content .toctree-wrapper ul li>p:only-child,.rst-content .toctree-wrapper ul li>p:only-child:last-child,.rst-content section ol li>p:only-child,.rst-content section ol li>p:only-child:last-child,.rst-content section ul li>p:only-child,.rst-content section ul li>p:only-child:last-child{margin-bottom:0}.rst-content .section ol li>ol,.rst-content .section ol li>ul,.rst-content .section ul li>ol,.rst-content .section ul li>ul,.rst-content .toctree-wrapper ol li>ol,.rst-content .toctree-wrapper ol li>ul,.rst-content .toctree-wrapper ul li>ol,.rst-content .toctree-wrapper ul li>ul,.rst-content section ol li>ol,.rst-content section ol li>ul,.rst-content section ul li>ol,.rst-content section ul li>ul{margin-bottom:12px}.rst-content .section ol.simple li>*,.rst-content .section ol.simple li ol,.rst-content .section ol.simple li ul,.rst-content .section ul.simple li>*,.rst-content .section ul.simple li ol,.rst-content .section ul.simple li ul,.rst-content .toctree-wrapper ol.simple li>*,.rst-content .toctree-wrapper ol.simple li ol,.rst-content .toctree-wrapper ol.simple li ul,.rst-content .toctree-wrapper ul.simple li>*,.rst-content .toctree-wrapper ul.simple li ol,.rst-content .toctree-wrapper ul.simple li ul,.rst-content section ol.simple li>*,.rst-content section ol.simple li ol,.rst-content section ol.simple li ul,.rst-content section ul.simple li>*,.rst-content section ul.simple li ol,.rst-content section ul.simple li ul{margin-top:0;margin-bottom:0}.rst-content .line-block{margin-left:0;margin-bottom:24px;line-height:24px}.rst-content .line-block .line-block{margin-left:24px;margin-bottom:0}.rst-content .topic-title{font-weight:700;margin-bottom:12px}.rst-content .toc-backref{color:#404040}.rst-content .align-right{float:right;margin:0 0 24px 24px}.rst-content .align-left{float:left;margin:0 24px 24px 0}.rst-content .align-center{margin:auto}.rst-content .align-center:not(table){display:block}.rst-content .code-block-caption .headerlink,.rst-content .eqno .headerlink,.rst-content .toctree-wrapper>p.caption .headerlink,.rst-content dl dt .headerlink,.rst-content h1 .headerlink,.rst-content h2 .headerlink,.rst-content h3 .headerlink,.rst-content h4 .headerlink,.rst-content h5 .headerlink,.rst-content h6 .headerlink,.rst-content p.caption .headerlink,.rst-content p .headerlink,.rst-content table>caption .headerlink{opacity:0;font-size:14px;font-family:FontAwesome;margin-left:.5em}.rst-content .code-block-caption .headerlink:focus,.rst-content .code-block-caption:hover .headerlink,.rst-content .eqno .headerlink:focus,.rst-content .eqno:hover .headerlink,.rst-content .toctree-wrapper>p.caption .headerlink:focus,.rst-content .toctree-wrapper>p.caption:hover .headerlink,.rst-content dl dt .headerlink:focus,.rst-content dl dt:hover .headerlink,.rst-content h1 .headerlink:focus,.rst-content h1:hover .headerlink,.rst-content h2 .headerlink:focus,.rst-content h2:hover .headerlink,.rst-content h3 .headerlink:focus,.rst-content h3:hover .headerlink,.rst-content h4 .headerlink:focus,.rst-content h4:hover .headerlink,.rst-content h5 .headerlink:focus,.rst-content h5:hover .headerlink,.rst-content h6 .headerlink:focus,.rst-content h6:hover .headerlink,.rst-content p.caption .headerlink:focus,.rst-content p.caption:hover .headerlink,.rst-content p .headerlink:focus,.rst-content p:hover .headerlink,.rst-content table>caption .headerlink:focus,.rst-content table>caption:hover .headerlink{opacity:1}.rst-content p a{overflow-wrap:anywhere}.rst-content .wy-table td p,.rst-content .wy-table td ul,.rst-content .wy-table th p,.rst-content .wy-table th ul,.rst-content table.docutils td p,.rst-content table.docutils td ul,.rst-content table.docutils th p,.rst-content table.docutils th ul,.rst-content table.field-list td p,.rst-content table.field-list td ul,.rst-content table.field-list th p,.rst-content table.field-list th ul{font-size:inherit}.rst-content .btn:focus{outline:2px solid}.rst-content table>caption .headerlink:after{font-size:12px}.rst-content .centered{text-align:center}.rst-content .sidebar{float:right;width:40%;display:block;margin:0 0 24px 24px;padding:24px;background:#f3f6f6;border:1px solid #e1e4e5}.rst-content .sidebar dl,.rst-content .sidebar p,.rst-content .sidebar ul{font-size:90%}.rst-content .sidebar .last,.rst-content .sidebar>:last-child{margin-bottom:0}.rst-content .sidebar .sidebar-title{display:block;font-family:Roboto Slab,ff-tisa-web-pro,Georgia,Arial,sans-serif;font-weight:700;background:#e1e4e5;padding:6px 12px;margin:-24px -24px 24px;font-size:100%}.rst-content .highlighted{background:#f1c40f;box-shadow:0 0 0 2px #f1c40f;display:inline;font-weight:700}.rst-content .citation-reference,.rst-content .footnote-reference{vertical-align:baseline;position:relative;top:-.4em;line-height:0;font-size:90%}.rst-content .citation-reference>span.fn-bracket,.rst-content .footnote-reference>span.fn-bracket{display:none}.rst-content .hlist{width:100%}.rst-content dl dt span.classifier:before{content:" : "}.rst-content dl dt span.classifier-delimiter{display:none!important}html.writer-html4 .rst-content table.docutils.citation,html.writer-html4 .rst-content table.docutils.footnote{background:none;border:none}html.writer-html4 .rst-content table.docutils.citation td,html.writer-html4 .rst-content table.docutils.citation tr,html.writer-html4 .rst-content table.docutils.footnote td,html.writer-html4 .rst-content table.docutils.footnote tr{border:none;background-color:transparent!important;white-space:normal}html.writer-html4 .rst-content table.docutils.citation td.label,html.writer-html4 .rst-content table.docutils.footnote td.label{padding-left:0;padding-right:0;vertical-align:top}html.writer-html5 .rst-content dl.citation,html.writer-html5 .rst-content dl.field-list,html.writer-html5 .rst-content dl.footnote{display:grid;grid-template-columns:auto minmax(80%,95%)}html.writer-html5 .rst-content dl.citation>dt,html.writer-html5 .rst-content dl.field-list>dt,html.writer-html5 .rst-content dl.footnote>dt{display:inline-grid;grid-template-columns:max-content auto}html.writer-html5 .rst-content aside.citation,html.writer-html5 .rst-content aside.footnote,html.writer-html5 .rst-content div.citation{display:grid;grid-template-columns:auto auto minmax(.65rem,auto) minmax(40%,95%)}html.writer-html5 .rst-content aside.citation>span.label,html.writer-html5 .rst-content aside.footnote>span.label,html.writer-html5 .rst-content div.citation>span.label{grid-column-start:1;grid-column-end:2}html.writer-html5 .rst-content aside.citation>span.backrefs,html.writer-html5 .rst-content aside.footnote>span.backrefs,html.writer-html5 .rst-content div.citation>span.backrefs{grid-column-start:2;grid-column-end:3;grid-row-start:1;grid-row-end:3}html.writer-html5 .rst-content aside.citation>p,html.writer-html5 .rst-content aside.footnote>p,html.writer-html5 .rst-content div.citation>p{grid-column-start:4;grid-column-end:5}html.writer-html5 .rst-content dl.citation,html.writer-html5 .rst-content dl.field-list,html.writer-html5 .rst-content dl.footnote{margin-bottom:24px}html.writer-html5 .rst-content dl.citation>dt,html.writer-html5 .rst-content dl.field-list>dt,html.writer-html5 .rst-content dl.footnote>dt{padding-left:1rem}html.writer-html5 .rst-content dl.citation>dd,html.writer-html5 .rst-content dl.citation>dt,html.writer-html5 .rst-content dl.field-list>dd,html.writer-html5 .rst-content dl.field-list>dt,html.writer-html5 .rst-content dl.footnote>dd,html.writer-html5 .rst-content dl.footnote>dt{margin-bottom:0}html.writer-html5 .rst-content dl.citation,html.writer-html5 .rst-content dl.footnote{font-size:.9rem}html.writer-html5 .rst-content dl.citation>dt,html.writer-html5 .rst-content dl.footnote>dt{margin:0 .5rem .5rem 0;line-height:1.2rem;word-break:break-all;font-weight:400}html.writer-html5 .rst-content dl.citation>dt>span.brackets:before,html.writer-html5 .rst-content dl.footnote>dt>span.brackets:before{content:"["}html.writer-html5 .rst-content dl.citation>dt>span.brackets:after,html.writer-html5 .rst-content dl.footnote>dt>span.brackets:after{content:"]"}html.writer-html5 .rst-content dl.citation>dt>span.fn-backref,html.writer-html5 .rst-content dl.footnote>dt>span.fn-backref{text-align:left;font-style:italic;margin-left:.65rem;word-break:break-word;word-spacing:-.1rem;max-width:5rem}html.writer-html5 .rst-content dl.citation>dt>span.fn-backref>a,html.writer-html5 .rst-content dl.footnote>dt>span.fn-backref>a{word-break:keep-all}html.writer-html5 .rst-content dl.citation>dt>span.fn-backref>a:not(:first-child):before,html.writer-html5 .rst-content dl.footnote>dt>span.fn-backref>a:not(:first-child):before{content:" "}html.writer-html5 .rst-content dl.citation>dd,html.writer-html5 .rst-content dl.footnote>dd{margin:0 0 .5rem;line-height:1.2rem}html.writer-html5 .rst-content dl.citation>dd p,html.writer-html5 .rst-content dl.footnote>dd p{font-size:.9rem}html.writer-html5 .rst-content aside.citation,html.writer-html5 .rst-content aside.footnote,html.writer-html5 .rst-content div.citation{padding-left:1rem;padding-right:1rem;font-size:.9rem;line-height:1.2rem}html.writer-html5 .rst-content aside.citation p,html.writer-html5 .rst-content aside.footnote p,html.writer-html5 .rst-content div.citation p{font-size:.9rem;line-height:1.2rem;margin-bottom:12px}html.writer-html5 .rst-content aside.citation span.backrefs,html.writer-html5 .rst-content aside.footnote span.backrefs,html.writer-html5 .rst-content div.citation span.backrefs{text-align:left;font-style:italic;margin-left:.65rem;word-break:break-word;word-spacing:-.1rem;max-width:5rem}html.writer-html5 .rst-content aside.citation span.backrefs>a,html.writer-html5 .rst-content aside.footnote span.backrefs>a,html.writer-html5 .rst-content div.citation span.backrefs>a{word-break:keep-all}html.writer-html5 .rst-content aside.citation span.backrefs>a:not(:first-child):before,html.writer-html5 .rst-content aside.footnote span.backrefs>a:not(:first-child):before,html.writer-html5 .rst-content div.citation span.backrefs>a:not(:first-child):before{content:" "}html.writer-html5 .rst-content aside.citation span.label,html.writer-html5 .rst-content aside.footnote span.label,html.writer-html5 .rst-content div.citation span.label{line-height:1.2rem}html.writer-html5 .rst-content aside.citation-list,html.writer-html5 .rst-content aside.footnote-list,html.writer-html5 .rst-content div.citation-list{margin-bottom:24px}html.writer-html5 .rst-content dl.option-list kbd{font-size:.9rem}.rst-content table.docutils.footnote,html.writer-html4 .rst-content table.docutils.citation,html.writer-html5 .rst-content aside.footnote,html.writer-html5 .rst-content aside.footnote-list aside.footnote,html.writer-html5 .rst-content div.citation-list>div.citation,html.writer-html5 .rst-content dl.citation,html.writer-html5 .rst-content dl.footnote{color:grey}.rst-content table.docutils.footnote code,.rst-content table.docutils.footnote tt,html.writer-html4 .rst-content table.docutils.citation code,html.writer-html4 .rst-content table.docutils.citation tt,html.writer-html5 .rst-content aside.footnote-list aside.footnote code,html.writer-html5 .rst-content aside.footnote-list aside.footnote tt,html.writer-html5 .rst-content aside.footnote code,html.writer-html5 .rst-content aside.footnote tt,html.writer-html5 .rst-content div.citation-list>div.citation code,html.writer-html5 .rst-content div.citation-list>div.citation tt,html.writer-html5 .rst-content dl.citation code,html.writer-html5 .rst-content dl.citation tt,html.writer-html5 .rst-content dl.footnote code,html.writer-html5 .rst-content dl.footnote tt{color:#555}.rst-content .wy-table-responsive.citation,.rst-content .wy-table-responsive.footnote{margin-bottom:0}.rst-content .wy-table-responsive.citation+:not(.citation),.rst-content .wy-table-responsive.footnote+:not(.footnote){margin-top:24px}.rst-content .wy-table-responsive.citation:last-child,.rst-content .wy-table-responsive.footnote:last-child{margin-bottom:24px}.rst-content table.docutils th{border-color:#e1e4e5}html.writer-html5 .rst-content table.docutils th{border:1px solid #e1e4e5}html.writer-html5 .rst-content table.docutils td>p,html.writer-html5 .rst-content table.docutils th>p{line-height:1rem;margin-bottom:0;font-size:.9rem}.rst-content table.docutils td .last,.rst-content table.docutils td .last>:last-child{margin-bottom:0}.rst-content table.field-list,.rst-content table.field-list td{border:none}.rst-content table.field-list td p{line-height:inherit}.rst-content table.field-list td>strong{display:inline-block}.rst-content table.field-list .field-name{padding-right:10px;text-align:left;white-space:nowrap}.rst-content table.field-list .field-body{text-align:left}.rst-content code,.rst-content tt{color:#000;font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,Courier,monospace;padding:2px 5px}.rst-content code big,.rst-content code em,.rst-content tt big,.rst-content tt em{font-size:100%!important;line-height:normal}.rst-content code.literal,.rst-content tt.literal{color:#e74c3c;white-space:normal}.rst-content code.xref,.rst-content tt.xref,a .rst-content code,a .rst-content tt{font-weight:700;color:#404040;overflow-wrap:normal}.rst-content kbd,.rst-content pre,.rst-content samp{font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,Courier,monospace}.rst-content a code,.rst-content a tt{color:#2980b9}.rst-content dl{margin-bottom:24px}.rst-content dl dt{font-weight:700;margin-bottom:12px}.rst-content dl ol,.rst-content dl p,.rst-content dl table,.rst-content dl ul{margin-bottom:12px}.rst-content dl dd{margin:0 0 12px 24px;line-height:24px}.rst-content dl dd>ol:last-child,.rst-content dl dd>p:last-child,.rst-content dl dd>table:last-child,.rst-content dl dd>ul:last-child{margin-bottom:0}html.writer-html4 .rst-content dl:not(.docutils),html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple){margin-bottom:24px}html.writer-html4 .rst-content dl:not(.docutils)>dt,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt{display:table;margin:6px 0;font-size:90%;line-height:normal;background:#e7f2fa;color:#2980b9;border-top:3px solid #6ab0de;padding:6px;position:relative}html.writer-html4 .rst-content dl:not(.docutils)>dt:before,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt:before{color:#6ab0de}html.writer-html4 .rst-content dl:not(.docutils)>dt .headerlink,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt .headerlink{color:#404040;font-size:100%!important}html.writer-html4 .rst-content dl:not(.docutils) dl:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) dl:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt{margin-bottom:6px;border:none;border-left:3px solid #ccc;background:#f0f0f0;color:#555}html.writer-html4 .rst-content dl:not(.docutils) dl:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt .headerlink,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) dl:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt .headerlink{color:#404040;font-size:100%!important}html.writer-html4 .rst-content dl:not(.docutils)>dt:first-child,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt:first-child{margin-top:0}html.writer-html4 .rst-content dl:not(.docutils) code.descclassname,html.writer-html4 .rst-content dl:not(.docutils) code.descname,html.writer-html4 .rst-content dl:not(.docutils) tt.descclassname,html.writer-html4 .rst-content dl:not(.docutils) tt.descname,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) code.descclassname,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) code.descname,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) tt.descclassname,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) tt.descname{background-color:transparent;border:none;padding:0;font-size:100%!important}html.writer-html4 .rst-content dl:not(.docutils) code.descname,html.writer-html4 .rst-content dl:not(.docutils) tt.descname,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) code.descname,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) tt.descname{font-weight:700}html.writer-html4 .rst-content dl:not(.docutils) .optional,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) .optional{display:inline-block;padding:0 4px;color:#000;font-weight:700}html.writer-html4 .rst-content dl:not(.docutils) .property,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) .property{display:inline-block;padding-right:8px;max-width:100%}html.writer-html4 .rst-content dl:not(.docutils) .k,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) .k{font-style:italic}html.writer-html4 .rst-content dl:not(.docutils) .descclassname,html.writer-html4 .rst-content dl:not(.docutils) .descname,html.writer-html4 .rst-content dl:not(.docutils) .sig-name,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) .descclassname,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) .descname,html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple) .sig-name{font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,Courier,monospace;color:#000}.rst-content .viewcode-back,.rst-content .viewcode-link{display:inline-block;color:#27ae60;font-size:80%;padding-left:24px}.rst-content .viewcode-back{display:block;float:right}.rst-content p.rubric{margin-bottom:12px;font-weight:700}.rst-content code.download,.rst-content tt.download{background:inherit;padding:inherit;font-weight:400;font-family:inherit;font-size:inherit;color:inherit;border:inherit;white-space:inherit}.rst-content code.download span:first-child,.rst-content tt.download span:first-child{-webkit-font-smoothing:subpixel-antialiased}.rst-content code.download span:first-child:before,.rst-content tt.download span:first-child:before{margin-right:4px}.rst-content .guilabel,.rst-content .menuselection{font-size:80%;font-weight:700;border-radius:4px;padding:2.4px 6px;margin:auto 2px}.rst-content .guilabel,.rst-content .menuselection{border:1px solid #7fbbe3;background:#e7f2fa}.rst-content :not(dl.option-list)>:not(dt):not(kbd):not(.kbd)>.kbd,.rst-content :not(dl.option-list)>:not(dt):not(kbd):not(.kbd)>kbd{color:inherit;font-size:80%;background-color:#fff;border:1px solid #a6a6a6;border-radius:4px;box-shadow:0 2px grey;padding:2.4px 6px;margin:auto 0}.rst-content .versionmodified{font-style:italic}@media screen and (max-width:480px){.rst-content .sidebar{width:100%}}span[id*=MathJax-Span]{color:#404040}.math{text-align:center}@font-face{font-family:Lato;src:url(fonts/lato-normal.woff2?bd03a2cc277bbbc338d464e679fe9942) format("woff2"),url(fonts/lato-normal.woff?27bd77b9162d388cb8d4c4217c7c5e2a) format("woff");font-weight:400;font-style:normal;font-display:block}@font-face{font-family:Lato;src:url(fonts/lato-bold.woff2?cccb897485813c7c256901dbca54ecf2) format("woff2"),url(fonts/lato-bold.woff?d878b6c29b10beca227e9eef4246111b) format("woff");font-weight:700;font-style:normal;font-display:block}@font-face{font-family:Lato;src:url(fonts/lato-bold-italic.woff2?0b6bb6725576b072c5d0b02ecdd1900d) format("woff2"),url(fonts/lato-bold-italic.woff?9c7e4e9eb485b4a121c760e61bc3707c) format("woff");font-weight:700;font-style:italic;font-display:block}@font-face{font-family:Lato;src:url(fonts/lato-normal-italic.woff2?4eb103b4d12be57cb1d040ed5e162e9d) format("woff2"),url(fonts/lato-normal-italic.woff?f28f2d6482446544ef1ea1ccc6dd5892) format("woff");font-weight:400;font-style:italic;font-display:block}@font-face{font-family:Roboto Slab;font-style:normal;font-weight:400;src:url(fonts/Roboto-Slab-Regular.woff2?7abf5b8d04d26a2cafea937019bca958) format("woff2"),url(fonts/Roboto-Slab-Regular.woff?c1be9284088d487c5e3ff0a10a92e58c) format("woff");font-display:block}@font-face{font-family:Roboto Slab;font-style:normal;font-weight:700;src:url(fonts/Roboto-Slab-Bold.woff2?9984f4a9bda09be08e83f2506954adbe) format("woff2"),url(fonts/Roboto-Slab-Bold.woff?bed5564a116b05148e3b3bea6fb1162a) format("woff");font-display:block} \ No newline at end of file diff --git a/tag/3.5.0/_static/doctools.js b/tag/3.5.0/_static/doctools.js new file mode 100644 index 0000000..0398ebb --- /dev/null +++ b/tag/3.5.0/_static/doctools.js @@ -0,0 +1,149 @@ +/* + * Base JavaScript utilities for all Sphinx HTML documentation. + */ +"use strict"; + +const BLACKLISTED_KEY_CONTROL_ELEMENTS = new Set([ + "TEXTAREA", + "INPUT", + "SELECT", + "BUTTON", +]); + +const _ready = (callback) => { + if (document.readyState !== "loading") { + callback(); + } else { + document.addEventListener("DOMContentLoaded", callback); + } +}; + +/** + * Small JavaScript module for the documentation. + */ +const Documentation = { + init: () => { + Documentation.initDomainIndexTable(); + Documentation.initOnKeyListeners(); + }, + + /** + * i18n support + */ + TRANSLATIONS: {}, + PLURAL_EXPR: (n) => (n === 1 ? 0 : 1), + LOCALE: "unknown", + + // gettext and ngettext don't access this so that the functions + // can safely bound to a different name (_ = Documentation.gettext) + gettext: (string) => { + const translated = Documentation.TRANSLATIONS[string]; + switch (typeof translated) { + case "undefined": + return string; // no translation + case "string": + return translated; // translation exists + default: + return translated[0]; // (singular, plural) translation tuple exists + } + }, + + ngettext: (singular, plural, n) => { + const translated = Documentation.TRANSLATIONS[singular]; + if (typeof translated !== "undefined") + return translated[Documentation.PLURAL_EXPR(n)]; + return n === 1 ? singular : plural; + }, + + addTranslations: (catalog) => { + Object.assign(Documentation.TRANSLATIONS, catalog.messages); + Documentation.PLURAL_EXPR = new Function( + "n", + `return (${catalog.plural_expr})` + ); + Documentation.LOCALE = catalog.locale; + }, + + /** + * helper function to focus on search bar + */ + focusSearchBar: () => { + document.querySelectorAll("input[name=q]")[0]?.focus(); + }, + + /** + * Initialise the domain index toggle buttons + */ + initDomainIndexTable: () => { + const toggler = (el) => { + const idNumber = el.id.substr(7); + const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`); + if (el.src.substr(-9) === "minus.png") { + el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`; + toggledRows.forEach((el) => (el.style.display = "none")); + } else { + el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`; + toggledRows.forEach((el) => (el.style.display = "")); + } + }; + + const togglerElements = document.querySelectorAll("img.toggler"); + togglerElements.forEach((el) => + el.addEventListener("click", (event) => toggler(event.currentTarget)) + ); + togglerElements.forEach((el) => (el.style.display = "")); + if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler); + }, + + initOnKeyListeners: () => { + // only install a listener if it is really needed + if ( + !DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && + !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS + ) + return; + + document.addEventListener("keydown", (event) => { + // bail for input elements + if (BLACKLISTED_KEY_CONTROL_ELEMENTS.has(document.activeElement.tagName)) return; + // bail with special keys + if (event.altKey || event.ctrlKey || event.metaKey) return; + + if (!event.shiftKey) { + switch (event.key) { + case "ArrowLeft": + if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + + const prevLink = document.querySelector('link[rel="prev"]'); + if (prevLink && prevLink.href) { + window.location.href = prevLink.href; + event.preventDefault(); + } + break; + case "ArrowRight": + if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + + const nextLink = document.querySelector('link[rel="next"]'); + if (nextLink && nextLink.href) { + window.location.href = nextLink.href; + event.preventDefault(); + } + break; + } + } + + // some keyboard layouts may need Shift to get / + switch (event.key) { + case "/": + if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; + Documentation.focusSearchBar(); + event.preventDefault(); + } + }); + }, +}; + +// quick alias for translations +const _ = Documentation.gettext; + +_ready(Documentation.init); diff --git a/tag/3.5.0/_static/documentation_options.js b/tag/3.5.0/_static/documentation_options.js new file mode 100644 index 0000000..1823c1b --- /dev/null +++ b/tag/3.5.0/_static/documentation_options.js @@ -0,0 +1,13 @@ +const DOCUMENTATION_OPTIONS = { + VERSION: '', + LANGUAGE: 'en', + COLLAPSE_INDEX: false, + BUILDER: 'html', + FILE_SUFFIX: '.html', + LINK_SUFFIX: '.html', + HAS_SOURCE: false, + SOURCELINK_SUFFIX: '.txt', + NAVIGATION_WITH_KEYS: false, + SHOW_SEARCH_SUMMARY: true, + ENABLE_SEARCH_SHORTCUTS: true, +}; \ No newline at end of file diff --git a/tag/3.5.0/_static/file.png b/tag/3.5.0/_static/file.png new file mode 100644 index 0000000..a858a41 Binary files /dev/null and b/tag/3.5.0/_static/file.png differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-bold.eot b/tag/3.5.0/_static/fonts/Lato/lato-bold.eot new file mode 100644 index 0000000..3361183 Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-bold.eot differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-bold.ttf b/tag/3.5.0/_static/fonts/Lato/lato-bold.ttf new file mode 100644 index 0000000..29f691d Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-bold.ttf differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-bold.woff b/tag/3.5.0/_static/fonts/Lato/lato-bold.woff new file mode 100644 index 0000000..c6dff51 Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-bold.woff differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-bold.woff2 b/tag/3.5.0/_static/fonts/Lato/lato-bold.woff2 new file mode 100644 index 0000000..bb19504 Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-bold.woff2 differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.eot b/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.eot new file mode 100644 index 0000000..3d41549 Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.eot differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.ttf b/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.ttf new file mode 100644 index 0000000..f402040 Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.ttf differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.woff b/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.woff new file mode 100644 index 0000000..88ad05b Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.woff differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.woff2 b/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.woff2 new file mode 100644 index 0000000..c4e3d80 Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-bolditalic.woff2 differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-italic.eot b/tag/3.5.0/_static/fonts/Lato/lato-italic.eot new file mode 100644 index 0000000..3f82642 Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-italic.eot differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-italic.ttf b/tag/3.5.0/_static/fonts/Lato/lato-italic.ttf new file mode 100644 index 0000000..b4bfc9b Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-italic.ttf differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-italic.woff b/tag/3.5.0/_static/fonts/Lato/lato-italic.woff new file mode 100644 index 0000000..76114bc Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-italic.woff differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-italic.woff2 b/tag/3.5.0/_static/fonts/Lato/lato-italic.woff2 new file mode 100644 index 0000000..3404f37 Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-italic.woff2 differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-regular.eot b/tag/3.5.0/_static/fonts/Lato/lato-regular.eot new file mode 100644 index 0000000..11e3f2a Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-regular.eot differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-regular.ttf b/tag/3.5.0/_static/fonts/Lato/lato-regular.ttf new file mode 100644 index 0000000..74decd9 Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-regular.ttf differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-regular.woff b/tag/3.5.0/_static/fonts/Lato/lato-regular.woff new file mode 100644 index 0000000..ae1307f Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-regular.woff differ diff --git a/tag/3.5.0/_static/fonts/Lato/lato-regular.woff2 b/tag/3.5.0/_static/fonts/Lato/lato-regular.woff2 new file mode 100644 index 0000000..3bf9843 Binary files /dev/null and b/tag/3.5.0/_static/fonts/Lato/lato-regular.woff2 differ diff --git a/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.eot b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.eot new file mode 100644 index 0000000..79dc8ef Binary files /dev/null and b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.eot differ diff --git a/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.ttf b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.ttf new file mode 100644 index 0000000..df5d1df Binary files /dev/null and b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.ttf differ diff --git a/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff new file mode 100644 index 0000000..6cb6000 Binary files /dev/null and b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff differ diff --git a/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff2 b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff2 new file mode 100644 index 0000000..7059e23 Binary files /dev/null and b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-bold.woff2 differ diff --git a/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.eot b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.eot new file mode 100644 index 0000000..2f7ca78 Binary files /dev/null and b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.eot differ diff --git a/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.ttf b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.ttf new file mode 100644 index 0000000..eb52a79 Binary files /dev/null and b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.ttf differ diff --git a/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff new file mode 100644 index 0000000..f815f63 Binary files /dev/null and b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff differ diff --git a/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff2 b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff2 new file mode 100644 index 0000000..f2c76e5 Binary files /dev/null and b/tag/3.5.0/_static/fonts/RobotoSlab/roboto-slab-v7-regular.woff2 differ diff --git a/tag/3.5.0/_static/images/Ansible-Mark-RGB_Black.png b/tag/3.5.0/_static/images/Ansible-Mark-RGB_Black.png new file mode 100644 index 0000000..0b4e721 Binary files /dev/null and b/tag/3.5.0/_static/images/Ansible-Mark-RGB_Black.png differ diff --git a/tag/3.5.0/_static/images/Ansible-Mark-RGB_Black.svg b/tag/3.5.0/_static/images/Ansible-Mark-RGB_Black.svg new file mode 100644 index 0000000..c600b6e --- /dev/null +++ b/tag/3.5.0/_static/images/Ansible-Mark-RGB_Black.svg @@ -0,0 +1,14 @@ + + + diff --git a/tag/3.5.0/_static/images/Ansible-Mark-RGB_White.png b/tag/3.5.0/_static/images/Ansible-Mark-RGB_White.png new file mode 100644 index 0000000..5754701 Binary files /dev/null and b/tag/3.5.0/_static/images/Ansible-Mark-RGB_White.png differ diff --git a/tag/3.5.0/_static/images/Ansible-Mark-RGB_White.svg b/tag/3.5.0/_static/images/Ansible-Mark-RGB_White.svg new file mode 100644 index 0000000..2275aec --- /dev/null +++ b/tag/3.5.0/_static/images/Ansible-Mark-RGB_White.svg @@ -0,0 +1 @@ + diff --git a/tag/3.5.0/_static/jquery.js b/tag/3.5.0/_static/jquery.js new file mode 100644 index 0000000..c4c6022 --- /dev/null +++ b/tag/3.5.0/_static/jquery.js @@ -0,0 +1,2 @@ +/*! jQuery v3.6.0 | (c) OpenJS Foundation and other contributors | jquery.org/license */ +!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.6.0",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},j=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||D,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,D=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="",y.option=!!ce.lastChild;var ge={thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n",""]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d\s*$/g;function je(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function De(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function qe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Le(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var _t,zt=[],Ut=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=zt.pop()||S.expando+"_"+wt.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Ut.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Ut.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Ut,"$1"+r):!1!==e.jsonp&&(e.url+=(Tt.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,zt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((_t=E.implementation.createHTMLDocument("").body).innerHTML="
",2===_t.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=Fe(y.pixelPosition,function(e,t){if(t)return t=We(e,n),Pe.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0"),n("table.docutils.footnote").wrap("
"),n("table.docutils.citation").wrap("
"),n(".wy-menu-vertical ul").not(".simple").siblings("a").each((function(){var t=n(this);expand=n(''),expand.on("click",(function(n){return e.toggleCurrent(t),n.stopPropagation(),!1})),t.prepend(expand)}))},reset:function(){var n=encodeURI(window.location.hash)||"#";try{var e=$(".wy-menu-vertical"),t=e.find('[href="'+n+'"]');if(0===t.length){var i=$('.document [id="'+n.substring(1)+'"]').closest("div.section");0===(t=e.find('[href="#'+i.attr("id")+'"]')).length&&(t=e.find('[href="#"]'))}if(t.length>0){$(".wy-menu-vertical .current").removeClass("current").attr("aria-expanded","false"),t.addClass("current").attr("aria-expanded","true"),t.closest("li.toctree-l1").parent().addClass("current").attr("aria-expanded","true");for(let n=1;n<=10;n++)t.closest("li.toctree-l"+n).addClass("current").attr("aria-expanded","true");t[0].scrollIntoView()}}catch(n){console.log("Error expanding nav for anchor",n)}},onScroll:function(){this.winScroll=!1;var n=this.win.scrollTop(),e=n+this.winHeight,t=this.navBar.scrollTop()+(n-this.winPosition);n<0||e>this.docHeight||(this.navBar.scrollTop(t),this.winPosition=n)},onResize:function(){this.winResize=!1,this.winHeight=this.win.height(),this.docHeight=$(document).height()},hashChange:function(){this.linkScroll=!0,this.win.one("hashchange",(function(){this.linkScroll=!1}))},toggleCurrent:function(n){var e=n.closest("li");e.siblings("li.current").removeClass("current").attr("aria-expanded","false"),e.siblings().find("li.current").removeClass("current").attr("aria-expanded","false");var t=e.find("> ul li");t.length&&(t.removeClass("current").attr("aria-expanded","false"),e.toggleClass("current").attr("aria-expanded",(function(n,e){return"true"==e?"false":"true"})))}},"undefined"!=typeof window&&(window.SphinxRtdTheme={Navigation:n.exports.ThemeNav,StickyNav:n.exports.ThemeNav}),function(){for(var n=0,e=["ms","moz","webkit","o"],t=0;t a.language.name.localeCompare(b.language.name)); + + const languagesHTML = ` +
+
Languages
+ ${languages + .map( + (translation) => ` +
+ ${translation.language.code} +
+ `, + ) + .join("\n")} +
+ `; + return languagesHTML; + } + + function renderVersions(config) { + if (!config.versions.active.length) { + return ""; + } + const versionsHTML = ` +
+
Versions
+ ${config.versions.active + .map( + (version) => ` +
+ ${version.slug} +
+ `, + ) + .join("\n")} +
+ `; + return versionsHTML; + } + + function renderDownloads(config) { + if (!Object.keys(config.versions.current.downloads).length) { + return ""; + } + const downloadsNameDisplay = { + pdf: "PDF", + epub: "Epub", + htmlzip: "HTML", + }; + + const downloadsHTML = ` +
+
Downloads
+ ${Object.entries(config.versions.current.downloads) + .map( + ([name, url]) => ` +
+ ${downloadsNameDisplay[name]} +
+ `, + ) + .join("\n")} +
+ `; + return downloadsHTML; + } + + document.addEventListener("readthedocs-addons-data-ready", function (event) { + const config = event.detail.data(); + + const flyout = ` +
+ + Read the Docs + v: ${config.versions.current.slug} + + +
+
+ ${renderLanguages(config)} + ${renderVersions(config)} + ${renderDownloads(config)} +
+
On Read the Docs
+
+ Project Home +
+
+ Builds +
+
+ Downloads +
+
+
+
Search
+
+
+ +
+
+
+
+ + Hosted by Read the Docs + +
+
+ `; + + // Inject the generated flyout into the body HTML element. + document.body.insertAdjacentHTML("beforeend", flyout); + + // Trigger the Read the Docs Addons Search modal when clicking on the "Search docs" input from inside the flyout. + document + .querySelector("#flyout-search-form") + .addEventListener("focusin", () => { + const event = new CustomEvent("readthedocs-search-show"); + document.dispatchEvent(event); + }); + }) +} + +if (themeLanguageSelector || themeVersionSelector) { + function onSelectorSwitch(event) { + const option = event.target.selectedIndex; + const item = event.target.options[option]; + window.location.href = item.dataset.url; + } + + document.addEventListener("readthedocs-addons-data-ready", function (event) { + const config = event.detail.data(); + + const versionSwitch = document.querySelector( + "div.switch-menus > div.version-switch", + ); + if (themeVersionSelector) { + let versions = config.versions.active; + if (config.versions.current.hidden || config.versions.current.type === "external") { + versions.unshift(config.versions.current); + } + const versionSelect = ` + + `; + + versionSwitch.innerHTML = versionSelect; + versionSwitch.firstElementChild.addEventListener("change", onSelectorSwitch); + } + + const languageSwitch = document.querySelector( + "div.switch-menus > div.language-switch", + ); + + if (themeLanguageSelector) { + if (config.projects.translations.length) { + // Add the current language to the options on the selector + let languages = config.projects.translations.concat( + config.projects.current, + ); + languages = languages.sort((a, b) => + a.language.name.localeCompare(b.language.name), + ); + + const languageSelect = ` + + `; + + languageSwitch.innerHTML = languageSelect; + languageSwitch.firstElementChild.addEventListener("change", onSelectorSwitch); + } + else { + languageSwitch.remove(); + } + } + }); +} + +document.addEventListener("readthedocs-addons-data-ready", function (event) { + // Trigger the Read the Docs Addons Search modal when clicking on "Search docs" input from the topnav. + document + .querySelector("[role='search'] input") + .addEventListener("focusin", () => { + const event = new CustomEvent("readthedocs-search-show"); + document.dispatchEvent(event); + }); +}); \ No newline at end of file diff --git a/tag/3.5.0/_static/language_data.js b/tag/3.5.0/_static/language_data.js new file mode 100644 index 0000000..c7fe6c6 --- /dev/null +++ b/tag/3.5.0/_static/language_data.js @@ -0,0 +1,192 @@ +/* + * This script contains the language-specific data used by searchtools.js, + * namely the list of stopwords, stemmer, scorer and splitter. + */ + +var stopwords = ["a", "and", "are", "as", "at", "be", "but", "by", "for", "if", "in", "into", "is", "it", "near", "no", "not", "of", "on", "or", "such", "that", "the", "their", "then", "there", "these", "they", "this", "to", "was", "will", "with"]; + + +/* Non-minified version is copied as a separate JS file, if available */ + +/** + * Porter Stemmer + */ +var Stemmer = function() { + + var step2list = { + ational: 'ate', + tional: 'tion', + enci: 'ence', + anci: 'ance', + izer: 'ize', + bli: 'ble', + alli: 'al', + entli: 'ent', + eli: 'e', + ousli: 'ous', + ization: 'ize', + ation: 'ate', + ator: 'ate', + alism: 'al', + iveness: 'ive', + fulness: 'ful', + ousness: 'ous', + aliti: 'al', + iviti: 'ive', + biliti: 'ble', + logi: 'log' + }; + + var step3list = { + icate: 'ic', + ative: '', + alize: 'al', + iciti: 'ic', + ical: 'ic', + ful: '', + ness: '' + }; + + var c = "[^aeiou]"; // consonant + var v = "[aeiouy]"; // vowel + var C = c + "[^aeiouy]*"; // consonant sequence + var V = v + "[aeiou]*"; // vowel sequence + + var mgr0 = "^(" + C + ")?" + V + C; // [C]VC... is m>0 + var meq1 = "^(" + C + ")?" + V + C + "(" + V + ")?$"; // [C]VC[V] is m=1 + var mgr1 = "^(" + C + ")?" + V + C + V + C; // [C]VCVC... is m>1 + var s_v = "^(" + C + ")?" + v; // vowel in stem + + this.stemWord = function (w) { + var stem; + var suffix; + var firstch; + var origword = w; + + if (w.length < 3) + return w; + + var re; + var re2; + var re3; + var re4; + + firstch = w.substr(0,1); + if (firstch == "y") + w = firstch.toUpperCase() + w.substr(1); + + // Step 1a + re = /^(.+?)(ss|i)es$/; + re2 = /^(.+?)([^s])s$/; + + if (re.test(w)) + w = w.replace(re,"$1$2"); + else if (re2.test(w)) + w = w.replace(re2,"$1$2"); + + // Step 1b + re = /^(.+?)eed$/; + re2 = /^(.+?)(ed|ing)$/; + if (re.test(w)) { + var fp = re.exec(w); + re = new RegExp(mgr0); + if (re.test(fp[1])) { + re = /.$/; + w = w.replace(re,""); + } + } + else if (re2.test(w)) { + var fp = re2.exec(w); + stem = fp[1]; + re2 = new RegExp(s_v); + if (re2.test(stem)) { + w = stem; + re2 = /(at|bl|iz)$/; + re3 = new RegExp("([^aeiouylsz])\\1$"); + re4 = new RegExp("^" + C + v + "[^aeiouwxy]$"); + if (re2.test(w)) + w = w + "e"; + else if (re3.test(w)) { + re = /.$/; + w = w.replace(re,""); + } + else if (re4.test(w)) + w = w + "e"; + } + } + + // Step 1c + re = /^(.+?)y$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + re = new RegExp(s_v); + if (re.test(stem)) + w = stem + "i"; + } + + // Step 2 + re = /^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + suffix = fp[2]; + re = new RegExp(mgr0); + if (re.test(stem)) + w = stem + step2list[suffix]; + } + + // Step 3 + re = /^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + suffix = fp[2]; + re = new RegExp(mgr0); + if (re.test(stem)) + w = stem + step3list[suffix]; + } + + // Step 4 + re = /^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/; + re2 = /^(.+?)(s|t)(ion)$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + re = new RegExp(mgr1); + if (re.test(stem)) + w = stem; + } + else if (re2.test(w)) { + var fp = re2.exec(w); + stem = fp[1] + fp[2]; + re2 = new RegExp(mgr1); + if (re2.test(stem)) + w = stem; + } + + // Step 5 + re = /^(.+?)e$/; + if (re.test(w)) { + var fp = re.exec(w); + stem = fp[1]; + re = new RegExp(mgr1); + re2 = new RegExp(meq1); + re3 = new RegExp("^" + C + v + "[^aeiouwxy]$"); + if (re.test(stem) || (re2.test(stem) && !(re3.test(stem)))) + w = stem; + } + re = /ll$/; + re2 = new RegExp(mgr1); + if (re.test(w) && re2.test(w)) { + re = /.$/; + w = w.replace(re,""); + } + + // and turn initial Y back to y + if (firstch == "y") + w = firstch.toLowerCase() + w.substr(1); + return w; + } +} + diff --git a/tag/3.5.0/_static/minus.png b/tag/3.5.0/_static/minus.png new file mode 100644 index 0000000..d96755f Binary files /dev/null and b/tag/3.5.0/_static/minus.png differ diff --git a/tag/3.5.0/_static/plus.png b/tag/3.5.0/_static/plus.png new file mode 100644 index 0000000..7107cec Binary files /dev/null and b/tag/3.5.0/_static/plus.png differ diff --git a/tag/3.5.0/_static/pygments.css b/tag/3.5.0/_static/pygments.css new file mode 100644 index 0000000..fe39d08 --- /dev/null +++ b/tag/3.5.0/_static/pygments.css @@ -0,0 +1,81 @@ +pre { line-height: 125%; } +td.linenos .normal { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +span.linenos { color: inherit; background-color: transparent; padding-left: 5px; padding-right: 5px; } +td.linenos .special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +span.linenos.special { color: #000000; background-color: #ffffc0; padding-left: 5px; padding-right: 5px; } +.highlight .hll { background-color: #ffffcc; border: 1px solid #edff00; padding-top: 2px; border-radius: 3px; display: block } +.highlight { background: #f8f8f8; } +.highlight .c { color: #6A737D; font-style: italic } /* Comment */ +.highlight .err { color: #A61717; background-color: #E3D2D2; border: 1px solid #F00 } /* Error */ +.highlight .k { color: #007020; font-weight: bold } /* Keyword */ +.highlight .l { color: #032F62 } /* Literal */ +.highlight .n { color: #333 } /* Name */ +.highlight .o { color: #666; font-weight: bold } /* Operator */ +.highlight .p { font-weight: bold } /* Punctuation */ +.highlight .ch { color: #6A737D; font-style: italic } /* Comment.Hashbang */ +.highlight .cm { color: #6A737D; font-style: italic } /* Comment.Multiline */ +.highlight .cp { color: #007020 } /* Comment.Preproc */ +.highlight .cpf { color: #6A737D; font-style: italic } /* Comment.PreprocFile */ +.highlight .c1 { color: #6A737D; font-style: italic } /* Comment.Single */ +.highlight .cs { color: #999; font-weight: bold; font-style: italic; background-color: #FFF0F0 } /* Comment.Special */ +.highlight .gd { color: #A00000; background-color: #FDD } /* Generic.Deleted */ +.highlight .ge { font-style: italic } /* Generic.Emph */ +.highlight .gr { color: #A00 } /* Generic.Error */ +.highlight .gh { color: #000080; font-weight: bold } /* Generic.Heading */ +.highlight .gi { color: #00A000; background-color: #DFD } /* Generic.Inserted */ +.highlight .go { color: #333 } /* Generic.Output */ +.highlight .gp { color: #C65D09; font-weight: bold } /* Generic.Prompt */ +.highlight .gs { font-weight: bold } /* Generic.Strong */ +.highlight .gu { color: #800080; font-weight: bold } /* Generic.Subheading */ +.highlight .gt { color: #0040D0 } /* Generic.Traceback */ +.highlight .kc { color: #007020; font-weight: bold } /* Keyword.Constant */ +.highlight .kd { color: #007020; font-weight: bold } /* Keyword.Declaration */ +.highlight .kn { color: #007020; font-weight: bold } /* Keyword.Namespace */ +.highlight .kp { color: #007020; font-weight: bold } /* Keyword.Pseudo */ +.highlight .kr { color: #007020; font-weight: bold } /* Keyword.Reserved */ +.highlight .kt { color: #902000; font-weight: bold } /* Keyword.Type */ +.highlight .ld { color: #032F62 } /* Literal.Date */ +.highlight .m { color: #208050 } /* Literal.Number */ +.highlight .s { color: #4070A0 } /* Literal.String */ +.highlight .na { color: #008080 } /* Name.Attribute */ +.highlight .nb { color: #0086B3 } /* Name.Builtin */ +.highlight .nc { color: #458; font-weight: bold } /* Name.Class */ +.highlight .no { color: #008080 } /* Name.Constant */ +.highlight .nd { color: #555; font-weight: bold } /* Name.Decorator */ +.highlight .ni { color: #800080; font-weight: bold } /* Name.Entity */ +.highlight .ne { color: #900; font-weight: bold } /* Name.Exception */ +.highlight .nf { color: #900; font-weight: bold } /* Name.Function */ +.highlight .nl { color: #002070; font-weight: bold } /* Name.Label */ +.highlight .nn { color: #555; font-weight: bold } /* Name.Namespace */ +.highlight .nx { color: #333 } /* Name.Other */ +.highlight .py { color: #333 } /* Name.Property */ +.highlight .nt { color: #22863A; font-weight: bold } /* Name.Tag */ +.highlight .nv { color: #9960B5; font-weight: bold } /* Name.Variable */ +.highlight .ow { color: #007020; font-weight: bold } /* Operator.Word */ +.highlight .pm { font-weight: bold } /* Punctuation.Marker */ +.highlight .w { color: #BBB } /* Text.Whitespace */ +.highlight .mb { color: #099 } /* Literal.Number.Bin */ +.highlight .mf { color: #099 } /* Literal.Number.Float */ +.highlight .mh { color: #099 } /* Literal.Number.Hex */ +.highlight .mi { color: #099 } /* Literal.Number.Integer */ +.highlight .mo { color: #099 } /* Literal.Number.Oct */ +.highlight .sa { color: #D14 } /* Literal.String.Affix */ +.highlight .sb { color: #D14 } /* Literal.String.Backtick */ +.highlight .sc { color: #D14 } /* Literal.String.Char */ +.highlight .dl { color: #D14 } /* Literal.String.Delimiter */ +.highlight .sd { color: #D14; font-style: italic } /* Literal.String.Doc */ +.highlight .s2 { color: #D14 } /* Literal.String.Double */ +.highlight .se { color: #D14; font-weight: bold } /* Literal.String.Escape */ +.highlight .sh { color: #D14 } /* Literal.String.Heredoc */ +.highlight .si { color: #D14; font-style: italic } /* Literal.String.Interpol */ +.highlight .sx { color: #D14 } /* Literal.String.Other */ +.highlight .sr { color: #009926 } /* Literal.String.Regex */ +.highlight .s1 { color: #D14 } /* Literal.String.Single */ +.highlight .ss { color: #990073 } /* Literal.String.Symbol */ +.highlight .bp { color: #999 } /* Name.Builtin.Pseudo */ +.highlight .fm { color: #06287E; font-weight: bold } /* Name.Function.Magic */ +.highlight .vc { color: #008080; font-weight: bold } /* Name.Variable.Class */ +.highlight .vg { color: #008080; font-weight: bold } /* Name.Variable.Global */ +.highlight .vi { color: #008080; font-weight: bold } /* Name.Variable.Instance */ +.highlight .vm { color: #BB60D5; font-weight: bold } /* Name.Variable.Magic */ +.highlight .il { color: #099 } /* Literal.Number.Integer.Long */ \ No newline at end of file diff --git a/tag/3.5.0/_static/searchtools.js b/tag/3.5.0/_static/searchtools.js new file mode 100644 index 0000000..91f4be5 --- /dev/null +++ b/tag/3.5.0/_static/searchtools.js @@ -0,0 +1,635 @@ +/* + * Sphinx JavaScript utilities for the full-text search. + */ +"use strict"; + +/** + * Simple result scoring code. + */ +if (typeof Scorer === "undefined") { + var Scorer = { + // Implement the following function to further tweak the score for each result + // The function takes a result array [docname, title, anchor, descr, score, filename] + // and returns the new score. + /* + score: result => { + const [docname, title, anchor, descr, score, filename, kind] = result + return score + }, + */ + + // query matches the full name of an object + objNameMatch: 11, + // or matches in the last dotted part of the object name + objPartialMatch: 6, + // Additive scores depending on the priority of the object + objPrio: { + 0: 15, // used to be importantResults + 1: 5, // used to be objectResults + 2: -5, // used to be unimportantResults + }, + // Used when the priority is not in the mapping. + objPrioDefault: 0, + + // query found in title + title: 15, + partialTitle: 7, + // query found in terms + term: 5, + partialTerm: 2, + }; +} + +// Global search result kind enum, used by themes to style search results. +class SearchResultKind { + static get index() { return "index"; } + static get object() { return "object"; } + static get text() { return "text"; } + static get title() { return "title"; } +} + +const _removeChildren = (element) => { + while (element && element.lastChild) element.removeChild(element.lastChild); +}; + +/** + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#escaping + */ +const _escapeRegExp = (string) => + string.replace(/[.*+\-?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string + +const _displayItem = (item, searchTerms, highlightTerms) => { + const docBuilder = DOCUMENTATION_OPTIONS.BUILDER; + const docFileSuffix = DOCUMENTATION_OPTIONS.FILE_SUFFIX; + const docLinkSuffix = DOCUMENTATION_OPTIONS.LINK_SUFFIX; + const showSearchSummary = DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY; + const contentRoot = document.documentElement.dataset.content_root; + + const [docName, title, anchor, descr, score, _filename, kind] = item; + + let listItem = document.createElement("li"); + // Add a class representing the item's type: + // can be used by a theme's CSS selector for styling + // See SearchResultKind for the class names. + listItem.classList.add(`kind-${kind}`); + let requestUrl; + let linkUrl; + if (docBuilder === "dirhtml") { + // dirhtml builder + let dirname = docName + "/"; + if (dirname.match(/\/index\/$/)) + dirname = dirname.substring(0, dirname.length - 6); + else if (dirname === "index/") dirname = ""; + requestUrl = contentRoot + dirname; + linkUrl = requestUrl; + } else { + // normal html builders + requestUrl = contentRoot + docName + docFileSuffix; + linkUrl = docName + docLinkSuffix; + } + let linkEl = listItem.appendChild(document.createElement("a")); + linkEl.href = linkUrl + anchor; + linkEl.dataset.score = score; + linkEl.innerHTML = title; + if (descr) { + listItem.appendChild(document.createElement("span")).innerHTML = + " (" + descr + ")"; + // highlight search terms in the description + if (SPHINX_HIGHLIGHT_ENABLED) // set in sphinx_highlight.js + highlightTerms.forEach((term) => _highlightText(listItem, term, "highlighted")); + } + else if (showSearchSummary) + fetch(requestUrl) + .then((responseData) => responseData.text()) + .then((data) => { + if (data) + listItem.appendChild( + Search.makeSearchSummary(data, searchTerms, anchor) + ); + // highlight search terms in the summary + if (SPHINX_HIGHLIGHT_ENABLED) // set in sphinx_highlight.js + highlightTerms.forEach((term) => _highlightText(listItem, term, "highlighted")); + }); + Search.output.appendChild(listItem); +}; +const _finishSearch = (resultCount) => { + Search.stopPulse(); + Search.title.innerText = _("Search Results"); + if (!resultCount) + Search.status.innerText = Documentation.gettext( + "Your search did not match any documents. Please make sure that all words are spelled correctly and that you've selected enough categories." + ); + else + Search.status.innerText = Documentation.ngettext( + "Search finished, found one page matching the search query.", + "Search finished, found ${resultCount} pages matching the search query.", + resultCount, + ).replace('${resultCount}', resultCount); +}; +const _displayNextItem = ( + results, + resultCount, + searchTerms, + highlightTerms, +) => { + // results left, load the summary and display it + // this is intended to be dynamic (don't sub resultsCount) + if (results.length) { + _displayItem(results.pop(), searchTerms, highlightTerms); + setTimeout( + () => _displayNextItem(results, resultCount, searchTerms, highlightTerms), + 5 + ); + } + // search finished, update title and status message + else _finishSearch(resultCount); +}; +// Helper function used by query() to order search results. +// Each input is an array of [docname, title, anchor, descr, score, filename, kind]. +// Order the results by score (in opposite order of appearance, since the +// `_displayNextItem` function uses pop() to retrieve items) and then alphabetically. +const _orderResultsByScoreThenName = (a, b) => { + const leftScore = a[4]; + const rightScore = b[4]; + if (leftScore === rightScore) { + // same score: sort alphabetically + const leftTitle = a[1].toLowerCase(); + const rightTitle = b[1].toLowerCase(); + if (leftTitle === rightTitle) return 0; + return leftTitle > rightTitle ? -1 : 1; // inverted is intentional + } + return leftScore > rightScore ? 1 : -1; +}; + +/** + * Default splitQuery function. Can be overridden in ``sphinx.search`` with a + * custom function per language. + * + * The regular expression works by splitting the string on consecutive characters + * that are not Unicode letters, numbers, underscores, or emoji characters. + * This is the same as ``\W+`` in Python, preserving the surrogate pair area. + */ +if (typeof splitQuery === "undefined") { + var splitQuery = (query) => query + .split(/[^\p{Letter}\p{Number}_\p{Emoji_Presentation}]+/gu) + .filter(term => term) // remove remaining empty strings +} + +/** + * Search Module + */ +const Search = { + _index: null, + _queued_query: null, + _pulse_status: -1, + + htmlToText: (htmlString, anchor) => { + const htmlElement = new DOMParser().parseFromString(htmlString, 'text/html'); + for (const removalQuery of [".headerlink", "script", "style"]) { + htmlElement.querySelectorAll(removalQuery).forEach((el) => { el.remove() }); + } + if (anchor) { + const anchorContent = htmlElement.querySelector(`[role="main"] ${anchor}`); + if (anchorContent) return anchorContent.textContent; + + console.warn( + `Anchored content block not found. Sphinx search tries to obtain it via DOM query '[role=main] ${anchor}'. Check your theme or template.` + ); + } + + // if anchor not specified or not found, fall back to main content + const docContent = htmlElement.querySelector('[role="main"]'); + if (docContent) return docContent.textContent; + + console.warn( + "Content block not found. Sphinx search tries to obtain it via DOM query '[role=main]'. Check your theme or template." + ); + return ""; + }, + + init: () => { + const query = new URLSearchParams(window.location.search).get("q"); + document + .querySelectorAll('input[name="q"]') + .forEach((el) => (el.value = query)); + if (query) Search.performSearch(query); + }, + + loadIndex: (url) => + (document.body.appendChild(document.createElement("script")).src = url), + + setIndex: (index) => { + Search._index = index; + if (Search._queued_query !== null) { + const query = Search._queued_query; + Search._queued_query = null; + Search.query(query); + } + }, + + hasIndex: () => Search._index !== null, + + deferQuery: (query) => (Search._queued_query = query), + + stopPulse: () => (Search._pulse_status = -1), + + startPulse: () => { + if (Search._pulse_status >= 0) return; + + const pulse = () => { + Search._pulse_status = (Search._pulse_status + 1) % 4; + Search.dots.innerText = ".".repeat(Search._pulse_status); + if (Search._pulse_status >= 0) window.setTimeout(pulse, 500); + }; + pulse(); + }, + + /** + * perform a search for something (or wait until index is loaded) + */ + performSearch: (query) => { + // create the required interface elements + const searchText = document.createElement("h2"); + searchText.textContent = _("Searching"); + const searchSummary = document.createElement("p"); + searchSummary.classList.add("search-summary"); + searchSummary.innerText = ""; + const searchList = document.createElement("ul"); + searchList.setAttribute("role", "list"); + searchList.classList.add("search"); + + const out = document.getElementById("search-results"); + Search.title = out.appendChild(searchText); + Search.dots = Search.title.appendChild(document.createElement("span")); + Search.status = out.appendChild(searchSummary); + Search.output = out.appendChild(searchList); + + const searchProgress = document.getElementById("search-progress"); + // Some themes don't use the search progress node + if (searchProgress) { + searchProgress.innerText = _("Preparing search..."); + } + Search.startPulse(); + + // index already loaded, the browser was quick! + if (Search.hasIndex()) Search.query(query); + else Search.deferQuery(query); + }, + + _parseQuery: (query) => { + // stem the search terms and add them to the correct list + const stemmer = new Stemmer(); + const searchTerms = new Set(); + const excludedTerms = new Set(); + const highlightTerms = new Set(); + const objectTerms = new Set(splitQuery(query.toLowerCase().trim())); + splitQuery(query.trim()).forEach((queryTerm) => { + const queryTermLower = queryTerm.toLowerCase(); + + // maybe skip this "word" + // stopwords array is from language_data.js + if ( + stopwords.indexOf(queryTermLower) !== -1 || + queryTerm.match(/^\d+$/) + ) + return; + + // stem the word + let word = stemmer.stemWord(queryTermLower); + // select the correct list + if (word[0] === "-") excludedTerms.add(word.substr(1)); + else { + searchTerms.add(word); + highlightTerms.add(queryTermLower); + } + }); + + if (SPHINX_HIGHLIGHT_ENABLED) { // set in sphinx_highlight.js + localStorage.setItem("sphinx_highlight_terms", [...highlightTerms].join(" ")) + } + + // console.debug("SEARCH: searching for:"); + // console.info("required: ", [...searchTerms]); + // console.info("excluded: ", [...excludedTerms]); + + return [query, searchTerms, excludedTerms, highlightTerms, objectTerms]; + }, + + /** + * execute search (requires search index to be loaded) + */ + _performSearch: (query, searchTerms, excludedTerms, highlightTerms, objectTerms) => { + const filenames = Search._index.filenames; + const docNames = Search._index.docnames; + const titles = Search._index.titles; + const allTitles = Search._index.alltitles; + const indexEntries = Search._index.indexentries; + + // Collect multiple result groups to be sorted separately and then ordered. + // Each is an array of [docname, title, anchor, descr, score, filename, kind]. + const normalResults = []; + const nonMainIndexResults = []; + + _removeChildren(document.getElementById("search-progress")); + + const queryLower = query.toLowerCase().trim(); + for (const [title, foundTitles] of Object.entries(allTitles)) { + if (title.toLowerCase().trim().includes(queryLower) && (queryLower.length >= title.length/2)) { + for (const [file, id] of foundTitles) { + const score = Math.round(Scorer.title * queryLower.length / title.length); + const boost = titles[file] === title ? 1 : 0; // add a boost for document titles + normalResults.push([ + docNames[file], + titles[file] !== title ? `${titles[file]} > ${title}` : title, + id !== null ? "#" + id : "", + null, + score + boost, + filenames[file], + SearchResultKind.title, + ]); + } + } + } + + // search for explicit entries in index directives + for (const [entry, foundEntries] of Object.entries(indexEntries)) { + if (entry.includes(queryLower) && (queryLower.length >= entry.length/2)) { + for (const [file, id, isMain] of foundEntries) { + const score = Math.round(100 * queryLower.length / entry.length); + const result = [ + docNames[file], + titles[file], + id ? "#" + id : "", + null, + score, + filenames[file], + SearchResultKind.index, + ]; + if (isMain) { + normalResults.push(result); + } else { + nonMainIndexResults.push(result); + } + } + } + } + + // lookup as object + objectTerms.forEach((term) => + normalResults.push(...Search.performObjectSearch(term, objectTerms)) + ); + + // lookup as search terms in fulltext + normalResults.push(...Search.performTermsSearch(searchTerms, excludedTerms)); + + // let the scorer override scores with a custom scoring function + if (Scorer.score) { + normalResults.forEach((item) => (item[4] = Scorer.score(item))); + nonMainIndexResults.forEach((item) => (item[4] = Scorer.score(item))); + } + + // Sort each group of results by score and then alphabetically by name. + normalResults.sort(_orderResultsByScoreThenName); + nonMainIndexResults.sort(_orderResultsByScoreThenName); + + // Combine the result groups in (reverse) order. + // Non-main index entries are typically arbitrary cross-references, + // so display them after other results. + let results = [...nonMainIndexResults, ...normalResults]; + + // remove duplicate search results + // note the reversing of results, so that in the case of duplicates, the highest-scoring entry is kept + let seen = new Set(); + results = results.reverse().reduce((acc, result) => { + let resultStr = result.slice(0, 4).concat([result[5]]).map(v => String(v)).join(','); + if (!seen.has(resultStr)) { + acc.push(result); + seen.add(resultStr); + } + return acc; + }, []); + + return results.reverse(); + }, + + query: (query) => { + const [searchQuery, searchTerms, excludedTerms, highlightTerms, objectTerms] = Search._parseQuery(query); + const results = Search._performSearch(searchQuery, searchTerms, excludedTerms, highlightTerms, objectTerms); + + // for debugging + //Search.lastresults = results.slice(); // a copy + // console.info("search results:", Search.lastresults); + + // print the results + _displayNextItem(results, results.length, searchTerms, highlightTerms); + }, + + /** + * search for object names + */ + performObjectSearch: (object, objectTerms) => { + const filenames = Search._index.filenames; + const docNames = Search._index.docnames; + const objects = Search._index.objects; + const objNames = Search._index.objnames; + const titles = Search._index.titles; + + const results = []; + + const objectSearchCallback = (prefix, match) => { + const name = match[4] + const fullname = (prefix ? prefix + "." : "") + name; + const fullnameLower = fullname.toLowerCase(); + if (fullnameLower.indexOf(object) < 0) return; + + let score = 0; + const parts = fullnameLower.split("."); + + // check for different match types: exact matches of full name or + // "last name" (i.e. last dotted part) + if (fullnameLower === object || parts.slice(-1)[0] === object) + score += Scorer.objNameMatch; + else if (parts.slice(-1)[0].indexOf(object) > -1) + score += Scorer.objPartialMatch; // matches in last name + + const objName = objNames[match[1]][2]; + const title = titles[match[0]]; + + // If more than one term searched for, we require other words to be + // found in the name/title/description + const otherTerms = new Set(objectTerms); + otherTerms.delete(object); + if (otherTerms.size > 0) { + const haystack = `${prefix} ${name} ${objName} ${title}`.toLowerCase(); + if ( + [...otherTerms].some((otherTerm) => haystack.indexOf(otherTerm) < 0) + ) + return; + } + + let anchor = match[3]; + if (anchor === "") anchor = fullname; + else if (anchor === "-") anchor = objNames[match[1]][1] + "-" + fullname; + + const descr = objName + _(", in ") + title; + + // add custom score for some objects according to scorer + if (Scorer.objPrio.hasOwnProperty(match[2])) + score += Scorer.objPrio[match[2]]; + else score += Scorer.objPrioDefault; + + results.push([ + docNames[match[0]], + fullname, + "#" + anchor, + descr, + score, + filenames[match[0]], + SearchResultKind.object, + ]); + }; + Object.keys(objects).forEach((prefix) => + objects[prefix].forEach((array) => + objectSearchCallback(prefix, array) + ) + ); + return results; + }, + + /** + * search for full-text terms in the index + */ + performTermsSearch: (searchTerms, excludedTerms) => { + // prepare search + const terms = Search._index.terms; + const titleTerms = Search._index.titleterms; + const filenames = Search._index.filenames; + const docNames = Search._index.docnames; + const titles = Search._index.titles; + + const scoreMap = new Map(); + const fileMap = new Map(); + + // perform the search on the required terms + searchTerms.forEach((word) => { + const files = []; + // find documents, if any, containing the query word in their text/title term indices + // use Object.hasOwnProperty to avoid mismatching against prototype properties + const arr = [ + { files: terms.hasOwnProperty(word) ? terms[word] : undefined, score: Scorer.term }, + { files: titleTerms.hasOwnProperty(word) ? titleTerms[word] : undefined, score: Scorer.title }, + ]; + // add support for partial matches + if (word.length > 2) { + const escapedWord = _escapeRegExp(word); + if (!terms.hasOwnProperty(word)) { + Object.keys(terms).forEach((term) => { + if (term.match(escapedWord)) + arr.push({ files: terms[term], score: Scorer.partialTerm }); + }); + } + if (!titleTerms.hasOwnProperty(word)) { + Object.keys(titleTerms).forEach((term) => { + if (term.match(escapedWord)) + arr.push({ files: titleTerms[term], score: Scorer.partialTitle }); + }); + } + } + + // no match but word was a required one + if (arr.every((record) => record.files === undefined)) return; + + // found search word in contents + arr.forEach((record) => { + if (record.files === undefined) return; + + let recordFiles = record.files; + if (recordFiles.length === undefined) recordFiles = [recordFiles]; + files.push(...recordFiles); + + // set score for the word in each file + recordFiles.forEach((file) => { + if (!scoreMap.has(file)) scoreMap.set(file, new Map()); + const fileScores = scoreMap.get(file); + fileScores.set(word, record.score); + }); + }); + + // create the mapping + files.forEach((file) => { + if (!fileMap.has(file)) fileMap.set(file, [word]); + else if (fileMap.get(file).indexOf(word) === -1) fileMap.get(file).push(word); + }); + }); + + // now check if the files don't contain excluded terms + const results = []; + for (const [file, wordList] of fileMap) { + // check if all requirements are matched + + // as search terms with length < 3 are discarded + const filteredTermCount = [...searchTerms].filter( + (term) => term.length > 2 + ).length; + if ( + wordList.length !== searchTerms.size && + wordList.length !== filteredTermCount + ) + continue; + + // ensure that none of the excluded terms is in the search result + if ( + [...excludedTerms].some( + (term) => + terms[term] === file || + titleTerms[term] === file || + (terms[term] || []).includes(file) || + (titleTerms[term] || []).includes(file) + ) + ) + break; + + // select one (max) score for the file. + const score = Math.max(...wordList.map((w) => scoreMap.get(file).get(w))); + // add result to the result list + results.push([ + docNames[file], + titles[file], + "", + null, + score, + filenames[file], + SearchResultKind.text, + ]); + } + return results; + }, + + /** + * helper function to return a node containing the + * search summary for a given text. keywords is a list + * of stemmed words. + */ + makeSearchSummary: (htmlText, keywords, anchor) => { + const text = Search.htmlToText(htmlText, anchor); + if (text === "") return null; + + const textLower = text.toLowerCase(); + const actualStartPosition = [...keywords] + .map((k) => textLower.indexOf(k.toLowerCase())) + .filter((i) => i > -1) + .slice(-1)[0]; + const startWithContext = Math.max(actualStartPosition - 120, 0); + + const top = startWithContext === 0 ? "" : "..."; + const tail = startWithContext + 240 < text.length ? "..." : ""; + + let summary = document.createElement("p"); + summary.classList.add("context"); + summary.textContent = top + text.substr(startWithContext, 240).trim() + tail; + + return summary; + }, +}; + +_ready(Search.init); diff --git a/tag/3.5.0/_static/sphinx_highlight.js b/tag/3.5.0/_static/sphinx_highlight.js new file mode 100644 index 0000000..8a96c69 --- /dev/null +++ b/tag/3.5.0/_static/sphinx_highlight.js @@ -0,0 +1,154 @@ +/* Highlighting utilities for Sphinx HTML documentation. */ +"use strict"; + +const SPHINX_HIGHLIGHT_ENABLED = true + +/** + * highlight a given string on a node by wrapping it in + * span elements with the given class name. + */ +const _highlight = (node, addItems, text, className) => { + if (node.nodeType === Node.TEXT_NODE) { + const val = node.nodeValue; + const parent = node.parentNode; + const pos = val.toLowerCase().indexOf(text); + if ( + pos >= 0 && + !parent.classList.contains(className) && + !parent.classList.contains("nohighlight") + ) { + let span; + + const closestNode = parent.closest("body, svg, foreignObject"); + const isInSVG = closestNode && closestNode.matches("svg"); + if (isInSVG) { + span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); + } else { + span = document.createElement("span"); + span.classList.add(className); + } + + span.appendChild(document.createTextNode(val.substr(pos, text.length))); + const rest = document.createTextNode(val.substr(pos + text.length)); + parent.insertBefore( + span, + parent.insertBefore( + rest, + node.nextSibling + ) + ); + node.nodeValue = val.substr(0, pos); + /* There may be more occurrences of search term in this node. So call this + * function recursively on the remaining fragment. + */ + _highlight(rest, addItems, text, className); + + if (isInSVG) { + const rect = document.createElementNS( + "http://www.w3.org/2000/svg", + "rect" + ); + const bbox = parent.getBBox(); + rect.x.baseVal.value = bbox.x; + rect.y.baseVal.value = bbox.y; + rect.width.baseVal.value = bbox.width; + rect.height.baseVal.value = bbox.height; + rect.setAttribute("class", className); + addItems.push({ parent: parent, target: rect }); + } + } + } else if (node.matches && !node.matches("button, select, textarea")) { + node.childNodes.forEach((el) => _highlight(el, addItems, text, className)); + } +}; +const _highlightText = (thisNode, text, className) => { + let addItems = []; + _highlight(thisNode, addItems, text, className); + addItems.forEach((obj) => + obj.parent.insertAdjacentElement("beforebegin", obj.target) + ); +}; + +/** + * Small JavaScript module for the documentation. + */ +const SphinxHighlight = { + + /** + * highlight the search words provided in localstorage in the text + */ + highlightSearchWords: () => { + if (!SPHINX_HIGHLIGHT_ENABLED) return; // bail if no highlight + + // get and clear terms from localstorage + const url = new URL(window.location); + const highlight = + localStorage.getItem("sphinx_highlight_terms") + || url.searchParams.get("highlight") + || ""; + localStorage.removeItem("sphinx_highlight_terms") + url.searchParams.delete("highlight"); + window.history.replaceState({}, "", url); + + // get individual terms from highlight string + const terms = highlight.toLowerCase().split(/\s+/).filter(x => x); + if (terms.length === 0) return; // nothing to do + + // There should never be more than one element matching "div.body" + const divBody = document.querySelectorAll("div.body"); + const body = divBody.length ? divBody[0] : document.querySelector("body"); + window.setTimeout(() => { + terms.forEach((term) => _highlightText(body, term, "highlighted")); + }, 10); + + const searchBox = document.getElementById("searchbox"); + if (searchBox === null) return; + searchBox.appendChild( + document + .createRange() + .createContextualFragment( + '" + ) + ); + }, + + /** + * helper function to hide the search marks again + */ + hideSearchWords: () => { + document + .querySelectorAll("#searchbox .highlight-link") + .forEach((el) => el.remove()); + document + .querySelectorAll("span.highlighted") + .forEach((el) => el.classList.remove("highlighted")); + localStorage.removeItem("sphinx_highlight_terms") + }, + + initEscapeListener: () => { + // only install a listener if it is really needed + if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) return; + + document.addEventListener("keydown", (event) => { + // bail for input elements + if (BLACKLISTED_KEY_CONTROL_ELEMENTS.has(document.activeElement.tagName)) return; + // bail with special keys + if (event.shiftKey || event.altKey || event.ctrlKey || event.metaKey) return; + if (DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS && (event.key === "Escape")) { + SphinxHighlight.hideSearchWords(); + event.preventDefault(); + } + }); + }, +}; + +_ready(() => { + /* Do not call highlightSearchWords() when we are on the search page. + * It will highlight words from the *previous* search query. + */ + if (typeof Search === "undefined") SphinxHighlight.highlightSearchWords(); + SphinxHighlight.initEscapeListener(); +}); diff --git a/tag/3.5.0/api_facts_module.html b/tag/3.5.0/api_facts_module.html new file mode 100644 index 0000000..68ff5f2 --- /dev/null +++ b/tag/3.5.0/api_facts_module.html @@ -0,0 +1,665 @@ + + + + + + + + + + community.routeros.api_facts module – Collect facts from remote devices running MikroTik RouterOS using the API — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.api_facts module – Collect facts from remote devices running MikroTik RouterOS using the API

+
+

Note

+

This module is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros. +You need further requirements to be able to use this module, +see Requirements for details.

+

To use it in a playbook, specify: community.routeros.api_facts.

+
+

New in community.routeros 2.1.0

+ +
+

Synopsis

+
    +
  • Collects a base set of device facts from a remote device that is running RouterOS. This module prepends all of the base network fact keys with ansible_net_<fact>. The facts module will always collect a base set of facts from the device and can enable or disable collection of additional facts.

  • +
  • As opposed to the community.routeros.facts module, it uses the RouterOS API, similar to the community.routeros.api module.

  • +
+
+
+

Requirements

+

The below requirements are needed on the host that executes this module.

+
    +
  • librouteros

  • +
  • Python >= 3.6 (for librouteros)

  • +
+
+
+

Parameters

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Parameter

Comments

+

ca_path

+

path

+

added in community.routeros 1.2.0

+

PEM formatted file that contains a CA certificate to be used for certificate validation.

+

See also validate_cert_hostname. Only used when tls=true and validate_certs=true.

+
+

encoding

+

string

+

added in community.routeros 2.1.0

+

Use the specified encoding when communicating with the RouterOS device.

+

Default is ASCII. Note that UTF-8 requires librouteros 3.2.1 or newer.

+

Default: "ASCII"

+
+

force_no_cert

+

boolean

+

added in community.routeros 2.4.0

+

Set to true to connect without a certificate when tls=true.

+

See also validate_certs.

+

Note: this forces the use of anonymous Diffie-Hellman (ADH) ciphers. The protocol is susceptible to Man-in-the-Middle attacks, because the keys used in the exchange are not authenticated. Instead of simply connecting without a certificate to “make things work” have a look at validate_certs and ca_path.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

gather_subset

+

list / elements=string

+

When supplied, this argument will restrict the facts collected to a given subset. Possible values for this argument include all, hardware, interfaces, and routing.

+

Can specify a list of values to include a larger subset. Values can also be used with an initial ! to specify that a specific subset should not be collected.

+

Default: ["all"]

+
+

hostname

+

string / required

+

RouterOS hostname API.

+
+

password

+

string / required

+

RouterOS user password.

+
+

port

+

integer

+

RouterOS API port. If tls is set, port will apply to TLS/SSL connection.

+

Defaults are 8728 for the HTTP API, and 8729 for the HTTPS API.

+
+

timeout

+

integer

+

added in community.routeros 2.3.0

+

Timeout for the request.

+

Default: 10

+
+
+

tls

+

aliases: ssl

+

boolean

+

If is set TLS will be used for RouterOS API connection.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

username

+

string / required

+

RouterOS login user.

+
+

validate_cert_hostname

+

boolean

+

added in community.routeros 1.2.0

+

Set to true to validate hostnames in certificates.

+

See also validate_certs. Only used when tls=true and validate_certs=true.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

validate_certs

+

boolean

+

added in community.routeros 1.2.0

+

Set to false to skip validation of TLS certificates.

+

See also validate_cert_hostname. Only used when tls=true.

+

Note: instead of simply deactivating certificate validations to “make things work”, please consider creating your own CA certificate and using it to sign certificates used for your router. You can tell the module about your CA certificate with the ca_path option.

+

Choices:

+
    +
  • false

  • +
  • true ← (default)

  • +
+
+
+
+

Attributes

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Attribute

Support

Description

+

action_group

+

Action group: community.routeros.api

+

Use group/community.routeros.api in module_defaults to set defaults for this module.

+
+

check_mode

+

Support: full

+

This action does not modify state.

+

Can run in check_mode and return changed status prediction without modifying target.

+
+

diff_mode

+

Support: N/A

+

This action does not modify state.

+

Will return details on what has changed (or possibly needs changing in check_mode), when in diff mode.

+
+

facts

+

Support: full

+

Action returns an ansible_facts dictionary that will update existing host facts.

+
+

idempotent

+

Support: full

+

This action does not modify state.

+

When run twice in a row outside check mode, with the same arguments, the second invocation indicates no change.

+

This assumes that the system controlled/queried by the module has not changed in a relevant way.

+
+

platform

+

Platform: RouterOS

+

Target OS/families that can be operated against.

+
+
+
+

See Also

+
+

See also

+
+
community.routeros.facts

Collect facts from remote devices running MikroTik RouterOS.

+
+
community.routeros.api

Ansible module for RouterOS API.

+
+
community.routeros.api_find_and_modify

Find and modify information using the API.

+
+
community.routeros.api_info

Retrieve information from API.

+
+
community.routeros.api_modify

Modify data at paths with API.

+
+
How to connect to RouterOS devices with the RouterOS API

How to connect to RouterOS devices with the RouterOS API.

+
+
+
+
+
+

Examples

+
- name: Collect all facts from the device
+  community.routeros.api_facts:
+    hostname: 192.168.88.1
+    username: admin
+    password: password
+    gather_subset: all
+
+- name: Do not collect hardware facts
+  community.routeros.api_facts:
+    hostname: 192.168.88.1
+    username: admin
+    password: password
+    gather_subset:
+      - "!hardware"
+
+
+
+
+

Returned Facts

+

Facts returned by this module are added/updated in the hostvars host facts and can be referenced by name just like any other host fact. They do not need to be registered in order to use them.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Key

Description

+

ansible_net_all_ipv4_addresses

+

list / elements=string

+

All IPv4 addresses configured on the device.

+

Returned: gather_subset contains interfaces

+
+

ansible_net_all_ipv6_addresses

+

list / elements=string

+

All IPv6 addresses configured on the device.

+

Returned: gather_subset contains interfaces

+
+

ansible_net_arch

+

string

+

The CPU architecture of the device.

+

Returned: gather_subset contains default

+
+

ansible_net_bgp_instance

+

dictionary

+

A dictionary with BGP instance information.

+

Returned: gather_subset contains routing

+
+

ansible_net_bgp_peer

+

dictionary

+

A dictionary with BGP peer information.

+

Returned: gather_subset contains routing

+
+

ansible_net_bgp_vpnv4_route

+

dictionary

+

A dictionary with BGP vpnv4 route information.

+

Returned: gather_subset contains routing

+
+

ansible_net_cpu_load

+

string

+

Current CPU load.

+

Returned: gather_subset contains default

+
+

ansible_net_gather_subset

+

list / elements=string

+

The list of fact subsets collected from the device.

+

Returned: always

+
+

ansible_net_hostname

+

string

+

The configured hostname of the device.

+

Returned: gather_subset contains default

+
+

ansible_net_interfaces

+

dictionary

+

A hash of all interfaces running on the system.

+

Returned: gather_subset contains interfaces

+
+

ansible_net_memfree_mb

+

integer

+

The available free memory on the remote device in MiB.

+

Returned: gather_subset contains hardware

+
+

ansible_net_memtotal_mb

+

integer

+

The total memory on the remote device in MiB.

+

Returned: gather_subset contains hardware

+
+

ansible_net_model

+

string

+

The model name returned from the device.

+

Returned: gather_subset contains default

+
+

ansible_net_neighbors

+

dictionary

+

The list of neighbors from the remote device.

+

Returned: gather_subset contains interfaces

+
+

ansible_net_ospf_instance

+

dictionary

+

A dictionary with OSPF instances.

+

Returned: gather_subset contains routing

+
+

ansible_net_ospf_neighbor

+

dictionary

+

A dictionary with OSPF neighbors.

+

Returned: gather_subset contains routing

+
+

ansible_net_route

+

dictionary

+

A dictionary for routes in all routing tables.

+

Returned: gather_subset contains routing

+
+

ansible_net_serialnum

+

string

+

The serial number of the remote device.

+

Returned: gather_subset contains default

+
+

ansible_net_spacefree_mb

+

dictionary

+

The available disk space on the remote device in MiB.

+

Returned: gather_subset contains hardware

+
+

ansible_net_spacetotal_mb

+

dictionary

+

The total disk space on the remote device in MiB.

+

Returned: gather_subset contains hardware

+
+

ansible_net_uptime

+

string

+

The uptime of the device.

+

Returned: gather_subset contains default

+
+

ansible_net_version

+

string

+

The operating system version running on the remote device.

+

Returned: gather_subset contains default

+
+
+

Authors

+
    +
  • Egor Zaitsev (@heuels)

  • +
  • Nikolay Dachev (@NikolayDachev)

  • +
  • Felix Fontein (@felixfontein)

  • +
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/api_find_and_modify_module.html b/tag/3.5.0/api_find_and_modify_module.html new file mode 100644 index 0000000..c97dc6c --- /dev/null +++ b/tag/3.5.0/api_find_and_modify_module.html @@ -0,0 +1,580 @@ + + + + + + + + + + community.routeros.api_find_and_modify module – Find and modify information using the API — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.api_find_and_modify module – Find and modify information using the API

+
+

Note

+

This module is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros. +You need further requirements to be able to use this module, +see Requirements for details.

+

To use it in a playbook, specify: community.routeros.api_find_and_modify.

+
+

New in community.routeros 2.1.0

+ +
+

Synopsis

+
    +
  • Allows to find entries for a path by conditions and modify the values of these entries.

  • +
  • Use the community.routeros.api_find_and_modify module to set all entries of a path to specific values, or change multiple entries in different ways in one step.

  • +
+
+
+

Requirements

+

The below requirements are needed on the host that executes this module.

+
    +
  • librouteros

  • +
  • Python >= 3.6 (for librouteros)

  • +
+
+
+

Parameters

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Parameter

Comments

+

allow_no_matches

+

boolean

+

Whether to allow that no match is found.

+

If not specified, this value is induced from whether require_matches_min is 0 or larger.

+

Choices:

+
    +
  • false

  • +
  • true

  • +
+
+

ca_path

+

path

+

added in community.routeros 1.2.0

+

PEM formatted file that contains a CA certificate to be used for certificate validation.

+

See also validate_cert_hostname. Only used when tls=true and validate_certs=true.

+
+

encoding

+

string

+

added in community.routeros 2.1.0

+

Use the specified encoding when communicating with the RouterOS device.

+

Default is ASCII. Note that UTF-8 requires librouteros 3.2.1 or newer.

+

Default: "ASCII"

+
+

find

+

dictionary / required

+

Fields to search for.

+

The module will only consider entries in the given path that match all fields provided here.

+

Use YAML ~, or prepend keys with !, to specify an unset value.

+

Note that if the dictionary specified here is empty, every entry in the path will be matched.

+
+

force_no_cert

+

boolean

+

added in community.routeros 2.4.0

+

Set to true to connect without a certificate when tls=true.

+

See also validate_certs.

+

Note: this forces the use of anonymous Diffie-Hellman (ADH) ciphers. The protocol is susceptible to Man-in-the-Middle attacks, because the keys used in the exchange are not authenticated. Instead of simply connecting without a certificate to “make things work” have a look at validate_certs and ca_path.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

hostname

+

string / required

+

RouterOS hostname API.

+
+

password

+

string / required

+

RouterOS user password.

+
+

path

+

string / required

+

Path to query.

+

An example value is ip address. This is equivalent to running /ip address in the RouterOS CLI.

+
+

port

+

integer

+

RouterOS API port. If tls is set, port will apply to TLS/SSL connection.

+

Defaults are 8728 for the HTTP API, and 8729 for the HTTPS API.

+
+

require_matches_max

+

integer

+

Make sure that there are no more matches than this number.

+

If there are more matches, fail instead of modifying anything.

+

If not specified, there is no upper limit.

+
+

require_matches_min

+

integer

+

Make sure that there are no less matches than this number.

+

If there are less matches, fail instead of modifying anything.

+

Default: 0

+
+

timeout

+

integer

+

added in community.routeros 2.3.0

+

Timeout for the request.

+

Default: 10

+
+
+

tls

+

aliases: ssl

+

boolean

+

If is set TLS will be used for RouterOS API connection.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

username

+

string / required

+

RouterOS login user.

+
+

validate_cert_hostname

+

boolean

+

added in community.routeros 1.2.0

+

Set to true to validate hostnames in certificates.

+

See also validate_certs. Only used when tls=true and validate_certs=true.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

validate_certs

+

boolean

+

added in community.routeros 1.2.0

+

Set to false to skip validation of TLS certificates.

+

See also validate_cert_hostname. Only used when tls=true.

+

Note: instead of simply deactivating certificate validations to “make things work”, please consider creating your own CA certificate and using it to sign certificates used for your router. You can tell the module about your CA certificate with the ca_path option.

+

Choices:

+
    +
  • false

  • +
  • true ← (default)

  • +
+
+

values

+

dictionary / required

+

On all entries matching the conditions in find, set the keys of this option to the values specified here.

+

Use YAML ~, or prepend keys with !, to specify to unset a value.

+
+
+
+

Attributes

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Attribute

Support

Description

+

action_group

+

Action group: community.routeros.api

+

Use group/community.routeros.api in module_defaults to set defaults for this module.

+
+

check_mode

+

Support: full

+

Can run in check_mode and return changed status prediction without modifying target.

+
+

diff_mode

+

Support: full

+

Will return details on what has changed (or possibly needs changing in check_mode), when in diff mode.

+
+

idempotent

+

Support: full

+

When run twice in a row outside check mode, with the same arguments, the second invocation indicates no change.

+

This assumes that the system controlled/queried by the module has not changed in a relevant way.

+
+

platform

+

Platform: RouterOS

+

Target OS/families that can be operated against.

+
+
+
+

Notes

+
+

Note

+
    +
  • If you want to change values based on their old values (like change all comments ‘foo’ to ‘bar’) and make sure that there are at least N such values, you can use require_matches_min=N together with allow_no_matches=true. This will make the module fail if there are less than N such entries, but not if there is no match. The latter case is needed for idempotency of the task: once the values have been changed, there should be no further match.

  • +
+
+
+
+

See Also

+
+

See also

+
+
community.routeros.api

Ansible module for RouterOS API.

+
+
community.routeros.api_facts

Collect facts from remote devices running MikroTik RouterOS using the API.

+
+
community.routeros.api_modify

Modify data at paths with API.

+
+
community.routeros.api_info

Retrieve information from API.

+
+
How to connect to RouterOS devices with the RouterOS API

How to connect to RouterOS devices with the RouterOS API.

+
+
+
+
+
+

Examples

+
- name: Rename bridge from 'bridge' to 'my-bridge'
+  community.routeros.api_find_and_modify:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: interface bridge
+    find:
+      name: bridge
+    values:
+      name: my-bridge
+
+- name: Change IP address to 192.168.1.1 for interface bridge - assuming there is only one
+  community.routeros.api_find_and_modify:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: ip address
+    find:
+      interface: bridge
+    values:
+      address: "192.168.1.1/24"
+  # If there are zero entries, or more than one: fail! We expected that
+  # exactly one is configured.
+    require_matches_min: 1
+    require_matches_max: 1
+
+
+
+
+

Return Values

+

Common return values are documented here, the following are the fields unique to this module:

+ + + + + + + + + + + + + + + + + + + + +

Key

Description

+

match_count

+

integer

+

The number of entries that matched the criteria in find.

+

Returned: success

+

Sample: 1

+
+

modify__count

+

integer

+

The number of entries that were modified.

+

Returned: success

+

Sample: 1

+
+

new_data

+

list / elements=dictionary

+

A list of all elements for the current path after a change was made.

+

Returned: success

+

Sample: [{".id": "*1", "actual-interface": "bridge", "address": "192.168.1.1/24", "comment": "awesome", "disabled": false, "dynamic": false, "interface": "bridge", "invalid": false, "network": "192.168.1.0"}]

+
+

old_data

+

list / elements=dictionary

+

A list of all elements for the current path before a change was made.

+

Returned: success

+

Sample: [{".id": "*1", "actual-interface": "bridge", "address": "192.168.88.1/24", "comment": "defconf", "disabled": false, "dynamic": false, "interface": "bridge", "invalid": false, "network": "192.168.88.0"}]

+
+
+

Authors

+
    +
  • Felix Fontein (@felixfontein)

  • +
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/api_info_module.html b/tag/3.5.0/api_info_module.html new file mode 100644 index 0000000..6fedfca --- /dev/null +++ b/tag/3.5.0/api_info_module.html @@ -0,0 +1,862 @@ + + + + + + + + + + community.routeros.api_info module – Retrieve information from API — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.api_info module – Retrieve information from API

+
+

Note

+

This module is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros. +You need further requirements to be able to use this module, +see Requirements for details.

+

To use it in a playbook, specify: community.routeros.api_info.

+
+

New in community.routeros 2.2.0

+ +
+

Synopsis

+ +
+
+

Requirements

+

The below requirements are needed on the host that executes this module.

+
    +
  • librouteros

  • +
  • Python >= 3.6 (for librouteros)

  • +
+
+
+

Parameters

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Parameter

Comments

+

ca_path

+

path

+

added in community.routeros 1.2.0

+

PEM formatted file that contains a CA certificate to be used for certificate validation.

+

See also validate_cert_hostname. Only used when tls=true and validate_certs=true.

+
+

encoding

+

string

+

added in community.routeros 2.1.0

+

Use the specified encoding when communicating with the RouterOS device.

+

Default is ASCII. Note that UTF-8 requires librouteros 3.2.1 or newer.

+

Default: "ASCII"

+
+

force_no_cert

+

boolean

+

added in community.routeros 2.4.0

+

Set to true to connect without a certificate when tls=true.

+

See also validate_certs.

+

Note: this forces the use of anonymous Diffie-Hellman (ADH) ciphers. The protocol is susceptible to Man-in-the-Middle attacks, because the keys used in the exchange are not authenticated. Instead of simply connecting without a certificate to “make things work” have a look at validate_certs and ca_path.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

handle_disabled

+

string

+

How to handle unset values.

+

exclamation prepends the keys with ! in the output with value null.

+

null-value uses the regular key with value null.

+

omit omits these values from the result.

+

Choices:

+
    +
  • "exclamation" ← (default)

  • +
  • "null-value"

  • +
  • "omit"

  • +
+
+

hide_defaults

+

boolean

+

Whether to hide default values.

+

Choices:

+
    +
  • false

  • +
  • true ← (default)

  • +
+
+

hostname

+

string / required

+

RouterOS hostname API.

+
+

include_builtin

+

boolean

+

added in community.routeros 2.4.0

+

Whether to include builtin values.

+

By default, they are not returned, and the builtin keys are omitted.

+

If set to true, they are returned as well, and the builtin keys are returned as well.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

include_dynamic

+

boolean

+

Whether to include dynamic values.

+

By default, they are not returned, and the dynamic keys are omitted.

+

If set to true, they are returned as well, and the dynamic keys are returned as well.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

include_read_only

+

boolean

+

added in community.routeros 2.10.0

+

Whether to include read-only fields.

+

By default, they are not returned.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

password

+

string / required

+

RouterOS user password.

+
+

path

+

string / required

+

Path to query.

+

An example value is ip address. This is equivalent to running /ip address print in the RouterOS CLI.

+

Choices:

+
    +
  • "caps-man aaa"

  • +
  • "caps-man access-list"

  • +
  • "caps-man channel"

  • +
  • "caps-man configuration"

  • +
  • "caps-man datapath"

  • +
  • "caps-man manager"

  • +
  • "caps-man manager interface"

  • +
  • "caps-man provisioning"

  • +
  • "caps-man security"

  • +
  • "certificate settings"

  • +
  • "interface 6to4"

  • +
  • "interface bonding"

  • +
  • "interface bridge"

  • +
  • "interface bridge mlag"

  • +
  • "interface bridge port"

  • +
  • "interface bridge port-controller"

  • +
  • "interface bridge port-extender"

  • +
  • "interface bridge settings"

  • +
  • "interface bridge vlan"

  • +
  • "interface detect-internet"

  • +
  • "interface eoip"

  • +
  • "interface ethernet"

  • +
  • "interface ethernet poe"

  • +
  • "interface ethernet switch"

  • +
  • "interface ethernet switch port"

  • +
  • "interface gre"

  • +
  • "interface gre6"

  • +
  • "interface l2tp-client"

  • +
  • "interface l2tp-server server"

  • +
  • "interface list"

  • +
  • "interface list member"

  • +
  • "interface ovpn-client"

  • +
  • "interface ovpn-server server"

  • +
  • "interface ppp-client"

  • +
  • "interface pppoe-client"

  • +
  • "interface pppoe-server server"

  • +
  • "interface pptp-server server"

  • +
  • "interface sstp-server server"

  • +
  • "interface vlan"

  • +
  • "interface vrrp"

  • +
  • "interface wifi"

  • +
  • "interface wifi aaa"

  • +
  • "interface wifi access-list"

  • +
  • "interface wifi cap"

  • +
  • "interface wifi capsman"

  • +
  • "interface wifi channel"

  • +
  • "interface wifi configuration"

  • +
  • "interface wifi datapath"

  • +
  • "interface wifi interworking"

  • +
  • "interface wifi provisioning"

  • +
  • "interface wifi security"

  • +
  • "interface wifi steering"

  • +
  • "interface wifiwave2"

  • +
  • "interface wifiwave2 aaa"

  • +
  • "interface wifiwave2 access-list"

  • +
  • "interface wifiwave2 cap"

  • +
  • "interface wifiwave2 capsman"

  • +
  • "interface wifiwave2 channel"

  • +
  • "interface wifiwave2 configuration"

  • +
  • "interface wifiwave2 datapath"

  • +
  • "interface wifiwave2 interworking"

  • +
  • "interface wifiwave2 provisioning"

  • +
  • "interface wifiwave2 security"

  • +
  • "interface wifiwave2 steering"

  • +
  • "interface wireguard"

  • +
  • "interface wireguard peers"

  • +
  • "interface wireless"

  • +
  • "interface wireless access-list"

  • +
  • "interface wireless align"

  • +
  • "interface wireless cap"

  • +
  • "interface wireless connect-list"

  • +
  • "interface wireless security-profiles"

  • +
  • "interface wireless sniffer"

  • +
  • "interface wireless snooper"

  • +
  • "iot modbus"

  • +
  • "ip accounting"

  • +
  • "ip accounting web-access"

  • +
  • "ip address"

  • +
  • "ip arp"

  • +
  • "ip cloud"

  • +
  • "ip cloud advanced"

  • +
  • "ip dhcp-client"

  • +
  • "ip dhcp-client option"

  • +
  • "ip dhcp-relay"

  • +
  • "ip dhcp-server"

  • +
  • "ip dhcp-server config"

  • +
  • "ip dhcp-server lease"

  • +
  • "ip dhcp-server matcher"

  • +
  • "ip dhcp-server network"

  • +
  • "ip dhcp-server option"

  • +
  • "ip dhcp-server option sets"

  • +
  • "ip dns"

  • +
  • "ip dns adlist"

  • +
  • "ip dns forwarders"

  • +
  • "ip dns static"

  • +
  • "ip firewall address-list"

  • +
  • "ip firewall connection tracking"

  • +
  • "ip firewall filter"

  • +
  • "ip firewall layer7-protocol"

  • +
  • "ip firewall mangle"

  • +
  • "ip firewall nat"

  • +
  • "ip firewall raw"

  • +
  • "ip firewall service-port"

  • +
  • "ip hotspot service-port"

  • +
  • "ip ipsec identity"

  • +
  • "ip ipsec peer"

  • +
  • "ip ipsec policy"

  • +
  • "ip ipsec profile"

  • +
  • "ip ipsec proposal"

  • +
  • "ip ipsec settings"

  • +
  • "ip neighbor discovery-settings"

  • +
  • "ip pool"

  • +
  • "ip proxy"

  • +
  • "ip route"

  • +
  • "ip route rule"

  • +
  • "ip route vrf"

  • +
  • "ip service"

  • +
  • "ip settings"

  • +
  • "ip smb"

  • +
  • "ip socks"

  • +
  • "ip ssh"

  • +
  • "ip tftp settings"

  • +
  • "ip traffic-flow"

  • +
  • "ip traffic-flow ipfix"

  • +
  • "ip traffic-flow target"

  • +
  • "ip upnp"

  • +
  • "ip upnp interfaces"

  • +
  • "ip vrf"

  • +
  • "ipv6 address"

  • +
  • "ipv6 dhcp-client"

  • +
  • "ipv6 dhcp-server"

  • +
  • "ipv6 dhcp-server option"

  • +
  • "ipv6 firewall address-list"

  • +
  • "ipv6 firewall filter"

  • +
  • "ipv6 firewall mangle"

  • +
  • "ipv6 firewall nat"

  • +
  • "ipv6 firewall raw"

  • +
  • "ipv6 nd"

  • +
  • "ipv6 nd prefix"

  • +
  • "ipv6 nd prefix default"

  • +
  • "ipv6 route"

  • +
  • "ipv6 settings"

  • +
  • "mpls"

  • +
  • "mpls interface"

  • +
  • "mpls ldp"

  • +
  • "mpls ldp accept-filter"

  • +
  • "mpls ldp advertise-filter"

  • +
  • "mpls ldp interface"

  • +
  • "port firmware"

  • +
  • "port remote-access"

  • +
  • "ppp aaa"

  • +
  • "ppp profile"

  • +
  • "ppp secret"

  • +
  • "queue interface"

  • +
  • "queue simple"

  • +
  • "queue tree"

  • +
  • "queue type"

  • +
  • "radius"

  • +
  • "radius incoming"

  • +
  • "routing bgp aggregate"

  • +
  • "routing bgp connection"

  • +
  • "routing bgp instance"

  • +
  • "routing bgp network"

  • +
  • "routing bgp peer"

  • +
  • "routing bgp template"

  • +
  • "routing filter"

  • +
  • "routing filter community-list"

  • +
  • "routing filter num-list"

  • +
  • "routing filter rule"

  • +
  • "routing filter select-rule"

  • +
  • "routing id"

  • +
  • "routing igmp-proxy"

  • +
  • "routing igmp-proxy interface"

  • +
  • "routing mme"

  • +
  • "routing ospf area"

  • +
  • "routing ospf area range"

  • +
  • "routing ospf instance"

  • +
  • "routing ospf interface-template"

  • +
  • "routing ospf static-neighbor"

  • +
  • "routing pimsm instance"

  • +
  • "routing pimsm interface-template"

  • +
  • "routing rip"

  • +
  • "routing ripng"

  • +
  • "routing rule"

  • +
  • "routing table"

  • +
  • "snmp"

  • +
  • "snmp community"

  • +
  • "system clock"

  • +
  • "system clock manual"

  • +
  • "system health settings"

  • +
  • "system identity"

  • +
  • "system leds settings"

  • +
  • "system logging"

  • +
  • "system logging action"

  • +
  • "system note"

  • +
  • "system ntp client"

  • +
  • "system ntp client servers"

  • +
  • "system ntp server"

  • +
  • "system package update"

  • +
  • "system resource irq rps"

  • +
  • "system routerboard settings"

  • +
  • "system scheduler"

  • +
  • "system script"

  • +
  • "system upgrade mirror"

  • +
  • "system ups"

  • +
  • "system watchdog"

  • +
  • "tool bandwidth-server"

  • +
  • "tool e-mail"

  • +
  • "tool graphing"

  • +
  • "tool graphing interface"

  • +
  • "tool graphing resource"

  • +
  • "tool mac-server"

  • +
  • "tool mac-server mac-winbox"

  • +
  • "tool mac-server ping"

  • +
  • "tool netwatch"

  • +
  • "tool romon"

  • +
  • "tool sms"

  • +
  • "tool sniffer"

  • +
  • "tool traffic-generator"

  • +
  • "user"

  • +
  • "user aaa"

  • +
  • "user group"

  • +
  • "user settings"

  • +
+
+

port

+

integer

+

RouterOS API port. If tls is set, port will apply to TLS/SSL connection.

+

Defaults are 8728 for the HTTP API, and 8729 for the HTTPS API.

+
+

restrict

+

list / elements=dictionary

+

added in community.routeros 2.18.0

+

Restrict output to entries matching the following criteria.

+
+

field

+

string / required

+

The field whose values to restrict.

+
+

invert

+

boolean

+

Invert the condition. This affects restrict[].match_disabled, restrict[].values, and restrict[].regex.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

match_disabled

+

boolean

+

Whether disabled or not provided values should match.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

regex

+

string

+

A regular expression matching values of the field to limit to.

+

Note that all values will be converted to strings before matching.

+

It is not possible to match disabled values with regular expressions. Set restrict[].match_disabled=true if you also want to match disabled values.

+
+

values

+

list / elements=any

+

The values of the field to limit to.

+

Note that the types of the values are important. If you provide a string "0", and librouteros converts the value returned by the API to the integer 0, then this will not match. If you are not sure, better include both variants: both the string and the integer.

+
+

timeout

+

integer

+

added in community.routeros 2.3.0

+

Timeout for the request.

+

Default: 10

+
+
+

tls

+

aliases: ssl

+

boolean

+

If is set TLS will be used for RouterOS API connection.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

unfiltered

+

boolean

+

Whether to output all fields, and not just the ones supported as input for community.routeros.api_modify.

+

Unfiltered output can contain counters and other state information.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

username

+

string / required

+

RouterOS login user.

+
+

validate_cert_hostname

+

boolean

+

added in community.routeros 1.2.0

+

Set to true to validate hostnames in certificates.

+

See also validate_certs. Only used when tls=true and validate_certs=true.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

validate_certs

+

boolean

+

added in community.routeros 1.2.0

+

Set to false to skip validation of TLS certificates.

+

See also validate_cert_hostname. Only used when tls=true.

+

Note: instead of simply deactivating certificate validations to “make things work”, please consider creating your own CA certificate and using it to sign certificates used for your router. You can tell the module about your CA certificate with the ca_path option.

+

Choices:

+
    +
  • false

  • +
  • true ← (default)

  • +
+
+
+
+

Attributes

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Attribute

Support

Description

+

action_group

+

Action group: community.routeros.api

+

Use group/community.routeros.api in module_defaults to set defaults for this module.

+
+

check_mode

+

Support: full

+

This action does not modify state.

+

Can run in check_mode and return changed status prediction without modifying target.

+
+

diff_mode

+

Support: N/A

+

This action does not modify state.

+

Will return details on what has changed (or possibly needs changing in check_mode), when in diff mode.

+
+

idempotent

+

Support: full

+

This action does not modify state.

+

When run twice in a row outside check mode, with the same arguments, the second invocation indicates no change.

+

This assumes that the system controlled/queried by the module has not changed in a relevant way.

+
+

platform

+

Platform: RouterOS

+

Target OS/families that can be operated against.

+
+
+
+

See Also

+
+

See also

+
+
community.routeros.api

Ansible module for RouterOS API.

+
+
community.routeros.api_facts

Collect facts from remote devices running MikroTik RouterOS using the API.

+
+
community.routeros.api_find_and_modify

Find and modify information using the API.

+
+
community.routeros.api_modify

Modify data at paths with API.

+
+
How to connect to RouterOS devices with the RouterOS API

How to connect to RouterOS devices with the RouterOS API.

+
+
+
+
+
+

Examples

+
- name: Get IP addresses
+  community.routeros.api_info:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: ip address
+  register: ip_addresses
+
+- name: Print data for IP addresses
+  ansible.builtin.debug:
+    var: ip_addresses.result
+
+- name: Get IP addresses
+  community.routeros.api_info:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: ip address
+  register: ip_addresses
+
+- name: Print data for IP addresses
+  ansible.builtin.debug:
+    var: ip_addresses.result
+
+
+
+
+

Return Values

+

Common return values are documented here, the following are the fields unique to this module:

+ + + + + + + + + + + +

Key

Description

+

result

+

list / elements=dictionary

+

A list of all elements for the current path.

+

Returned: always

+

Sample: [{".id": "*1", "actual-interface": "bridge", "address": "192.168.88.1/24", "comment": "defconf", "disabled": false, "dynamic": false, "interface": "bridge", "invalid": false, "network": "192.168.88.0"}]

+
+
+

Authors

+
    +
  • Felix Fontein (@felixfontein)

  • +
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/api_modify_module.html b/tag/3.5.0/api_modify_module.html new file mode 100644 index 0000000..8bc9702 --- /dev/null +++ b/tag/3.5.0/api_modify_module.html @@ -0,0 +1,916 @@ + + + + + + + + + + community.routeros.api_modify module – Modify data at paths with API — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.api_modify module – Modify data at paths with API

+
+

Note

+

This module is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros. +You need further requirements to be able to use this module, +see Requirements for details.

+

To use it in a playbook, specify: community.routeros.api_modify.

+
+

New in community.routeros 2.2.0

+ +
+

Synopsis

+
    +
  • Allows to modify information for a path using the API.

  • +
  • Use the community.routeros.api_find_and_modify module to modify one or multiple entries in a controlled way depending on some search conditions.

  • +
  • To make a backup of a path that can be restored with this module, use the community.routeros.api_info module.

  • +
  • The module ignores dynamic and builtin entries.

  • +
  • Note that this module is still heavily in development, and only supports some paths. If you want to support new paths, or think you found problems with existing paths, please first create an issue in the community.routeros Issue Tracker.

  • +
+
+
+

Requirements

+

The below requirements are needed on the host that executes this module.

+
    +
  • Needs ordereddict for Python 2.6

  • +
  • Python >= 3.6 (for librouteros)

  • +
  • librouteros

  • +
+
+
+

Parameters

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Parameter

Comments

+

ca_path

+

path

+

added in community.routeros 1.2.0

+

PEM formatted file that contains a CA certificate to be used for certificate validation.

+

See also validate_cert_hostname. Only used when tls=true and validate_certs=true.

+
+

data

+

list / elements=dictionary / required

+

Data to ensure that is present for this path.

+

Fields not provided will not be modified.

+

If .id appears in an entry, it will be ignored.

+
+

encoding

+

string

+

added in community.routeros 2.1.0

+

Use the specified encoding when communicating with the RouterOS device.

+

Default is ASCII. Note that UTF-8 requires librouteros 3.2.1 or newer.

+

Default: "ASCII"

+
+

ensure_order

+

boolean

+

Whether to ensure the same order of the config as present in data.

+

Requires handle_absent_entries=remove.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

force_no_cert

+

boolean

+

added in community.routeros 2.4.0

+

Set to true to connect without a certificate when tls=true.

+

See also validate_certs.

+

Note: this forces the use of anonymous Diffie-Hellman (ADH) ciphers. The protocol is susceptible to Man-in-the-Middle attacks, because the keys used in the exchange are not authenticated. Instead of simply connecting without a certificate to “make things work” have a look at validate_certs and ca_path.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

handle_absent_entries

+

string

+

How to handle entries that are present in the current config, but not in data.

+

ignore ignores them.

+

remove removes them.

+

Choices:

+
    +
  • "ignore" ← (default)

  • +
  • "remove"

  • +
+
+

handle_entries_content

+

string

+

For a single entry in data, this describes how to handle fields that are not mentioned in that entry, but appear in the actual config.

+

If ignore, they are not modified.

+

If remove, they are removed. If at least one cannot be removed, the module will fail.

+

If remove_as_much_as_possible, all that can be removed will be removed. The ones that cannot be removed will be kept.

+

Note that remove and remove_as_much_as_possible do not apply to write-only fields.

+

Choices:

+
    +
  • "ignore" ← (default)

  • +
  • "remove"

  • +
  • "remove_as_much_as_possible"

  • +
+
+

handle_read_only

+

string

+

added in community.routeros 2.10.0

+

How to handle values passed in for read-only fields.

+

If ignore, they are not passed to the API.

+

If validate, the values are not passed for creation, and for updating they are compared to the value returned for the object. If they differ, the module fails.

+

If error, the module will fail if read-only fields are provided.

+

Choices:

+
    +
  • "ignore"

  • +
  • "validate"

  • +
  • "error" ← (default)

  • +
+
+

handle_write_only

+

string

+

added in community.routeros 2.10.0

+

How to handle values passed in for write-only fields.

+

If create_only, they are passed on creation, and ignored for updating.

+

If always_update, they are always passed to the API. This means that if such a value is present, the module will always result in changed since there is no way to validate whether the value actually changed.

+

If error, the module will fail if write-only fields are provided.

+

Choices:

+
    +
  • "create_only" ← (default)

  • +
  • "always_update"

  • +
  • "error"

  • +
+
+

hostname

+

string / required

+

RouterOS hostname API.

+
+

password

+

string / required

+

RouterOS user password.

+
+

path

+

string / required

+

Path to query.

+

An example value is ip address. This is equivalent to running modification commands in /ip address in the RouterOS CLI.

+

Choices:

+
    +
  • "caps-man aaa"

  • +
  • "caps-man access-list"

  • +
  • "caps-man channel"

  • +
  • "caps-man configuration"

  • +
  • "caps-man datapath"

  • +
  • "caps-man manager"

  • +
  • "caps-man manager interface"

  • +
  • "caps-man provisioning"

  • +
  • "caps-man security"

  • +
  • "certificate settings"

  • +
  • "interface 6to4"

  • +
  • "interface bonding"

  • +
  • "interface bridge"

  • +
  • "interface bridge mlag"

  • +
  • "interface bridge port"

  • +
  • "interface bridge port-controller"

  • +
  • "interface bridge port-extender"

  • +
  • "interface bridge settings"

  • +
  • "interface bridge vlan"

  • +
  • "interface detect-internet"

  • +
  • "interface eoip"

  • +
  • "interface ethernet"

  • +
  • "interface ethernet poe"

  • +
  • "interface ethernet switch"

  • +
  • "interface ethernet switch port"

  • +
  • "interface gre"

  • +
  • "interface gre6"

  • +
  • "interface l2tp-client"

  • +
  • "interface l2tp-server server"

  • +
  • "interface list"

  • +
  • "interface list member"

  • +
  • "interface ovpn-client"

  • +
  • "interface ovpn-server server"

  • +
  • "interface ppp-client"

  • +
  • "interface pppoe-client"

  • +
  • "interface pppoe-server server"

  • +
  • "interface pptp-server server"

  • +
  • "interface sstp-server server"

  • +
  • "interface vlan"

  • +
  • "interface vrrp"

  • +
  • "interface wifi"

  • +
  • "interface wifi aaa"

  • +
  • "interface wifi access-list"

  • +
  • "interface wifi cap"

  • +
  • "interface wifi capsman"

  • +
  • "interface wifi channel"

  • +
  • "interface wifi configuration"

  • +
  • "interface wifi datapath"

  • +
  • "interface wifi interworking"

  • +
  • "interface wifi provisioning"

  • +
  • "interface wifi security"

  • +
  • "interface wifi steering"

  • +
  • "interface wifiwave2"

  • +
  • "interface wifiwave2 aaa"

  • +
  • "interface wifiwave2 access-list"

  • +
  • "interface wifiwave2 cap"

  • +
  • "interface wifiwave2 capsman"

  • +
  • "interface wifiwave2 channel"

  • +
  • "interface wifiwave2 configuration"

  • +
  • "interface wifiwave2 datapath"

  • +
  • "interface wifiwave2 interworking"

  • +
  • "interface wifiwave2 provisioning"

  • +
  • "interface wifiwave2 security"

  • +
  • "interface wifiwave2 steering"

  • +
  • "interface wireguard"

  • +
  • "interface wireguard peers"

  • +
  • "interface wireless"

  • +
  • "interface wireless access-list"

  • +
  • "interface wireless align"

  • +
  • "interface wireless cap"

  • +
  • "interface wireless connect-list"

  • +
  • "interface wireless security-profiles"

  • +
  • "interface wireless sniffer"

  • +
  • "interface wireless snooper"

  • +
  • "iot modbus"

  • +
  • "ip accounting"

  • +
  • "ip accounting web-access"

  • +
  • "ip address"

  • +
  • "ip arp"

  • +
  • "ip cloud"

  • +
  • "ip cloud advanced"

  • +
  • "ip dhcp-client"

  • +
  • "ip dhcp-client option"

  • +
  • "ip dhcp-relay"

  • +
  • "ip dhcp-server"

  • +
  • "ip dhcp-server config"

  • +
  • "ip dhcp-server lease"

  • +
  • "ip dhcp-server matcher"

  • +
  • "ip dhcp-server network"

  • +
  • "ip dhcp-server option"

  • +
  • "ip dhcp-server option sets"

  • +
  • "ip dns"

  • +
  • "ip dns adlist"

  • +
  • "ip dns forwarders"

  • +
  • "ip dns static"

  • +
  • "ip firewall address-list"

  • +
  • "ip firewall connection tracking"

  • +
  • "ip firewall filter"

  • +
  • "ip firewall layer7-protocol"

  • +
  • "ip firewall mangle"

  • +
  • "ip firewall nat"

  • +
  • "ip firewall raw"

  • +
  • "ip firewall service-port"

  • +
  • "ip hotspot service-port"

  • +
  • "ip ipsec identity"

  • +
  • "ip ipsec peer"

  • +
  • "ip ipsec policy"

  • +
  • "ip ipsec profile"

  • +
  • "ip ipsec proposal"

  • +
  • "ip ipsec settings"

  • +
  • "ip neighbor discovery-settings"

  • +
  • "ip pool"

  • +
  • "ip proxy"

  • +
  • "ip route"

  • +
  • "ip route rule"

  • +
  • "ip route vrf"

  • +
  • "ip service"

  • +
  • "ip settings"

  • +
  • "ip smb"

  • +
  • "ip socks"

  • +
  • "ip ssh"

  • +
  • "ip tftp settings"

  • +
  • "ip traffic-flow"

  • +
  • "ip traffic-flow ipfix"

  • +
  • "ip traffic-flow target"

  • +
  • "ip upnp"

  • +
  • "ip upnp interfaces"

  • +
  • "ip vrf"

  • +
  • "ipv6 address"

  • +
  • "ipv6 dhcp-client"

  • +
  • "ipv6 dhcp-server"

  • +
  • "ipv6 dhcp-server option"

  • +
  • "ipv6 firewall address-list"

  • +
  • "ipv6 firewall filter"

  • +
  • "ipv6 firewall mangle"

  • +
  • "ipv6 firewall nat"

  • +
  • "ipv6 firewall raw"

  • +
  • "ipv6 nd"

  • +
  • "ipv6 nd prefix"

  • +
  • "ipv6 nd prefix default"

  • +
  • "ipv6 route"

  • +
  • "ipv6 settings"

  • +
  • "mpls"

  • +
  • "mpls interface"

  • +
  • "mpls ldp"

  • +
  • "mpls ldp accept-filter"

  • +
  • "mpls ldp advertise-filter"

  • +
  • "mpls ldp interface"

  • +
  • "port firmware"

  • +
  • "port remote-access"

  • +
  • "ppp aaa"

  • +
  • "ppp profile"

  • +
  • "ppp secret"

  • +
  • "queue interface"

  • +
  • "queue simple"

  • +
  • "queue tree"

  • +
  • "queue type"

  • +
  • "radius"

  • +
  • "radius incoming"

  • +
  • "routing bgp aggregate"

  • +
  • "routing bgp connection"

  • +
  • "routing bgp instance"

  • +
  • "routing bgp network"

  • +
  • "routing bgp peer"

  • +
  • "routing bgp template"

  • +
  • "routing filter"

  • +
  • "routing filter community-list"

  • +
  • "routing filter num-list"

  • +
  • "routing filter rule"

  • +
  • "routing filter select-rule"

  • +
  • "routing id"

  • +
  • "routing igmp-proxy"

  • +
  • "routing igmp-proxy interface"

  • +
  • "routing mme"

  • +
  • "routing ospf area"

  • +
  • "routing ospf area range"

  • +
  • "routing ospf instance"

  • +
  • "routing ospf interface-template"

  • +
  • "routing ospf static-neighbor"

  • +
  • "routing pimsm instance"

  • +
  • "routing pimsm interface-template"

  • +
  • "routing rip"

  • +
  • "routing ripng"

  • +
  • "routing rule"

  • +
  • "routing table"

  • +
  • "snmp"

  • +
  • "snmp community"

  • +
  • "system clock"

  • +
  • "system clock manual"

  • +
  • "system health settings"

  • +
  • "system identity"

  • +
  • "system leds settings"

  • +
  • "system logging"

  • +
  • "system logging action"

  • +
  • "system note"

  • +
  • "system ntp client"

  • +
  • "system ntp client servers"

  • +
  • "system ntp server"

  • +
  • "system package update"

  • +
  • "system resource irq rps"

  • +
  • "system routerboard settings"

  • +
  • "system scheduler"

  • +
  • "system script"

  • +
  • "system upgrade mirror"

  • +
  • "system ups"

  • +
  • "system watchdog"

  • +
  • "tool bandwidth-server"

  • +
  • "tool e-mail"

  • +
  • "tool graphing"

  • +
  • "tool graphing interface"

  • +
  • "tool graphing resource"

  • +
  • "tool mac-server"

  • +
  • "tool mac-server mac-winbox"

  • +
  • "tool mac-server ping"

  • +
  • "tool netwatch"

  • +
  • "tool romon"

  • +
  • "tool sms"

  • +
  • "tool sniffer"

  • +
  • "tool traffic-generator"

  • +
  • "user"

  • +
  • "user aaa"

  • +
  • "user group"

  • +
  • "user settings"

  • +
+
+

port

+

integer

+

RouterOS API port. If tls is set, port will apply to TLS/SSL connection.

+

Defaults are 8728 for the HTTP API, and 8729 for the HTTPS API.

+
+

restrict

+

list / elements=dictionary

+

added in community.routeros 2.18.0

+

Restrict operation to entries matching the following criteria.

+

This can be useful together with handle_absent_entries=remove to operate on a subset of the values.

+

For example, for path=ip firewall filter, you can set restrict[].field=chain and restrict[].values=input to restrict operation to the input chain, and ignore the forward and output chains.

+
+

field

+

string / required

+

The field whose values to restrict.

+
+

invert

+

boolean

+

Invert the condition. This affects restrict[].match_disabled, restrict[].values, and restrict[].regex.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

match_disabled

+

boolean

+

Whether disabled or not provided values should match.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

regex

+

string

+

A regular expression matching values of the field to limit to.

+

Note that all values will be converted to strings before matching.

+

It is not possible to match disabled values with regular expressions. Set restrict[].match_disabled=true if you also want to match disabled values.

+
+

values

+

list / elements=any

+

The values of the field to limit to.

+

Note that the types of the values are important. If you provide a string "0", and librouteros converts the value returned by the API to the integer 0, then this will not match. If you are not sure, better include both variants: both the string and the integer.

+
+

timeout

+

integer

+

added in community.routeros 2.3.0

+

Timeout for the request.

+

Default: 10

+
+
+

tls

+

aliases: ssl

+

boolean

+

If is set TLS will be used for RouterOS API connection.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

username

+

string / required

+

RouterOS login user.

+
+

validate_cert_hostname

+

boolean

+

added in community.routeros 1.2.0

+

Set to true to validate hostnames in certificates.

+

See also validate_certs. Only used when tls=true and validate_certs=true.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

validate_certs

+

boolean

+

added in community.routeros 1.2.0

+

Set to false to skip validation of TLS certificates.

+

See also validate_cert_hostname. Only used when tls=true.

+

Note: instead of simply deactivating certificate validations to “make things work”, please consider creating your own CA certificate and using it to sign certificates used for your router. You can tell the module about your CA certificate with the ca_path option.

+

Choices:

+
    +
  • false

  • +
  • true ← (default)

  • +
+
+
+
+

Attributes

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Attribute

Support

Description

+

action_group

+

Action group: community.routeros.api

+

Use group/community.routeros.api in module_defaults to set defaults for this module.

+
+

check_mode

+

Support: full

+

Can run in check_mode and return changed status prediction without modifying target.

+
+

diff_mode

+

Support: full

+

Will return details on what has changed (or possibly needs changing in check_mode), when in diff mode.

+
+

idempotent

+

Support: full

+

When run twice in a row outside check mode, with the same arguments, the second invocation indicates no change.

+

This assumes that the system controlled/queried by the module has not changed in a relevant way.

+
+

platform

+

Platform: RouterOS

+

Target OS/families that can be operated against.

+
+
+
+

Notes

+
+

Note

+
    +
  • If write-only fields are present in the path, the module is not idempotent in a strict sense, since it is not able to verify the current value of these fields. The behavior the module should assume can be controlled with the handle_write_only option.

  • +
+
+
+
+

See Also

+
+

See also

+
+
community.routeros.api

Ansible module for RouterOS API.

+
+
community.routeros.api_facts

Collect facts from remote devices running MikroTik RouterOS using the API.

+
+
community.routeros.api_find_and_modify

Find and modify information using the API.

+
+
community.routeros.api_info

Retrieve information from API.

+
+
How to connect to RouterOS devices with the RouterOS API

How to connect to RouterOS devices with the RouterOS API.

+
+
+
+
+
+

Examples

+
- name: Setup DHCP server networks
+  # Ensures that we have exactly two DHCP server networks (in the specified order)
+  community.routeros.api_modify:
+    path: ip dhcp-server network
+    handle_absent_entries: remove
+    handle_entries_content: remove_as_much_as_possible
+    ensure_order: true
+    data:
+      - address: 192.168.88.0/24
+        comment: admin network
+        dns-server: 192.168.88.1
+        gateway: 192.168.88.1
+      - address: 192.168.1.0/24
+        comment: customer network 1
+        dns-server: 192.168.1.1
+        gateway: 192.168.1.1
+        netmask: 24
+
+- name: Adjust NAT
+  community.routeros.api_modify:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: ip firewall nat
+    data:
+      - action: masquerade
+        chain: srcnat
+        comment: NAT to WAN
+        out-interface-list: WAN
+        # Three ways to unset values:
+        #   - nothing after `:`
+        #   - "empty" value (null/~/None)
+        #   - prepend '!'
+        out-interface:
+        to-addresses: ~
+        '!to-ports':
+
+- name: Block all incoming connections
+  community.routeros.api_modify:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: ip firewall filter
+    handle_absent_entries: remove
+    handle_entries_content: remove_as_much_as_possible
+    restrict:
+      # Do not touch any chain except the input chain
+      - field: chain
+        values:
+          - input
+    data:
+      - action: drop
+        chain: input
+
+
+
+
+

Return Values

+

Common return values are documented here, the following are the fields unique to this module:

+ + + + + + + + + + + + + + +

Key

Description

+

new_data

+

list / elements=dictionary

+

A list of all elements for the current path after a change was made.

+

Returned: always

+

Sample: [{".id": "*1", "actual-interface": "bridge", "address": "192.168.1.1/24", "comment": "awesome", "disabled": false, "dynamic": false, "interface": "bridge", "invalid": false, "network": "192.168.1.0"}]

+
+

old_data

+

list / elements=dictionary

+

A list of all elements for the current path before a change was made.

+

Returned: always

+

Sample: [{".id": "*1", "actual-interface": "bridge", "address": "192.168.88.1/24", "comment": "defconf", "disabled": false, "dynamic": false, "interface": "bridge", "invalid": false, "network": "192.168.88.0"}]

+
+
+

Authors

+
    +
  • Felix Fontein (@felixfontein)

  • +
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/api_module.html b/tag/3.5.0/api_module.html new file mode 100644 index 0000000..df0a63c --- /dev/null +++ b/tag/3.5.0/api_module.html @@ -0,0 +1,737 @@ + + + + + + + + + + community.routeros.api module – Ansible module for RouterOS API — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.api module – Ansible module for RouterOS API

+
+

Note

+

This module is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros. +You need further requirements to be able to use this module, +see Requirements for details.

+

To use it in a playbook, specify: community.routeros.api.

+
+ +
+

Synopsis

+
    +
  • Ansible module for RouterOS API with the Python librouteros library.

  • +
  • This module can add, remove, update, query, and execute arbitrary command in RouterOS through the API.

  • +
+
+
+

Requirements

+

The below requirements are needed on the host that executes this module.

+
    +
  • librouteros

  • +
  • Python >= 3.6 (for librouteros)

  • +
+
+
+

Parameters

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Parameter

Comments

+

add

+

string

+

Will add selected arguments in selected path to RouterOS config.

+

Example address=1.1.1.1/32 interface=ether1.

+

Equivalent in RouterOS CLI /ip address add address=1.1.1.1/32 interface=ether1.

+
+

ca_path

+

path

+

added in community.routeros 1.2.0

+

PEM formatted file that contains a CA certificate to be used for certificate validation.

+

See also validate_cert_hostname. Only used when tls=true and validate_certs=true.

+
+

cmd

+

string

+

Execute any/arbitrary command in selected path, after the command we can add .id.

+

Example path system script and cmd run .id=*03 is equivalent in RouterOS CLI /system script run number=0.

+

Example path ip address and cmd print is equivalent in RouterOS CLI /ip address print.

+
+

encoding

+

string

+

added in community.routeros 2.1.0

+

Use the specified encoding when communicating with the RouterOS device.

+

Default is ASCII. Note that UTF-8 requires librouteros 3.2.1 or newer.

+

Default: "ASCII"

+
+

extended_query

+

dictionary

+

Extended query given path for selected query attributes from RouterOS API.

+

Extended query allow conjunctive input. If there is no matching entry, an empty list will be returned.

+
+

attributes

+

list / elements=string / required

+

The list of attributes to return.

+

Every attribute used in a extended_query.where[] clause need to be listed here.

+
+

where

+

list / elements=dictionary

+

Allows to restrict the objects returned.

+

The conditions here must all match. An extended_query.where[].or condition needs at least one of its conditions to match.

+
+

attribute

+

string

+

The attribute to match. Must be part of extended_query.attributes.

+

Either extended_query.where[].or or all of extended_query.where[].attribute, extended_query.where[].is, and extended_query.where[].value have to be specified.

+
+

is

+

string

+

The operator to use for matching.

+

For equality use == or eq. For less use < or less. For more use > or more.

+

Use in to check whether the value is part of a list. In that case, extended_query.where[].value must be a list.

+

Either extended_query.where[].or or all of extended_query.where[].attribute, extended_query.where[].is, and extended_query.where[].value have to be specified.

+

Choices:

+
    +
  • "=="

  • +
  • "!="

  • +
  • ">"

  • +
  • "<"

  • +
  • "in"

  • +
  • "eq"

  • +
  • "not"

  • +
  • "more"

  • +
  • "less"

  • +
+
+

or

+

list / elements=dictionary

+

A list of conditions so that at least one of them has to match.

+

Either extended_query.where[].or or all of extended_query.where[].attribute, extended_query.where[].is, and extended_query.where[].value have to be specified.

+
+

attribute

+

string / required

+

The attribute to match. Must be part of extended_query.attributes.

+
+

is

+

string / required

+

The operator to use for matching.

+

For equality use == or eq. For less use < or less. For more use > or more.

+

Use in to check whether the value is part of a list. In that case, extended_query.where[].or[].value must be a list.

+

Choices:

+
    +
  • "=="

  • +
  • "!="

  • +
  • ">"

  • +
  • "<"

  • +
  • "in"

  • +
  • "eq"

  • +
  • "not"

  • +
  • "more"

  • +
  • "less"

  • +
+
+

value

+

any / required

+

The value to compare to. Must be a list for extended_query.where[].or[].is=in.

+
+

value

+

any

+

The value to compare to. Must be a list for extended_query.where[].is=in.

+

Either extended_query.where[].or or all of extended_query.where[].attribute, extended_query.where[].is, and extended_query.where[].value have to be specified.

+
+

force_no_cert

+

boolean

+

added in community.routeros 2.4.0

+

Set to true to connect without a certificate when tls=true.

+

See also validate_certs.

+

Note: this forces the use of anonymous Diffie-Hellman (ADH) ciphers. The protocol is susceptible to Man-in-the-Middle attacks, because the keys used in the exchange are not authenticated. Instead of simply connecting without a certificate to “make things work” have a look at validate_certs and ca_path.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

hostname

+

string / required

+

RouterOS hostname API.

+
+

password

+

string / required

+

RouterOS user password.

+
+

path

+

string / required

+

Main path for all other arguments.

+

If other arguments are not set, the module will return all items in selected path.

+

Example ip address. Equivalent of RouterOS CLI /ip address print.

+
+

port

+

integer

+

RouterOS API port. If tls is set, port will apply to TLS/SSL connection.

+

Defaults are 8728 for the HTTP API, and 8729 for the HTTPS API.

+
+

query

+

string

+

Query given path for selected query attributes from RouterOS API.

+

WHERE is key word which extend query. WHERE format is key operator value - with spaces.

+

WHERE valid operators are == or eq, != or not, > or more, < or less.

+

Example path ip address and query .id address will return only .id and address for all items in ip address path.

+

Example path ip address and query .id address WHERE address == 1.1.1.3/32. will return only .id and address for items in ip address path, where address is eq to 1.1.1.3/32.

+

Example path interface and query mtu name WHERE mut > 1400 will return only interfaces mtu,name where mtu is bigger than 1400.

+

Equivalent in RouterOS CLI /interface print where mtu > 1400.

+
+

remove

+

string

+

Remove config/value from RouterOS by ‘.id’.

+

Example *03 will remove config/value with id=*03 in selected path.

+

Equivalent in RouterOS CLI /ip address remove numbers=1.

+

Note number in RouterOS CLI is different from .id.

+
+

timeout

+

integer

+

added in community.routeros 2.3.0

+

Timeout for the request.

+

Default: 10

+
+
+

tls

+

aliases: ssl

+

boolean

+

If is set TLS will be used for RouterOS API connection.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

update

+

string

+

Update config/value in RouterOS by ‘.id’ in selected path.

+

Example .id=*03 address=1.1.1.3/32 and path ip address will replace the existing IP address with .id=*03.

+

Equivalent in RouterOS CLI /ip address set address=1.1.1.3/32 numbers=1.

+

Note number in RouterOS CLI is different from .id.

+
+

username

+

string / required

+

RouterOS login user.

+
+

validate_cert_hostname

+

boolean

+

added in community.routeros 1.2.0

+

Set to true to validate hostnames in certificates.

+

See also validate_certs. Only used when tls=true and validate_certs=true.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+

validate_certs

+

boolean

+

added in community.routeros 1.2.0

+

Set to false to skip validation of TLS certificates.

+

See also validate_cert_hostname. Only used when tls=true.

+

Note: instead of simply deactivating certificate validations to “make things work”, please consider creating your own CA certificate and using it to sign certificates used for your router. You can tell the module about your CA certificate with the ca_path option.

+

Choices:

+
    +
  • false

  • +
  • true ← (default)

  • +
+
+
+
+

Attributes

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Attribute

Support

Description

+

action_group

+

Action group: community.routeros.api

+

added in community.routeros 2.1.0

+

Use group/community.routeros.api in module_defaults to set defaults for this module.

+
+

check_mode

+

Support: none

+

Can run in check_mode and return changed status prediction without modifying target.

+
+

diff_mode

+

Support: none

+

Will return details on what has changed (or possibly needs changing in check_mode), when in diff mode.

+
+

idempotent

+

Support: N/A

+

Whether the executed command is idempotent depends on the operation performed.

+

When run twice in a row outside check mode, with the same arguments, the second invocation indicates no change.

+

This assumes that the system controlled/queried by the module has not changed in a relevant way.

+
+

platform

+

Platform: RouterOS

+

Target OS/families that can be operated against.

+
+
+
+

Notes

+
+

Note

+ +
+
+
+

See Also

+
+

See also

+
+
How to quote and unquote commands and arguments

How to quote and unquote commands and arguments.

+
+
community.routeros.api_facts

Collect facts from remote devices running MikroTik RouterOS using the API.

+
+
community.routeros.api_find_and_modify

Find and modify information using the API.

+
+
community.routeros.api_info

Retrieve information from API.

+
+
community.routeros.api_modify

Modify data at paths with API.

+
+
How to connect to RouterOS devices with the RouterOS API

How to connect to RouterOS devices with the RouterOS API.

+
+
+
+
+
+

Examples

+
- name: Get example - ip address print
+  community.routeros.api:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: "ip address"
+  register: ipaddrd_printout
+
+- name: Dump "Get example" output
+  ansible.builtin.debug:
+    msg: '{{ ipaddrd_printout }}'
+
+- name: Add example - ip address
+  community.routeros.api:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: "ip address"
+    add: "address=192.168.255.10/24 interface=ether2"
+
+- name: Query example - ".id, address" in "ip address WHERE address == 192.168.255.10/24"
+  community.routeros.api:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: "ip address"
+    query: ".id address WHERE address == {{ ip2 }}"
+  register: queryout
+
+- name: Dump "Query example" output
+  ansible.builtin.debug:
+    msg: '{{ queryout }}'
+
+- name: Extended query example - ".id,address,network" where address is not 192.168.255.10/24 or is 10.20.36.20/24
+  community.routeros.api:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: "ip address"
+    extended_query:
+      attributes:
+        - network
+        - address
+        - .id
+      where:
+        - attribute: "network"
+          is: "=="
+          value: "192.168.255.0"
+        - or:
+            - attribute: "address"
+              is: "!="
+              value: "192.168.255.10/24"
+            - attribute: "address"
+              is: "eq"
+              value: "10.20.36.20/24"
+        - attribute: "network"
+          is: "in"
+          value:
+            - "10.20.36.0"
+            - "192.168.255.0"
+  register: extended_queryout
+
+- name: Dump "Extended query example" output
+  ansible.builtin.debug:
+    msg: '{{ extended_queryout }}'
+
+- name: Update example - ether2 ip address with ".id = *14"
+  community.routeros.api:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: "ip address"
+    update: >-
+      .id=*14
+      address=192.168.255.20/24
+      comment={{ 'Update 192.168.255.10/24 to 192.168.255.20/24 on ether2' | community.routeros.quote_argument_value }}
+
+- name: Remove example - ether2 ip 192.168.255.20/24 with ".id = *14"
+  community.routeros.api:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: "ip address"
+    remove: "*14"
+
+- name: Arbitrary command example "/system identity print"
+  community.routeros.api:
+    hostname: "{{ hostname }}"
+    password: "{{ password }}"
+    username: "{{ username }}"
+    path: "system identity"
+    cmd: "print"
+  register: arbitraryout
+
+- name: Dump "Arbitrary command example" output
+  ansible.builtin.debug:
+    msg: '{{ arbitraryout }}'
+
+
+
+
+

Return Values

+

Common return values are documented here, the following are the fields unique to this module:

+ + + + + + + + + + + +

Key

Description

+

message

+

list / elements=string

+

All outputs are in list with dictionary elements returned from RouterOS API.

+

Returned: always

+

Sample: [{"address": "1.2.3.4"}, {"address": "2.3.4.5"}]

+
+
+

Authors

+
    +
  • Nikolay Dachev (@NikolayDachev)

  • +
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/changelog.html b/tag/3.5.0/changelog.html new file mode 100644 index 0000000..d1125d8 --- /dev/null +++ b/tag/3.5.0/changelog.html @@ -0,0 +1,1407 @@ + + + + + + + + + Community.Routeros Release Notes — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • +
  • +
+
+
+
+ + +
+ +
+

Community.Routeros Release Notes

+ +
+

v3.5.0

+
+

Release Summary

+

Feature release.

+
+
+

Minor Changes

+ +
+
+
+

v3.4.0

+
+

Release Summary

+

Feature and bugfix release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+
+

v3.3.0

+
+

Release Summary

+

Feature release.

+
+
+

Minor Changes

+ +
+
+
+

v3.2.0

+
+

Release Summary

+

Feature release.

+
+
+

Minor Changes

+ +
+
+
+

v3.1.0

+
+

Release Summary

+

Bugfix and feature release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+
+

v3.0.0

+
+

Release Summary

+

Major release that drops support for End of Life Python versions and fixes check mode for community.routeros.command.

+
+
+

Breaking Changes / Porting Guide

+ +
+
+

Removed Features (previously deprecated)

+
    +
  • The collection no longer supports Ansible 2.9, ansible-base 2.10, ansible-core 2.11, ansible-core 2.12, ansible-core 2.13, and ansible-core 2.14. If you need to continue using End of Life versions of Ansible/ansible-base/ansible-core, please use community.routeros 2.x.y (https://github.com/ansible-collections/community.routeros/pull/318).

  • +
+
+
+
+

v2.20.0

+
+

Release Summary

+

Feature release.

+
+
+

Minor Changes

+ +
+
+
+

v2.19.0

+
+

Release Summary

+

Feature release.

+
+
+

Minor Changes

+ +
+
+
+

v2.18.0

+
+

Release Summary

+

Feature release.

+
+
+

Minor Changes

+ +
+
+

Deprecated Features

+
    +
  • The collection deprecates support for all Ansible/ansible-base/ansible-core versions that are currently End of Life, according to the ansible-core support matrix. This means that the next major release of the collection will no longer support Ansible 2.9, ansible-base 2.10, ansible-core 2.11, ansible-core 2.12, ansible-core 2.13, and ansible-core 2.14.

  • +
+
+
+

Bugfixes

+ +
+
+
+

v2.17.0

+
+

Release Summary

+

Feature release.

+
+
+

Minor Changes

+ +
+
+
+

v2.16.0

+
+

Release Summary

+

Feature release.

+
+
+

Minor Changes

+ +
+
+
+

v2.15.0

+
+

Release Summary

+

Feature release.

+
+
+

Minor Changes

+ +
+
+
+

v2.14.0

+
+

Release Summary

+

Feature release.

+
+
+

Minor Changes

+ +
+
+
+

v2.13.0

+
+

Release Summary

+

Bugfix and feature release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+
+

v2.12.0

+
+

Release Summary

+

Feature release.

+
+
+

Minor Changes

+ +
+
+
+

v2.11.0

+
+

Release Summary

+

Feature and bugfix release.

+
+
+

Minor Changes

+ +
+
+
+

v2.10.0

+
+

Release Summary

+

Bugfix and feature release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+
+

v2.9.0

+
+

Release Summary

+

Bugfix and feature release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+
+

v2.8.3

+
+

Release Summary

+

Maintenance release with updated documentation.

+

From this version on, community.routeros is using the new Ansible semantic markup +in its documentation. If you look at documentation with the ansible-doc CLI tool +from ansible-core before 2.15, please note that it does not render the markup +correctly. You should be still able to read it in most cases, but you need +ansible-core 2.15 or later to see it as it is intended. Alternatively you can +look at the devel docsite +for the rendered HTML version of the documentation of the latest release.

+
+
+

Known Issues

+ +
+
+
+

v2.8.2

+
+

Release Summary

+

Bugfix release.

+
+
+

Bugfixes

+ +
+
+
+

v2.8.1

+
+

Release Summary

+

Bugfix release.

+
+
+

Bugfixes

+ +
+
+
+

v2.8.0

+
+

Release Summary

+

Bugfix and feature release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+
+

v2.7.0

+
+

Release Summary

+

Bugfix and feature release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+
+

v2.6.0

+
+

Release Summary

+

Regular bugfix and feature release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+
+

v2.5.0

+
+

Release Summary

+

Feature and bugfix release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+
+

v2.4.0

+
+

Release Summary

+

Feature release improving the api* modules.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+

Known Issues

+
    +
  • api_modify - when limits for entries in queue tree are defined as human readable - for example 25M -, the configuration will be correctly set in ROS, but the module will indicate the item is changed on every run even when there was no change done. This is caused by the ROS API which returns the number in bytes - for example 25000000 (which is inconsistent with the CLI behavior). In order to mitigate that, the limits have to be defined in bytes (those will still appear as human readable in the ROS CLI) (https://github.com/ansible-collections/community.routeros/pull/131).

  • +
  • api_modify, api_info - routing ospf area, routing ospf area range, routing ospf instance, routing ospf interface-template paths are not fully implemented for ROS6 due to the significant changes between ROS6 and ROS7 (https://github.com/ansible-collections/community.routeros/pull/131).

  • +
+
+
+
+

v2.3.1

+
+

Release Summary

+

Maintenance release with improved documentation.

+
+
+

Known Issues

+
    +
  • The community.routeros.command module claims to support check mode. Since it cannot judge whether the commands executed modify state or not, this behavior is incorrect. Since this potentially breaks existing playbooks, we will not change this behavior until community.routeros 3.0.0.

  • +
+
+
+
+

v2.3.0

+
+

Release Summary

+

Feature and bugfix release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+
+

v2.2.1

+
+

Release Summary

+

Bugfix release.

+
+
+

Bugfixes

+ +
+
+
+

v2.2.0

+
+

Release Summary

+

New feature release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+

New Modules

+
    +
  • community.routeros.api_info - Retrieve information from API

  • +
  • community.routeros.api_modify - Modify data at paths with API

  • +
+
+
+
+

v2.1.0

+
+

Release Summary

+

Feature and bugfix release with new modules.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+

New Modules

+
    +
  • community.routeros.api_facts - Collect facts from remote devices running MikroTik RouterOS using the API

  • +
  • community.routeros.api_find_and_modify - Find and modify information using the API

  • +
+
+
+
+

v2.0.0

+
+

Release Summary

+

A new major release with breaking changes in the behavior of community.routeros.api and community.routeros.command.

+
+
+

Minor Changes

+ +
+
+

Breaking Changes / Porting Guide

+ +
+
+

Bugfixes

+ +
+
+

New Plugins

+
+

Filter

+
    +
  • community.routeros.join - Join a list of arguments to a command

  • +
  • community.routeros.list_to_dict - Convert a list of arguments to a list of dictionary

  • +
  • community.routeros.quote_argument - Quote an argument

  • +
  • community.routeros.quote_argument_value - Quote an argument value

  • +
  • community.routeros.split - Split a command into arguments

  • +
+
+
+
+
+

v1.2.0

+
+

Release Summary

+

Bugfix and feature release.

+
+
+

Minor Changes

+ +
+
+

Bugfixes

+ +
+
+
+

v1.1.0

+
+

Release Summary

+

This release allow dashes in usernames for SSH-based modules.

+
+
+

Minor Changes

+ +
+
+
+

v1.0.1

+
+

Release Summary

+

Maintenance release with a bugfix for api.

+
+
+

Bugfixes

+ +
+
+
+

v1.0.0

+
+

Release Summary

+

This is the first production (non-prerelease) release of community.routeros.

+
+
+

Bugfixes

+ +
+
+
+

v0.1.1

+
+

Release Summary

+

Small improvements and bugfixes over the initial release.

+
+
+

Bugfixes

+ +
+
+
+

v0.1.0

+
+

Release Summary

+

The community.routeros continues the work on the Ansible RouterOS modules from their state in community.network 1.2.0. The changes listed here are thus relative to the modules community.network.routeros_*.

+
+
+

Minor Changes

+ +
+
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/command_module.html b/tag/3.5.0/command_module.html new file mode 100644 index 0000000..ea1ad17 --- /dev/null +++ b/tag/3.5.0/command_module.html @@ -0,0 +1,403 @@ + + + + + + + + + + community.routeros.command module – Run commands on remote devices running MikroTik RouterOS — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.command module – Run commands on remote devices running MikroTik RouterOS

+
+

Note

+

This module is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros.

+

To use it in a playbook, specify: community.routeros.command.

+
+ +
+

Synopsis

+
    +
  • Sends arbitrary commands to an RouterOS node and returns the results read from the device. This module includes an argument that will cause the module to wait for a specific condition before returning or timing out if the condition is not met.

  • +
  • The module always indicates a (changed) status. You can use the changed_when task property to determine whether a command task actually resulted in a change or not.

  • +
+
+
+

Parameters

+ + + + + + + + + + + + + + + + + + + + + + + +

Parameter

Comments

+

commands

+

list / elements=string / required

+

List of commands to send to the remote RouterOS device over the configured provider. The resulting output from the command is returned. If the wait_for argument is provided, the module is not returned until the condition is satisfied or the number of retries has expired.

+
+

interval

+

integer

+

Configures the interval in seconds to wait between retries of the command. If the command does not pass the specified conditions, the interval indicates how long to wait before trying the command again.

+

Default: 1

+
+

match

+

string

+

The match argument is used in conjunction with the wait_for argument to specify the match policy. Valid values are all or any. If the value is set to all then all conditionals in the wait_for must be satisfied. If the value is set to any then only one of the values must be satisfied.

+

Choices:

+
    +
  • "any"

  • +
  • "all" ← (default)

  • +
+
+

retries

+

integer

+

Specifies the number of retries a command should by tried before it is considered failed. The command is run on the target device every retry and evaluated against the wait_for conditions.

+

Default: 10

+
+

wait_for

+

list / elements=string

+

List of conditions to evaluate against the output of the command. The task will wait for each condition to be true before moving forward. If the conditional is not true within the configured number of retries, the task fails. See examples.

+
+
+
+

Attributes

+ + + + + + + + + + + + + + + + + + + + + + + + + +

Attribute

Support

Description

+

check_mode

+

Support: none

+

Before community.routeros 3.0.0, the module claimed to support check mode. It simply executed the command in check mode.

+

Can run in check_mode and return changed status prediction without modifying target.

+
+

diff_mode

+

Support: none

+

Will return details on what has changed (or possibly needs changing in check_mode), when in diff mode.

+
+

idempotent

+

Support: N/A

+

Whether the executed command is idempotent depends on the command.

+

When run twice in a row outside check mode, with the same arguments, the second invocation indicates no change.

+

This assumes that the system controlled/queried by the module has not changed in a relevant way.

+
+

platform

+

Platform: RouterOS

+

Target OS/families that can be operated against.

+
+
+
+

See Also

+
+

See also

+
+
How to connect to RouterOS devices with SSH

How to connect to RouterOS devices with SSH.

+
+
How to quote and unquote commands and arguments

How to quote and unquote commands and arguments.

+
+
+
+
+
+

Examples

+
- name: Run command on remote devices
+  community.routeros.command:
+    commands: /system routerboard print
+
+- name: Run command and check to see if output contains routeros
+  community.routeros.command:
+    commands: /system resource print
+    wait_for: result[0] contains MikroTik
+
+- name: Run multiple commands on remote nodes
+  community.routeros.command:
+    commands:
+      - /system routerboard print
+      - /system identity print
+
+- name: Run multiple commands and evaluate the output
+  community.routeros.command:
+    commands:
+      - /system routerboard print
+      - /interface ethernet print
+    wait_for:
+      - result[0] contains x86
+      - result[1] contains ether1
+
+
+
+
+

Return Values

+

Common return values are documented here, the following are the fields unique to this module:

+ + + + + + + + + + + + + + + + + +

Key

Description

+

failed_conditions

+

list / elements=string

+

The list of conditionals that have failed.

+

Returned: failed

+

Sample: ["...", "..."]

+
+

stdout

+

list / elements=string

+

The set of responses from the commands.

+

Returned: always apart from low level errors (such as action plugin)

+

Sample: ["...", "..."]

+
+

stdout_lines

+

list / elements=string

+

The value of stdout split into a list.

+

Returned: always apart from low level errors (such as action plugin)

+

Sample: [["...", "..."], ["..."], ["..."]]

+
+
+

Authors

+
    +
  • Egor Zaitsev (@heuels)

  • +
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/docsite/api-guide.html b/tag/3.5.0/docsite/api-guide.html new file mode 100644 index 0000000..eae581a --- /dev/null +++ b/tag/3.5.0/docsite/api-guide.html @@ -0,0 +1,352 @@ + + + + + + + + + How to connect to RouterOS devices with the RouterOS API — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • +
  • +
+
+
+
+ + +
+ +
+

How to connect to RouterOS devices with the RouterOS API

+

You can use the community.routeros.api module to connect to a RouterOS device with the RouterOS API. More specific module to modify certain entries are the community.routeros.api_modify and community.routeros.api_find_and_modify modules. The community.routeros.api_info module allows to retrieve information on specific predefined paths that can be used as input for the community.routeros.api_modify module, and the community.routeros.api_facts module allows to retrieve Ansible facts using the RouterOS API.

+

No special setup is needed; the module needs to be run on a host that can connect to the device’s API. The most common case is that the module is run on localhost, either by using hosts: localhost in the playbook, or by using delegate_to: localhost for the task. The following example shows how to run the equivalent of /ip address print:

+
---
+- name: RouterOS test with API
+  hosts: localhost
+  gather_facts: false
+  vars:
+    hostname: 192.168.1.1
+    username: admin
+    password: test1234
+  tasks:
+    - name: Get "ip address print"
+      community.routeros.api:
+        hostname: "{{ hostname }}"
+        password: "{{ password }}"
+        username: "{{ username }}"
+        path: "ip address"
+        # The following options configure TLS/SSL.
+        # Depending on your setup, these options need different values:
+        tls: true
+        validate_certs: true
+        validate_cert_hostname: true
+        # If you are using your own PKI, specify the path to your CA certificate here:
+        # ca_path: /path/to/ca-certificate.pem
+      register: print_path
+
+    - name: Show IP address of first interface
+      ansible.builtin.debug:
+        msg: "{{ print_path.msg[0].address }}"
+
+
+

This results in the following output:

+
PLAY [RouterOS test] *********************************************************************************************
+
+TASK [Get "ip address print"] ************************************************************************************
+ok: [localhost]
+
+TASK [Show IP address of first interface] ************************************************************************
+ok: [localhost] => {
+    "msg": "192.168.2.1/24"
+}
+
+PLAY RECAP *******************************************************************************************************
+localhost                  : ok=2    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0
+
+
+

Check out the documentation of the community.routeros.api module for details on the options.

+
+

Using the community.routeros.api module defaults group

+

To avoid having to specify common parameters for all the API based modules in every task, you can use the community.routeros.api module defaults group:

+
---
+- name: RouterOS test with API
+  hosts: localhost
+  gather_facts: false
+  module_defaults:
+    group/community.routeros.api:
+      hostname: 192.168.1.1
+      password: admin
+      username: test1234
+      # The following options configure TLS/SSL.
+      # Depending on your setup, these options need different values:
+      tls: true
+      validate_certs: true
+      validate_cert_hostname: true
+      # If you are using your own PKI, specify the path to your CA certificate here:
+      # ca_path: /path/to/ca-certificate.pem
+  tasks:
+    - name: Gather facts
+      community.routeros.api_facts:
+
+    - name: Get "ip address print"
+      community.routeros.api:
+        path: "ip address"
+
+    - name: Change IP address to 192.168.1.1 for interface bridge
+      community.routeros.api_find_and_modify:
+        path: ip address
+        find:
+          interface: bridge
+        values:
+          address: "192.168.1.1/24"
+
+
+

Here all three tasks will use the options set for the module defaults group.

+
+
+

Setting up encryption

+

It is recommended to always use tls=true when connecting with the API, even if you are only connecting to the device through a trusted network. The following options control how TLS/SSL is used:

+
+
force_no_cert:
+

Setting to true connects to the device without a certificate. This is discouraged to use in production and is susceptible to Man-in-the-Middle attacks, but might be useful when setting the device up. The default value is false.

+
+
validate_certs:
+

Setting to false disables any certificate validation. This is discouraged to use in production, but is needed when setting the device up. The default value is true.

+
+
validate_cert_hostname:
+

Setting to false (default) disables hostname verification during certificate validation. This is needed if the hostnames specified in the certificate do not match the hostname used for connecting (usually the device’s IP). It is recommended to set up the certificate correctly and set this to true; the default false is chosen for backwards compatibility to an older version of the module.

+
+
ca_path:
+

If you are not using a commercially trusted CA certificate to sign your device’s certificate, or have not included your CA certificate in Python’s truststore, you need to point this option to the CA certificate.

+
+
+

We recommend to create a CA certificate that is used to sign the certificates for your RouterOS devices, and have the certificates include the correct hostname(s), including the IP of the device. That way, you can fully enable TLS and be sure that you always talk to the correct device.

+
+

Setting up a PKI

+

Please follow the instructions in the community.crypto How to create a small CA guide to set up a CA certificate and sign a certificate for your router. You should add a Subject Alternative Name for the IP address (for example IP:192.168.1.1) and - if available - for the DNS name (for example DNS:router.local) to the certificate.

+
+
+

Installing a certificate on a MikroTik router

+

Installing the certificate is best done with the SSH connection. (See the How to connect to RouterOS devices with SSH guide for more information.) Once the certificate has been installed, and the HTTPS API enabled, it’s easier to work with the API, since it has a quite a few less problems, and returns data as JSON objects instead of text you first have to parse.

+

First you have to convert the certificate and its private key to a PKCS #12 bundle. This can be done with the community.crypto.openssl_pkcs12. The following playbook assumes that the certificate is available as keys/{{ inventory_hostname }}.pem, and its private key is available as keys/{{ inventory_hostname }}.key. It generates a random passphrase to protect the PKCS#12 file.

+
---
+- name: Install certificates on devices
+  hosts: routers
+  gather_facts: false
+  tasks:
+    - block:
+        - set_fact:
+            random_password: "{{ lookup('community.general.random_string', length=32, override_all='0123456789abcdefghijklmnopqrstuvwxyz') }}"
+
+        - name: Create PKCS#12 bundle
+          openssl_pkcs12:
+            path: keys/{{ inventory_hostname }}.p12
+            certificate_path: keys/{{ inventory_hostname }}.pem
+            privatekey_path: keys/{{ inventory_hostname }}.key
+            friendly_name: '{{ inventory_hostname }}'
+            passphrase: "{{ random_password }}"
+            mode: "0600"
+          changed_when: false
+          delegate_to: localhost
+
+        - name: Copy router certificate onto router
+          ansible.netcommon.net_put:
+            src: 'keys/{{ inventory_hostname }}.p12'
+            dest: '{{ inventory_hostname }}.p12'
+
+        - name: Install router certificate and clean up
+          community.routeros.command:
+            commands:
+              # Import certificate:
+              - /certificate import name={{ inventory_hostname }} file-name={{ inventory_hostname }}.p12 passphrase="{{ random_password }}"
+              # Remove PKCS12 bundle:
+              - /file remove {{ inventory_hostname }}.p12
+              # Show certificates
+              - /certificate print
+          register: output
+
+        - name: Show result of certificate import
+          debug:
+            var: output.stdout_lines[0]
+
+        - name: Show certificates
+          debug:
+            var: output.stdout_lines[2]
+
+      always:
+        - name: Wipe PKCS12 bundle
+          command: wipe keys/{{ inventory_hostname }}.p12
+          changed_when: false
+          delegate_to: localhost
+
+    - name: Use certificate
+      community.routeros.command:
+        commands:
+          - /ip service set www-ssl address={{ admin_network }} certificate={{ inventory_hostname }} disabled=no tls-version=only-1.2
+          - /ip service set api-ssl address={{ admin_network }} certificate={{ inventory_hostname }} tls-version=only-1.2
+
+
+

The playbook also assumes that admin_network describes the network from which the HTTPS and API interface can be accessed. This can be for example 192.168.1.0/24.

+

When this playbook completed successfully, you should be able to use the HTTPS admin interface (reachable in a browser from https://192.168.1.1/, with the correct IP inserted), as well as the community.routeros.api module module with TLS and certificate validation enabled:

+
- community.routeros.api:
+    ...
+    tls: true
+    validate_certs: true
+    validate_cert_hostname: true
+    ca_path: /path/to/ca-certificate.pem
+
+
+
+
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/docsite/quoting.html b/tag/3.5.0/docsite/quoting.html new file mode 100644 index 0000000..1baf0ba --- /dev/null +++ b/tag/3.5.0/docsite/quoting.html @@ -0,0 +1,173 @@ + + + + + + + + + How to quote and unquote commands and arguments — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • +
  • +
+
+
+
+ + +
+ +
+

How to quote and unquote commands and arguments

+

When using the community.routeros.command module or the community.routeros.api module modules, you need to pass text data in quoted form. While in some cases quoting is not needed (when passing IP addresses or names without spaces, for example), in other cases it is required, like when passing a comment which contains a space.

+

The community.routeros collection provides a set of Jinja2 filter plugins which helps you with these tasks:

+
    +
  • The community.routeros.quote_argument_value filter quotes an argument value: 'this is a "comment"' | community.routeros.quote_argument_value == '"this is a \\"comment\\""'.

  • +
  • The community.routeros.quote_argument filter quotes an argument with or without a value: 'comment=this is a "comment"' | community.routeros.quote_argument == 'comment="this is a \\"comment\\""'.

  • +
  • The community.routeros.join filter quotes a list of arguments and joins them to one string: ['foo=bar', 'comment=foo is bar'] | community.routeros.join == 'foo=bar comment="foo is bar"'.

  • +
  • The community.routeros.split filter splits a command into a list of arguments (with or without values): 'foo=bar comment="foo is bar"' | community.routeros.split == ['foo=bar', 'comment=foo is bar']

  • +
  • The community.routeros.list_to_dict filter splits a list of arguments with values into a dictionary: ['foo=bar', 'comment=foo is bar'] | community.routeros.list_to_dict == {'foo': 'bar', 'comment': 'foo is bar'}. It has two optional arguments: require_assignment (default value true) allows to accept arguments without values when set to false; and skip_empty_values (default value false) allows to skip arguments whose value is empty.

  • +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/docsite/ssh-guide.html b/tag/3.5.0/docsite/ssh-guide.html new file mode 100644 index 0000000..3039648 --- /dev/null +++ b/tag/3.5.0/docsite/ssh-guide.html @@ -0,0 +1,278 @@ + + + + + + + + + How to connect to RouterOS devices with SSH — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • +
  • +
+
+
+
+ + +
+ +
+

How to connect to RouterOS devices with SSH

+

The collection offers two modules to connect to RouterOS devies with SSH:

+ +

The modules need the ansible.netcommon.network_cli connection plugin for this.

+
+

Important notes

+
    +
  1. The SSH-based modules do not support arbitrary symbols in the router’s identity. If you are having trouble connecting to your device, please make sure that your MikroTik’s identity contains only alphanumeric characters and dashes. Also make sure that the identity string is not longer than 19 characters (see issue for details). Similar problems can happen for unsupported characters in your username.

  2. +
  3. The community.routeros.command module does not support nesting commands and expects every command to start with a forward slash (/). Running the following command will produce an error:

    +
    - community.routeros.command:
    +    commands:
    +      - /ip
    +      - print
    +
    +
    +
  4. +
  5. When using the community.routeros.command module module, make sure to not specify too long commands. Alternatively, add something like +cet512w to the username (replace admin with admin+cet512w) to tell RouterOS to not wrap before 512 characters in a line (see issue for details).

  6. +
  7. The ansible.netcommon.network_cli connection plugin uses paramiko by default to connect to devices with SSH. You can set its ssh_type option to libssh to use ansible-pylibssh instead, which offers Python bindings to libssh. See its documentation for details.

  8. +
  9. User is not allowed to login via SSH by password to modern Mikrotik if SSH key for the user is added!

  10. +
+
+
+

Setting up an inventory

+

An example inventory hosts file for a RouterOS device is as follows:

+
[routers]
+router ansible_host=192.168.2.1
+
+[routers:vars]
+ansible_connection=ansible.netcommon.network_cli
+ansible_network_os=community.routeros.routeros
+ansible_user=admin
+ansible_ssh_pass=test1234
+
+
+

This tells Ansible that you have a RouterOS device called router with IP 192.168.2.1. Ansible should use the ansible.netcommon.network_cli connection plugin together with the the community.routeros.routeros cliconf plugin. The credentials are stored as ansible_user and ansible_ssh_pass in the inventory.

+
+
+

Connecting to the device

+

With the above inventory, you can use the following playbook to execute /system resource print on the device

+
---
+- name: RouterOS test with network_cli connection
+  hosts: routers
+  gather_facts: false
+  tasks:
+
+  - name: Gather system resources
+    community.routeros.command:
+      commands:
+        - /system resource print
+    register: system_resource_print
+
+  - name: Show system resources
+    debug:
+      var: system_resource_print.stdout_lines
+
+  - name: Gather facts
+    community.routeros.facts:
+
+  - name: Show a fact
+    debug:
+      msg: "First IP address: {{ ansible_net_all_ipv4_addresses[0] }}"
+
+
+

This results in the following output:

+
PLAY [RouterOS test with network_cli connection] *****************************************************************
+
+TASK [Gather system resources] ***********************************************************************************
+ok: [router]
+
+TASK [Show system resources] *************************************************************************************
+ok: [router] => {
+    "system_resource_print.stdout_lines": [
+        [
+            "uptime: 3d10h28m51s",
+            "                  version: 6.48.3 (stable)",
+            "               build-time: May/25/2021 06:09:45",
+            "              free-memory: 31.2MiB",
+            "             total-memory: 64.0MiB",
+            "                      cpu: MIPS 24Kc V7.4",
+            "                cpu-count: 1",
+            "            cpu-frequency: 400MHz",
+            "                 cpu-load: 1%",
+            "           free-hdd-space: 54.2MiB",
+            "          total-hdd-space: 128.0MiB",
+            "  write-sect-since-reboot: 927",
+            "         write-sect-total: 51572981",
+            "               bad-blocks: 1%",
+            "        architecture-name: mipsbe",
+            "               board-name: RB750GL",
+            "                 platform: MikroTik"
+        ]
+    ]
+}
+
+TASK [Gather facts] **********************************************************************************************
+ok: [router]
+
+TASK [Show a fact] ***********************************************************************************************
+ok: [router] => {
+    "msg": "First IP address: 192.168.2.1"
+}
+
+PLAY RECAP *******************************************************************************************************
+router                     : ok=4    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0
+
+
+
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/environment_variables.html b/tag/3.5.0/environment_variables.html new file mode 100644 index 0000000..709875b --- /dev/null +++ b/tag/3.5.0/environment_variables.html @@ -0,0 +1,163 @@ + + + + + + + + + + Index of all Collection Environment Variables — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • +
  • +
+
+
+
+ + +
+ +
+

Index of all Collection Environment Variables

+

The following index documents all environment variables declared by plugins in collections. +Environment variables used by the ansible-core configuration are documented in Ansible Configuration Settings.

+

No environment variables have been defined.

+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/facts_module.html b/tag/3.5.0/facts_module.html new file mode 100644 index 0000000..582cde1 --- /dev/null +++ b/tag/3.5.0/facts_module.html @@ -0,0 +1,533 @@ + + + + + + + + + + community.routeros.facts module – Collect facts from remote devices running MikroTik RouterOS — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.facts module – Collect facts from remote devices running MikroTik RouterOS

+
+

Note

+

This module is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros.

+

To use it in a playbook, specify: community.routeros.facts.

+
+ +
+

Synopsis

+
    +
  • Collects a base set of device facts from a remote device that is running RouterOS. This module prepends all of the base network fact keys with ansible_net_<fact>. The facts module will always collect a base set of facts from the device and can enable or disable collection of additional facts.

  • +
+
+
+

Parameters

+ + + + + + + + + + + +

Parameter

Comments

+

gather_subset

+

list / elements=string

+

When supplied, this argument will restrict the facts collected to a given subset. Possible values for this argument include all, hardware, config, interfaces, and routing.

+

Can specify a list of values to include a larger subset. Values can also be used with an initial ! to specify that a specific subset should not be collected.

+

Default: ["!config"]

+
+
+
+

Attributes

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Attribute

Support

Description

+

check_mode

+

Support: full

+

This action does not modify state.

+

Can run in check_mode and return changed status prediction without modifying target.

+
+

diff_mode

+

Support: N/A

+

This action does not modify state.

+

Will return details on what has changed (or possibly needs changing in check_mode), when in diff mode.

+
+

facts

+

Support: full

+

Action returns an ansible_facts dictionary that will update existing host facts.

+
+

idempotent

+

Support: full

+

This action does not modify state.

+

When run twice in a row outside check mode, with the same arguments, the second invocation indicates no change.

+

This assumes that the system controlled/queried by the module has not changed in a relevant way.

+
+

platform

+

Platform: RouterOS

+

Target OS/families that can be operated against.

+
+
+
+

See Also

+
+

See also

+
+
How to connect to RouterOS devices with SSH

How to connect to RouterOS devices with SSH.

+
+
+
+
+
+

Examples

+
- name: Collect all facts from the device
+  community.routeros.facts:
+    gather_subset: all
+
+- name: Collect only the config and default facts
+  community.routeros.facts:
+    gather_subset:
+      - config
+
+- name: Do not collect hardware facts
+  community.routeros.facts:
+    gather_subset:
+      - "!hardware"
+
+
+
+
+

Returned Facts

+

Facts returned by this module are added/updated in the hostvars host facts and can be referenced by name just like any other host fact. They do not need to be registered in order to use them.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Key

Description

+

ansible_net_all_ipv4_addresses

+

list / elements=string

+

All IPv4 addresses configured on the device.

+

Returned: gather_subset contains interfaces

+
+

ansible_net_all_ipv6_addresses

+

list / elements=string

+

All IPv6 addresses configured on the device.

+

Returned: gather_subset contains interfaces

+
+

ansible_net_arch

+

string

+

The CPU architecture of the device.

+

Returned: gather_subset contains default

+
+

ansible_net_bgp_instance

+

dictionary

+

A dictionary with BGP instance information.

+

Returned: gather_subset contains routing

+
+

ansible_net_bgp_peer

+

dictionary

+

A dictionary with BGP peer information.

+

Returned: gather_subset contains routing

+
+

ansible_net_bgp_vpnv4_route

+

dictionary

+

A dictionary with BGP vpnv4 route information.

+

Returned: gather_subset contains routing

+
+

ansible_net_config

+

string

+

The current active config from the device.

+

Returned: gather_subset contains config

+
+

ansible_net_config_nonverbose

+

string

+

added in community.routeros 1.2.0

+

The current active config from the device in minimal form.

+

This value is idempotent in the sense that if the facts module is run twice and the device’s config was not changed between the runs, the value is identical. This is achieved by running /export and stripping the timestamp from the comment in the first line.

+

Returned: gather_subset contains config

+
+

ansible_net_cpu_load

+

string

+

Current CPU load.

+

Returned: gather_subset contains default

+
+

ansible_net_gather_subset

+

list / elements=string

+

The list of fact subsets collected from the device.

+

Returned: always

+
+

ansible_net_hostname

+

string

+

The configured hostname of the device.

+

Returned: gather_subset contains default

+
+

ansible_net_interfaces

+

dictionary

+

A hash of all interfaces running on the system.

+

Returned: gather_subset contains interfaces

+
+

ansible_net_memfree_mb

+

integer

+

The available free memory on the remote device in MiB.

+

Returned: gather_subset contains hardware

+
+

ansible_net_memtotal_mb

+

integer

+

The total memory on the remote device in MiB.

+

Returned: gather_subset contains hardware

+
+

ansible_net_model

+

string

+

The model name returned from the device.

+

Returned: gather_subset contains default

+
+

ansible_net_neighbors

+

dictionary

+

The list of neighbors from the remote device.

+

Returned: gather_subset contains interfaces

+
+

ansible_net_ospf_instance

+

dictionary

+

A dictionary with OSPF instances.

+

Returned: gather_subset contains routing

+
+

ansible_net_ospf_neighbor

+

dictionary

+

A dictionary with OSPF neighbors.

+

Returned: gather_subset contains routing

+
+

ansible_net_route

+

dictionary

+

A dictionary for routes in all routing tables.

+

Returned: gather_subset contains routing

+
+

ansible_net_serialnum

+

string

+

The serial number of the remote device.

+

Returned: gather_subset contains default

+
+

ansible_net_spacefree_mb

+

dictionary

+

The available disk space on the remote device in MiB.

+

Returned: gather_subset contains hardware

+
+

ansible_net_spacetotal_mb

+

dictionary

+

The total disk space on the remote device in MiB.

+

Returned: gather_subset contains hardware

+
+

ansible_net_uptime

+

string

+

The uptime of the device.

+

Returned: gather_subset contains default

+
+

ansible_net_version

+

string

+

The operating system version running on the remote device.

+

Returned: gather_subset contains default

+
+
+

Authors

+
    +
  • Egor Zaitsev (@heuels)

  • +
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/index.html b/tag/3.5.0/index.html new file mode 100644 index 0000000..fe1adb6 --- /dev/null +++ b/tag/3.5.0/index.html @@ -0,0 +1,262 @@ + + + + + + + + + + Community.Routeros — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • +
  • +
+
+
+
+ + +
+ +
+

Community.Routeros

+

Collection version 3.5.0

+ +
+

Description

+

Modules and plugins for MikroTik RouterOS

+

Authors:

+
    +
  • Egor Zaitsev (github.com/heuels)

  • +
  • Nikolay Dachev (github.com/NikolayDachev)

  • +
  • Felix Fontein (github.com/felixfontein)

  • +
+

Supported ansible-core versions:

+
    +
  • 2.15.0 or newer

  • +
+ +
+
+

Communication

+ +
+
+
+
+

Changelog

+ +
+
+

Guides

+ +
+
+

Plugin Index

+

These are the plugins in the community.routeros collection:

+
+

Modules

+ +
+
+
+
+

Cliconf Plugins

+
    +
  • routeros cliconf – Use routeros cliconf to run command on MikroTik RouterOS platform

  • +
+
+
+
+
+

Filter Plugins

+ +
+
+
+
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/join_filter.html b/tag/3.5.0/join_filter.html new file mode 100644 index 0000000..8a84531 --- /dev/null +++ b/tag/3.5.0/join_filter.html @@ -0,0 +1,270 @@ + + + + + + + + + + community.routeros.join filter – Join a list of arguments to a command — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.join filter – Join a list of arguments to a command

+
+

Note

+

This filter plugin is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros.

+

To use it in a playbook, specify: community.routeros.join.

+
+

New in community.routeros 2.0.0

+ +
+

Synopsis

+
    +
  • Join and quotes a list of arguments to a command.

  • +
+
+
+

Input

+

This describes the input of the filter, the value before | community.routeros.join.

+ + + + + + + + + + + +

Parameter

Comments

+

Input

+

list / elements=string / required

+

A list of arguments to quote and join.

+
+
+
+

Examples

+
- name: Join arguments for a RouterOS CLI command
+  ansible.builtin.set_fact:
+    arguments: "{{ ['foo=bar', 'comment=foo is bar'] | community.routeros.join }}"
+    # Should result in 'foo=bar comment="foo is bar"'
+
+
+
+
+

Return Value

+ + + + + + + + + + + +

Key

Description

+

Return value

+

string

+

The joined and quoted result.

+

Returned: success

+
+
+

Authors

+
    +
  • Felix Fontein (@felixfontein)

  • +
+
+

Hint

+

Configuration entries for each entry type have a low to high priority order. For example, a variable that is lower in the list will override a variable that is higher up.

+
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/list_to_dict_filter.html b/tag/3.5.0/list_to_dict_filter.html new file mode 100644 index 0000000..eb2dffe --- /dev/null +++ b/tag/3.5.0/list_to_dict_filter.html @@ -0,0 +1,310 @@ + + + + + + + + + + community.routeros.list_to_dict filter – Convert a list of arguments to a dictionary — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.list_to_dict filter – Convert a list of arguments to a dictionary

+
+

Note

+

This filter plugin is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros.

+

To use it in a playbook, specify: community.routeros.list_to_dict.

+
+

New in community.routeros 2.0.0

+ +
+

Synopsis

+
    +
  • Convert a list of arguments to a dictionary.

  • +
+
+
+

Input

+

This describes the input of the filter, the value before | community.routeros.list_to_dict.

+ + + + + + + + + + + +

Parameter

Comments

+

Input

+

list / elements=string / required

+

A list of assignments. Can be the result of the community.routeros.split filter.

+
+
+
+

Keyword parameters

+

This describes keyword parameters of the filter. These are the values key1=value1, key2=value2 and so on in the following +example: input | community.routeros.list_to_dict(key1=value1, key2=value2, ...)

+ + + + + + + + + + + + + + +

Parameter

Comments

+

require_assignment

+

boolean

+

Allows to accept arguments without values when set to false.

+

Choices:

+
    +
  • false

  • +
  • true ← (default)

  • +
+
+

skip_empty_values

+

boolean

+

Allows to skip arguments whose value is empty when set to true.

+

Choices:

+
    +
  • false ← (default)

  • +
  • true

  • +
+
+
+
+

Examples

+
- name: Convert a list to a dictionary
+  ansible.builtin.set_fact:
+    dictionary: "{{ ['foo=bar', 'comment=foo is bar'] | community.routeros.list_to_dict }}"
+    # dictionary == {'foo': 'bar', 'comment': 'foo is bar'}
+
+
+
+
+

Return Value

+ + + + + + + + + + + +

Key

Description

+

Return value

+

dictionary

+

A dictionary representation of the input data.

+

Returned: success

+
+
+

Authors

+
    +
  • Felix Fontein (@felixfontein)

  • +
+
+

Hint

+

Configuration entries for each entry type have a low to high priority order. For example, a variable that is lower in the list will override a variable that is higher up.

+
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/objects.inv b/tag/3.5.0/objects.inv new file mode 100644 index 0000000..b217375 Binary files /dev/null and b/tag/3.5.0/objects.inv differ diff --git a/tag/3.5.0/quote_argument_filter.html b/tag/3.5.0/quote_argument_filter.html new file mode 100644 index 0000000..b71757d --- /dev/null +++ b/tag/3.5.0/quote_argument_filter.html @@ -0,0 +1,270 @@ + + + + + + + + + + community.routeros.quote_argument filter – Quote an argument — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.quote_argument filter – Quote an argument

+
+

Note

+

This filter plugin is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros.

+

To use it in a playbook, specify: community.routeros.quote_argument.

+
+

New in community.routeros 2.0.0

+ +
+

Synopsis

+
    +
  • Quote an argument.

  • +
+
+
+

Input

+

This describes the input of the filter, the value before | community.routeros.quote_argument.

+ + + + + + + + + + + +

Parameter

Comments

+

Input

+

string / required

+

An argument to quote.

+
+
+
+

Examples

+
- name: Quote a RouterOS CLI command argument
+  ansible.builtin.set_fact:
+    quoted: "{{ 'comment=this is a "comment"' | community.routeros.quote_argument }}"
+    # Should result in 'comment="this is a \"comment\""'
+
+
+
+
+

Return Value

+ + + + + + + + + + + +

Key

Description

+

Return value

+

string

+

The quoted argument.

+

Returned: success

+
+
+

Authors

+
    +
  • Felix Fontein (@felixfontein)

  • +
+
+

Hint

+

Configuration entries for each entry type have a low to high priority order. For example, a variable that is lower in the list will override a variable that is higher up.

+
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/quote_argument_value_filter.html b/tag/3.5.0/quote_argument_value_filter.html new file mode 100644 index 0000000..83e844f --- /dev/null +++ b/tag/3.5.0/quote_argument_value_filter.html @@ -0,0 +1,270 @@ + + + + + + + + + + community.routeros.quote_argument_value filter – Quote an argument value — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.quote_argument_value filter – Quote an argument value

+
+

Note

+

This filter plugin is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros.

+

To use it in a playbook, specify: community.routeros.quote_argument_value.

+
+

New in community.routeros 2.0.0

+ +
+

Synopsis

+
    +
  • Quote an argument value.

  • +
+
+
+

Input

+

This describes the input of the filter, the value before | community.routeros.quote_argument_value.

+ + + + + + + + + + + +

Parameter

Comments

+

Input

+

string / required

+

An argument value to quote.

+
+
+
+

Examples

+
- name: Quote a RouterOS CLI command argument's value
+  ansible.builtin.set_fact:
+    quoted: "{{ 'this is a "comment"' | community.routeros.quote_argument_value }}"
+    # Should result in '"this is a \"comment\""'
+
+
+
+
+

Return Value

+ + + + + + + + + + + +

Key

Description

+

Return value

+

string

+

The quoted argument value.

+

Returned: success

+
+
+

Authors

+
    +
  • Felix Fontein (@felixfontein)

  • +
+
+

Hint

+

Configuration entries for each entry type have a low to high priority order. For example, a variable that is lower in the list will override a variable that is higher up.

+
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/routeros_cliconf.html b/tag/3.5.0/routeros_cliconf.html new file mode 100644 index 0000000..5a11b72 --- /dev/null +++ b/tag/3.5.0/routeros_cliconf.html @@ -0,0 +1,214 @@ + + + + + + + + + + community.routeros.routeros cliconf – Use routeros cliconf to run command on MikroTik RouterOS platform — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.routeros cliconf – Use routeros cliconf to run command on MikroTik RouterOS platform

+
+

Note

+

This cliconf plugin is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros.

+

To use it in a playbook, specify: community.routeros.routeros.

+
+ +
+

Synopsis

+
    +
  • This routeros plugin provides low level abstraction APIs for sending and receiving CLI commands from MikroTik RouterOS network devices.

  • +
+
+

Authors

+
    +
  • Egor Zaitsev (@heuels)

  • +
+
+

Hint

+

Configuration entries for each entry type have a low to high priority order. For example, a variable that is lower in the list will override a variable that is higher up.

+
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file diff --git a/tag/3.5.0/search.html b/tag/3.5.0/search.html new file mode 100644 index 0000000..4fefae8 --- /dev/null +++ b/tag/3.5.0/search.html @@ -0,0 +1,176 @@ + + + + + + + + Search — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • +
  • +
+
+
+
+ + +
+ + + + +
+ +
+ +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/tag/3.5.0/searchindex.js b/tag/3.5.0/searchindex.js new file mode 100644 index 0000000..88a374f --- /dev/null +++ b/tag/3.5.0/searchindex.js @@ -0,0 +1 @@ +Search.setIndex({"alltitles":{"Attributes":[[0,"attributes"],[1,"attributes"],[2,"attributes"],[3,"attributes"],[4,"attributes"],[6,"attributes"],[11,"attributes"]],"Authors":[[0,"authors"],[1,"authors"],[2,"authors"],[3,"authors"],[4,"authors"],[6,"authors"],[11,"authors"],[13,"authors"],[14,"authors"],[15,"authors"],[16,"authors"],[17,"authors"],[18,"authors"]],"Breaking Changes / Porting Guide":[[5,"breaking-changes-porting-guide"],[5,"id76"]],"Bugfixes":[[5,"bugfixes"],[5,"id9"],[5,"id17"],[5,"id28"],[5,"id35"],[5,"id38"],[5,"id41"],[5,"id43"],[5,"id46"],[5,"id49"],[5,"id52"],[5,"id55"],[5,"id58"],[5,"id64"],[5,"id66"],[5,"id69"],[5,"id72"],[5,"id77"],[5,"id80"],[5,"id84"],[5,"id86"],[5,"id88"]],"Changelog":[[12,"changelog"]],"Cliconf Plugins":[[12,"cliconf-plugins"]],"Collection links":[[0,"collection-links"],[1,"collection-links"],[2,"collection-links"],[3,"collection-links"],[4,"collection-links"],[6,"collection-links"],[11,"collection-links"],[13,"collection-links"],[14,"collection-links"],[15,"collection-links"],[16,"collection-links"],[17,"collection-links"],[18,"collection-links"]],"Communication":[[12,"communication"]],"Community.Routeros":[[12,null]],"Community.Routeros Release Notes":[[5,null]],"Connecting to the device":[[9,"connecting-to-the-device"]],"Deprecated Features":[[5,"deprecated-features"]],"Description":[[12,"description"]],"Examples":[[0,"examples"],[1,"examples"],[2,"examples"],[3,"examples"],[4,"examples"],[6,"examples"],[11,"examples"],[13,"examples"],[14,"examples"],[15,"examples"],[16,"examples"],[18,"examples"]],"Filter":[[5,"filter"]],"Filter Plugins":[[12,"filter-plugins"]],"Guides":[[12,"guides"]],"How to connect to RouterOS devices with SSH":[[9,null]],"How to connect to RouterOS devices with the RouterOS API":[[7,null]],"How to quote and unquote commands and arguments":[[8,null]],"Important notes":[[9,"important-notes"]],"Index of all Collection Environment Variables":[[10,null]],"Input":[[13,"input"],[14,"input"],[15,"input"],[16,"input"],[18,"input"]],"Installing a certificate on a MikroTik router":[[7,"installing-a-certificate-on-a-mikrotik-router"]],"Keyword parameters":[[14,"keyword-parameters"]],"Known Issues":[[5,"known-issues"],[5,"id59"],[5,"id61"]],"Minor Changes":[[5,"minor-changes"],[5,"id2"],[5,"id4"],[5,"id6"],[5,"id8"],[5,"id12"],[5,"id14"],[5,"id16"],[5,"id19"],[5,"id21"],[5,"id23"],[5,"id25"],[5,"id27"],[5,"id30"],[5,"id32"],[5,"id34"],[5,"id37"],[5,"id45"],[5,"id48"],[5,"id51"],[5,"id54"],[5,"id57"],[5,"id63"],[5,"id68"],[5,"id71"],[5,"id75"],[5,"id79"],[5,"id82"],[5,"id90"]],"Modules":[[12,"modules"]],"New Modules":[[5,"new-modules"],[5,"id73"]],"New Plugins":[[5,"new-plugins"]],"Notes":[[1,"notes"],[3,"notes"],[4,"notes"]],"Parameters":[[0,"parameters"],[1,"parameters"],[2,"parameters"],[3,"parameters"],[4,"parameters"],[6,"parameters"],[11,"parameters"]],"Plugin Index":[[12,"plugin-index"]],"Release Summary":[[5,"release-summary"],[5,"id1"],[5,"id3"],[5,"id5"],[5,"id7"],[5,"id10"],[5,"id11"],[5,"id13"],[5,"id15"],[5,"id18"],[5,"id20"],[5,"id22"],[5,"id24"],[5,"id26"],[5,"id29"],[5,"id31"],[5,"id33"],[5,"id36"],[5,"id39"],[5,"id40"],[5,"id42"],[5,"id44"],[5,"id47"],[5,"id50"],[5,"id53"],[5,"id56"],[5,"id60"],[5,"id62"],[5,"id65"],[5,"id67"],[5,"id70"],[5,"id74"],[5,"id78"],[5,"id81"],[5,"id83"],[5,"id85"],[5,"id87"],[5,"id89"]],"Removed Features (previously deprecated)":[[5,"removed-features-previously-deprecated"]],"Requirements":[[0,"requirements"],[1,"requirements"],[2,"requirements"],[3,"requirements"],[4,"requirements"]],"Return Value":[[13,"return-value"],[14,"return-value"],[15,"return-value"],[16,"return-value"],[18,"return-value"]],"Return Values":[[1,"return-values"],[2,"return-values"],[3,"return-values"],[4,"return-values"],[6,"return-values"]],"Returned Facts":[[0,"returned-facts"],[11,"returned-facts"]],"See Also":[[0,"see-also"],[1,"see-also"],[2,"see-also"],[3,"see-also"],[4,"see-also"],[6,"see-also"],[11,"see-also"]],"Setting up a PKI":[[7,"setting-up-a-pki"]],"Setting up an inventory":[[9,"setting-up-an-inventory"]],"Setting up encryption":[[7,"setting-up-encryption"]],"Synopsis":[[0,"synopsis"],[1,"synopsis"],[2,"synopsis"],[3,"synopsis"],[4,"synopsis"],[6,"synopsis"],[11,"synopsis"],[13,"synopsis"],[14,"synopsis"],[15,"synopsis"],[16,"synopsis"],[17,"synopsis"],[18,"synopsis"]],"Topics":[[5,"topics"]],"Using the community.routeros.api module defaults group":[[7,"using-the-community-routeros-api-module-defaults-group"]],"community.routeros.api module \u2013 Ansible module for RouterOS API":[[4,null]],"community.routeros.api_facts module \u2013 Collect facts from remote devices running MikroTik RouterOS using the API":[[0,null]],"community.routeros.api_find_and_modify module \u2013 Find and modify information using the API":[[1,null]],"community.routeros.api_info module \u2013 Retrieve information from API":[[2,null]],"community.routeros.api_modify module \u2013 Modify data at paths with API":[[3,null]],"community.routeros.command module \u2013 Run commands on remote devices running MikroTik RouterOS":[[6,null]],"community.routeros.facts module \u2013 Collect facts from remote devices running MikroTik RouterOS":[[11,null]],"community.routeros.join filter \u2013 Join a list of arguments to a command":[[13,null]],"community.routeros.list_to_dict filter \u2013 Convert a list of arguments to a dictionary":[[14,null]],"community.routeros.quote_argument filter \u2013 Quote an argument":[[15,null]],"community.routeros.quote_argument_value filter \u2013 Quote an argument value":[[16,null]],"community.routeros.routeros cliconf \u2013 Use routeros cliconf to run command on MikroTik RouterOS platform":[[17,null]],"community.routeros.split filter \u2013 Split a command into arguments":[[18,null]],"v0.1.0":[[5,"v0-1-0"]],"v0.1.1":[[5,"v0-1-1"]],"v1.0.0":[[5,"v1-0-0"]],"v1.0.1":[[5,"v1-0-1"]],"v1.1.0":[[5,"v1-1-0"]],"v1.2.0":[[5,"v1-2-0"]],"v2.0.0":[[5,"v2-0-0"]],"v2.1.0":[[5,"v2-1-0"]],"v2.10.0":[[5,"v2-10-0"]],"v2.11.0":[[5,"v2-11-0"]],"v2.12.0":[[5,"v2-12-0"]],"v2.13.0":[[5,"v2-13-0"]],"v2.14.0":[[5,"v2-14-0"]],"v2.15.0":[[5,"v2-15-0"]],"v2.16.0":[[5,"v2-16-0"]],"v2.17.0":[[5,"v2-17-0"]],"v2.18.0":[[5,"v2-18-0"]],"v2.19.0":[[5,"v2-19-0"]],"v2.2.0":[[5,"v2-2-0"]],"v2.2.1":[[5,"v2-2-1"]],"v2.20.0":[[5,"v2-20-0"]],"v2.3.0":[[5,"v2-3-0"]],"v2.3.1":[[5,"v2-3-1"]],"v2.4.0":[[5,"v2-4-0"]],"v2.5.0":[[5,"v2-5-0"]],"v2.6.0":[[5,"v2-6-0"]],"v2.7.0":[[5,"v2-7-0"]],"v2.8.0":[[5,"v2-8-0"]],"v2.8.1":[[5,"v2-8-1"]],"v2.8.2":[[5,"v2-8-2"]],"v2.8.3":[[5,"v2-8-3"]],"v2.9.0":[[5,"v2-9-0"]],"v3.0.0":[[5,"v3-0-0"]],"v3.1.0":[[5,"v3-1-0"]],"v3.2.0":[[5,"v3-2-0"]],"v3.3.0":[[5,"v3-3-0"]],"v3.4.0":[[5,"v3-4-0"]],"v3.5.0":[[5,"v3-5-0"]]},"docnames":["api_facts_module","api_find_and_modify_module","api_info_module","api_modify_module","api_module","changelog","command_module","docsite/api-guide","docsite/quoting","docsite/ssh-guide","environment_variables","facts_module","index","join_filter","list_to_dict_filter","quote_argument_filter","quote_argument_value_filter","routeros_cliconf","split_filter"],"envversion":{"sphinx":65,"sphinx.domains.c":3,"sphinx.domains.changeset":1,"sphinx.domains.citation":1,"sphinx.domains.cpp":9,"sphinx.domains.index":1,"sphinx.domains.javascript":3,"sphinx.domains.math":2,"sphinx.domains.python":4,"sphinx.domains.rst":2,"sphinx.domains.std":2,"sphinx.ext.intersphinx":1},"filenames":["api_facts_module.rst","api_find_and_modify_module.rst","api_info_module.rst","api_modify_module.rst","api_module.rst","changelog.rst","command_module.rst","docsite/api-guide.rst","docsite/quoting.rst","docsite/ssh-guide.rst","environment_variables.rst","facts_module.rst","index.rst","join_filter.rst","list_to_dict_filter.rst","quote_argument_filter.rst","quote_argument_value_filter.rst","routeros_cliconf.rst","split_filter.rst"],"indexentries":{},"objects":{},"objnames":{},"objtypes":{},"terms":{"":[5,7,9,11,16],"0":[0,1,2,3,4,6,7,9,11,12,13,14,15,16,17,18],"0123456789abcdefghijklmnopqrstuvwxyz":7,"03":4,"06":9,"0600":7,"09":9,"0mib":9,"1":[0,1,2,3,4,6,7,9,11],"10":[0,1,2,3,4,6],"101":5,"104":5,"106":5,"107":5,"108":5,"109":5,"110":5,"12":7,"120":5,"121":5,"122":5,"123":5,"124":5,"125":5,"126":5,"127":5,"128":[5,9],"129":5,"130":5,"131":5,"133":5,"134":5,"137":5,"138":5,"14":4,"1400":4,"141":5,"143":5,"144":5,"148":5,"149":5,"15":12,"153":5,"154":5,"156":5,"158":5,"159":5,"161":5,"162":5,"168":[0,1,2,3,4,7,9],"170":5,"177":5,"179":5,"18":[2,3],"180":5,"189":5,"19":9,"190":5,"191":5,"192":[0,1,2,3,4,5,7,9],"193":5,"194":5,"195":5,"197":5,"198":5,"199":5,"2":[0,1,2,3,4,7,9,11,12,13,14,15,16,18],"20":4,"200":5,"201":5,"2021":9,"203":5,"204":5,"205":5,"208":5,"210":5,"211":5,"213":5,"215":5,"216":5,"217":5,"218":5,"220":5,"223":5,"224":5,"226":5,"227":5,"23":5,"230":5,"233":5,"234":5,"235":5,"236":5,"237":5,"239":5,"24":[1,2,3,4,7],"241":5,"242":5,"243":5,"244":5,"245":5,"246":5,"248":5,"24kc":9,"25":9,"25000000":5,"255":4,"256":5,"257":5,"259":5,"25m":5,"262":5,"263":5,"264":5,"266":5,"269":5,"270":5,"271":5,"272":5,"273":5,"274":5,"276":5,"277":5,"278":5,"279":5,"280":5,"284":5,"286":5,"288":5,"294":5,"295":5,"297":5,"2mib":9,"3":[0,1,2,3,4,6,9,11,12,13,14,15,16,17,18],"300":5,"302":5,"303":5,"304":5,"305":5,"309":5,"31":9,"310":5,"311":5,"313":5,"315":5,"318":5,"32":[4,7],"320":5,"321":5,"322":5,"323":5,"324":5,"327":5,"331":5,"338":5,"339":5,"34":5,"340":5,"341":5,"342":5,"343":5,"344":5,"345":5,"350":5,"36":4,"37":5,"38":5,"39":5,"3d10h28m51":9,"4":[0,1,2,3,4,9],"400mhz":9,"43":5,"45":[5,9],"47":5,"48":9,"49":5,"5":[0,1,2,3,4,6,11,12,13,14,15,16,17,18],"50":5,"512":9,"51572981":9,"53":5,"54":9,"55":5,"6":[0,1,2,3,4,9],"62":5,"63":5,"64":9,"67":5,"68":5,"6to4":[2,3,5],"8":[0,1,2,3,4],"83":5,"8728":[0,1,2,3,4],"8729":[0,1,2,3,4],"88":[0,1,2,3],"89":5,"927":9,"95":5,"A":[0,1,2,3,4,5,6,11,13,14,18],"As":0,"By":[2,5],"For":[3,4,13,14,15,16,17,18],"If":[0,1,2,3,4,5,6,7,9],"In":[4,5],"It":[0,1,2,3,4,6,7,8,11,13,14,15,16,17,18],"No":[7,10],"On":1,"That":7,"The":[0,1,2,3,4,5,6,7,8,9,10,11,13,15,16,18],"These":[12,14],"To":[0,1,2,3,4,6,7,11,13,14,15,16,17,18],"Will":[0,1,2,3,4,6,11],"With":9,"_":5,"aaa":[2,3],"abl":[0,1,2,3,4,5,7],"about":[0,1,2,3,4,5,9,12],"abov":9,"abstract":17,"accept":[2,3,5,8,14],"access":[2,3,5,7],"accord":5,"account":[2,3],"achiev":11,"action":[0,1,2,3,4,5,6,11],"action_group":[0,1,2,3,4],"activ":11,"actual":[1,2,3,6],"ad":[0,1,2,3,4,5,9,11],"adapt":5,"add":[4,5,7,9],"addit":[0,11],"address":[0,1,2,3,4,5,7,8,9,11],"adh":[0,1,2,3,4,5],"adjust":[3,5],"adlist":[2,3,5],"admin":[0,3,7,9],"admin_network":7,"advanc":[2,3],"advertis":[2,3,5],"affect":[2,3],"after":[1,3,4,5],"again":6,"against":[0,1,2,3,4,5,6,11],"aggreg":[2,3,5],"algorithm":5,"alia":5,"alias":[0,1,2,3,4],"align":[2,3],"all":[0,1,2,3,4,5,6,7,11],"allow":[1,2,3,4,5,7,8,9,14],"allow_no_match":1,"alphanumer":9,"alreadi":5,"also":[5,7,9],"altern":[5,7,9],"alwai":[0,2,3,4,5,6,7,11],"always_upd":3,"an":[0,1,2,3,4,5,6,7,8,11,12],"ani":[0,2,3,4,6,7,11],"anonym":[0,1,2,3,4],"ansibl":[0,1,2,3,5,6,7,9,10,11,12,13,14,15,16,17,18],"ansible_connect":9,"ansible_fact":[0,11],"ansible_host":9,"ansible_net_":[0,11],"ansible_net_all_ipv4_address":[0,9,11],"ansible_net_all_ipv6_address":[0,11],"ansible_net_arch":[0,11],"ansible_net_bgp_inst":[0,11],"ansible_net_bgp_p":[0,11],"ansible_net_bgp_vpnv4_rout":[0,11],"ansible_net_config":11,"ansible_net_config_nonverbos":[5,11],"ansible_net_cpu_load":[0,11],"ansible_net_gather_subset":[0,11],"ansible_net_hostnam":[0,11],"ansible_net_interfac":[0,11],"ansible_net_memfree_mb":[0,11],"ansible_net_memtotal_mb":[0,11],"ansible_net_model":[0,11],"ansible_net_neighbor":[0,11],"ansible_net_ospf_inst":[0,11],"ansible_net_ospf_neighbor":[0,11],"ansible_net_rout":[0,11],"ansible_net_serialnum":[0,11],"ansible_net_spacefree_mb":[0,11],"ansible_net_spacetotal_mb":[0,11],"ansible_net_uptim":[0,11],"ansible_net_vers":[0,11],"ansible_network_o":9,"ansible_ssh_pass":9,"ansible_us":9,"anymor":5,"anyth":1,"apart":6,"api":[5,8,12,17],"api_fact":[1,2,3,4,5,7,12],"api_find_and_modifi":[0,2,3,4,5,7,12],"api_info":[0,1,3,4,5,7,12],"api_modifi":[0,1,2,4,5,7,12],"appear":[3,5],"appli":[0,1,2,3,4],"applic":5,"ar":[0,1,2,3,4,5,6,7,9,10,11,12,14],"arbitrari":[4,6,9],"arbitraryout":4,"architectur":[0,9,11],"area":[2,3,5],"argument":[0,1,2,3,4,5,6,11,12],"argument_list":18,"arp":[2,3,5],"ascii":[0,1,2,3,4,5],"ask":[0,1,2,3,4,6,11,12,13,14,15,16,17,18],"assign":14,"assum":[0,1,2,3,4,6,7,11],"attack":[0,1,2,3,4,7],"attribut":5,"auth":5,"authent":[0,1,2,3,4],"author":12,"auto":5,"automat":5,"avail":[0,5,7,11],"avoid":[5,7],"awesom":[1,3],"back":5,"backport":5,"backup":[2,3],"backward":7,"bad":9,"bandwidth":[2,3],"bar":[1,8,13,14,18],"base":[0,1,5,7,9,11],"baz":18,"becaus":[0,1,2,3,4],"been":[1,5,7,10],"befor":[1,2,3,5,6,9,13,14,15,16,18],"behavior":[3,5],"below":[0,1,2,3,4],"best":7,"better":[2,3],"between":[5,6,11],"bgp":[0,2,3,5,11],"bigger":4,"bind":9,"blackhol":5,"block":[3,7,9],"board":9,"bond":[2,3,5],"boolean":[0,1,2,3,4,14],"boot":5,"both":[2,3],"bridg":[1,2,3,5,7],"broker":5,"browser":7,"bsd":5,"bug":[0,1,2,3,4,6,11,12,13,14,15,16,17,18],"build":9,"builtin":[2,3,4,5,7,13,14,15,16,18],"bundl":7,"byte":5,"ca":[0,1,2,3,4,7],"ca_path":[0,1,2,3,4,5,7],"call":9,"can":[0,1,2,3,4,5,6,7,9,11,14],"cannot":[3,5],"cap":[2,3,5],"capsman":[2,3],"case":[1,4,5,7,8],"caus":[5,6],"certain":7,"certif":[0,1,2,3,4,5],"certificate_path":7,"cet512w":9,"chain":3,"chang":[0,1,2,3,4,6,7,9,11],"changed_when":[5,6,7],"changelog":5,"channel":[2,3,5,12],"charact":[5,9],"check":[0,1,2,3,4,5,6,7,11,13,14,15,16,17,18],"check_mod":[0,1,2,3,4,6,11],"choic":[0,1,2,3,4,6,14],"chosen":7,"cipher":[0,1,2,3,4,5],"circumst":5,"claim":[5,6],"classifi":5,"claus":[4,5],"clean":7,"cli":[1,2,3,4,5,13,15,16,17],"cliconf":[5,9],"client":[2,3,5],"clock":[2,3,5],"cloud":[2,3,5],"cmd":4,"collect":[5,8,9,12],"com":[5,12],"combo":5,"command":[3,4,5,7,9,12,15,16],"comment":[0,1,2,3,4,5,6,8,11,13,14,15,16,18],"commerci":7,"common":[1,2,3,4,6,7],"commun":[8,9],"compar":[3,4],"compat":[5,7],"complet":[5,7],"complex":5,"concurr":5,"condit":[1,2,3,4,6],"config":[2,3,4,5,11],"configur":[0,1,2,3,5,6,7,10,11,13,14,15,16,17,18],"conflict":5,"conform":5,"conjunct":[4,6],"connect":[0,1,2,3,4,5,6,11,12],"consid":[0,1,2,3,4,6],"contain":[0,1,2,3,4,5,6,8,9,11],"content":5,"continu":5,"control":[0,1,2,3,4,5,6,7,11],"convert":[2,3,5,7,12],"copi":7,"core":[0,1,2,3,4,5,6,10,11,12,13,14,15,16,17,18],"correct":[5,7],"correctli":[5,7],"count":9,"counter":2,"cpu":[0,5,9,11],"crash":5,"creat":[0,1,2,3,4,5,7],"create_onli":3,"creation":[3,5],"credenti":9,"criteria":[1,2,3],"crypto":7,"current":[0,1,2,3,5,11],"custom":[3,5],"cycl":5,"dachev":[0,4,12],"dash":[5,9],"data":[0,1,2,4,5,7,8,12,14],"datapath":[2,3,5],"date":5,"ddn":5,"deactiv":[0,1,2,3,4],"debug":[2,4,7,9],"deciph":5,"declar":[5,10],"default":[0,1,2,3,4,5,6,8,9,11,14],"defconf":[1,2,3],"defin":[5,10],"delegate_to":7,"depend":[3,4,5,6,7],"describ":[3,7,13,14,15,16,18],"descript":[0,1,2,3,4,6,11,13,14,15,16,18],"dest":7,"detail":[0,1,2,3,4,6,7,9,11],"detect":[2,3,5],"determin":[5,6],"devel":5,"develop":[2,3],"devi":9,"devic":[1,2,3,4,5,12,17],"dhcp":[2,3,5],"dictionari":[0,1,2,3,4,5,8,11,12],"diff":[0,1,2,3,4,6,11],"diff_mod":[0,1,2,3,4,6,11],"differ":[1,3,4,7],"diffi":[0,1,2,3,4],"directori":5,"disabl":[0,1,2,3,5,7,11],"discourag":7,"discoveri":[2,3,5],"discuss":12,"disk":[0,11],"dn":[2,3,5,7],"do":[0,3,5,7,9,11],"doc":5,"docsit":5,"document":[1,2,3,4,5,6,7,9,10],"doe":[0,2,5,6,9,11],"doh":5,"domain":5,"done":[5,7],"drop":[3,5],"dscp":5,"dst":5,"due":5,"duid":5,"dump":4,"duplic":5,"dure":[5,7],"dynam":[1,2,3,5],"e":[2,3,5],"each":[6,13,14,15,16,17,18],"easier":7,"egor":[0,6,11,12,17],"either":[4,7],"element":[0,1,2,3,4,5,6,11,13,14,18],"empti":[1,3,4,8,14],"enabl":[0,5,7,11],"encod":[0,1,2,3,4,5],"end":5,"engin":5,"ensur":[3,5],"ensure_ord":3,"entri":[1,2,3,4,5,7,13,14,15,16,17,18],"environ":5,"eoip":[2,3,5],"eq":4,"equal":4,"equival":[1,2,3,4,5,7],"error":[3,5,6,9],"escap":5,"ether1":[4,6],"ether2":4,"etherboot":5,"ethernet":[2,3,5,6],"evalu":6,"even":[5,7],"everi":[1,4,5,6,7,9],"exactli":[1,3],"exampl":[5,7,8,9,17],"except":[3,5],"exchang":[0,1,2,3,4],"exclam":2,"exclus":4,"execut":[0,1,2,3,4,5,6,9],"exist":[0,2,3,4,5,11],"expect":[1,9],"expir":6,"explicit":5,"export":[5,11],"expos":5,"express":[2,3],"extend":[2,3,4,5],"extended_queri":4,"extended_queryout":4,"extra":5,"fact":[1,2,3,4,5,7,9,12],"fail":[1,3,5,6,7,9],"failed_condit":6,"failed_when":5,"failur":5,"fals":[0,1,2,3,4,5,7,8,9,14],"famili":[0,1,2,3,4,6,11],"favor":5,"featur":[0,1,2,3,4,6,11,12,13,14,15,16,17,18],"fec":5,"felix":[0,1,2,3,12,13,14,15,16,18],"felixfontein":[0,1,2,3,12,13,14,15,16,18],"few":7,"field":[1,2,3,4,5,6],"file":[0,1,2,3,4,5,7,9],"filter":[2,3,8],"final":5,"find":[0,2,3,4,5,7,12],"firewal":[2,3,5],"firmwar":[2,3],"first":[2,3,5,7,9,11],"firwal":5,"fix":5,"flow":[2,3,5],"follow":[1,2,3,4,5,6,7,9,10,14],"fontein":[0,1,2,3,12,13,14,15,16,18],"foo":[1,8,13,14,18],"forc":[0,1,2,3,4,5],"force_no_cert":[0,1,2,3,4,5,7],"form":[5,8,11],"format":[0,1,2,3,4],"forum":12,"forward":[2,3,5,6,9],"found":[1,2,3],"fragment":5,"free":[0,9,11],"frequenc":[5,9],"friendly_nam":7,"fritzbox":5,"from":[1,3,4,5,6,7,12,17],"full":[0,1,2,3,5,11],"fulli":[5,7],"function":5,"further":[0,1,2,3,4],"galaxi":[0,1,2,3,4,6,11,13,14,15,16,17,18],"gatewai":[3,5],"gather":[7,9],"gather_fact":[7,9],"gather_subset":[0,5,11],"gener":[2,3,5,7,12],"get":[2,4,5,7],"github":[5,12],"given":[0,1,4,11],"gmt":5,"graph":[2,3,5],"gre":[2,3,5],"gre6":[2,3,5],"group":[0,1,2,3,4,5],"guid":7,"ha":[0,1,2,3,4,5,6,7,8,11],"handl":[2,3,5],"handle_absent_entri":3,"handle_dis":2,"handle_entries_cont":3,"handle_read_onli":[3,5],"handle_write_onli":[3,5],"happen":[5,9],"hardwar":[0,11],"hash":[0,11],"have":[0,1,2,3,4,5,6,7,9,10,13,14,15,16,17,18],"hdd":9,"he":5,"health":[2,3,5],"heavili":[2,3],"hellman":[0,1,2,3,4],"help":[0,1,2,3,4,6,8,11,12,13,14,15,16,17,18],"here":[1,2,3,4,5,6,7],"heuel":[0,6,11,12,17],"hide":2,"hide_default":2,"high":[13,14,15,16,17,18],"higher":[13,14,15,16,17,18],"host":[0,1,2,3,4,5,7,9,11],"hostnam":[0,1,2,3,4,5,7,11],"hostvar":[0,11],"hotspot":[2,3,5],"how":[0,1,2,3,4,6,11,12],"html":5,"http":[0,1,2,3,4,5,7],"human":5,"hw":5,"i":[0,1,2,3,4,5,6,7,8,9,11,13,14,15,16,17,18],"icmp":5,"id":[1,2,3,4,5],"idempot":[0,1,2,3,4,5,6,11],"ident":[2,3,4,5,6,9,11],"identifi":5,"igmp":[2,3,5],"ignor":[3,7,9],"im":12,"implement":5,"import":[2,3,5,7],"imposs":5,"improv":5,"includ":[0,1,2,3,4,5,6,7,11,13,14,15,16,17,18],"include_builtin":[2,5],"include_dynam":2,"include_read_onli":[2,5],"inclus":5,"incom":[2,3],"inconsist":5,"incorrect":5,"indic":[0,1,2,3,4,5,6,11],"induc":1,"inform":[0,3,4,5,7,11,12],"ingress":5,"initi":[0,5,11],"input":[2,3,4,7],"insecur":5,"insert":7,"instal":[0,1,2,3,4,5,6,11,13,14,15,16,17,18],"instanc":[0,2,3,5,11],"instead":[0,1,2,3,4,7,9],"instruct":7,"integ":[0,1,2,3,4,6,11],"intend":5,"interfac":[0,1,2,3,4,5,6,7,11],"intern":5,"internet":[2,3],"interv":[5,6],"interwork":[2,3],"introduc":5,"invalid":[1,2,3],"inventory_hostnam":7,"invert":[2,3],"invoc":[0,1,2,3,4,6,11],"iot":[2,3,5],"ip":[1,2,3,4,5,7,8,9],"ip2":4,"ip_address":2,"ipaddrd_printout":4,"ipfix":[2,3],"ipsec":[2,3,5],"ipv4":[0,5,11],"ipv6":[0,2,3,5,11],"irc":12,"irq":[2,3,5],"issu":[0,1,2,3,4,6,9,11,12,13,14,15,16,17,18],"item":[4,5],"its":[4,5,7,9],"jinja2":8,"join":[5,8,12],"json":7,"judg":5,"jump":5,"just":[0,2,11],"keep":5,"kei":[0,1,2,3,4,5,6,7,9,11,13,14,15,16,18],"kept":3,"key1":14,"key2":14,"l2tp":[2,3,5],"larger":[0,1,11],"later":5,"latest":5,"latter":1,"layer7":[2,3,5],"ldp":[2,3,5],"leas":[2,3,5],"least":[1,3,4,5],"led":[2,3],"length":7,"less":[1,4,7],"level":[6,17],"libera":12,"librari":4,"libroutero":[0,1,2,3,4],"libssh":9,"licens":5,"life":5,"like":[0,1,5,8,9,11],"limit":[1,2,3,5],"line":[5,9,11],"list":[0,1,2,3,4,5,6,8,11,12,15,16,17,18],"list_to_dict":[5,8,12],"load":[0,9,11],"local":7,"localhost":7,"log":[2,3,5],"login":[0,1,2,3,4,9],"long":[6,9],"longer":[5,9],"look":[0,1,2,3,4,5],"lookup":7,"low":[6,13,14,15,16,17,18],"lower":[13,14,15,16,17,18],"mac":[2,3,5],"made":[1,3],"mai":[5,9],"mail":[2,3,5],"main":4,"mainten":5,"major":5,"make":[0,1,2,3,4,5,9],"man":[0,1,2,3,4,5,7],"manag":[2,3,5],"mangl":[2,3,5],"manual":[2,3],"mark":5,"markup":5,"masquerad":3,"match":[1,2,3,4,5,6,7],"match_count":1,"match_dis":[2,3],"matcher":[2,3,5],"matrix":[5,12],"max":5,"mdix":5,"mean":[3,5],"member":[2,3,5],"memori":[0,5,9,11],"mention":3,"messag":[4,5],"met":6,"mib":[0,11],"middl":[0,1,2,3,4,7],"might":7,"mikrotik":[1,2,3,4,5,9,12],"minim":11,"mip":9,"mipsb":9,"mirror":[2,3],"miss":5,"mitig":5,"mlag":[2,3,5],"mld":5,"mme":[2,3],"modbu":[2,3,5],"mode":[0,1,2,3,4,5,6,7,11],"model":[0,11],"modem":5,"modern":9,"modif":[3,4],"modifi":[0,2,4,5,6,7,11,12],"modify__count":1,"modul":[8,9],"module_default":[0,1,2,3,4,7],"module_util":5,"more":[1,4,5,7],"moreov":5,"most":[5,7],"move":6,"mpl":[2,3,5],"msg":[4,5,7,9],"mss":5,"mtu":4,"multicast":5,"multipl":[1,3,5,6],"must":[4,6],"mut":4,"mutual":4,"my":1,"n":[0,1,2,4,6,11],"naiv":5,"name":[0,1,2,3,4,5,6,7,8,9,11,13,14,15,16,18],"nat":[2,3,5],"nativ":5,"nd":[2,3,5],"need":[0,1,2,3,4,5,6,7,8,9,11],"neighbor":[0,2,3,5,11],"nest":9,"net_put":7,"netcommon":[7,9],"netmask":3,"netwatch":[2,3,5],"network":[0,1,2,3,4,5,7,11,12,17],"network_cli":9,"never":5,"new":[0,1,2,3,13,14,15,16,18],"new_data":[1,3],"newer":[0,1,2,3,4,5,12],"next":5,"nikolai":[0,4,12],"nikolaydachev":[0,4,12],"node":6,"non":5,"none":[3,4,5,6],"normal":2,"note":[0,2,12],"noth":3,"now":5,"nth":5,"ntp":[2,3,5],"null":[2,3],"num":[2,3,5],"number":[0,1,4,5,6,11],"o":[0,1,2,3,4,6,11],"object":[3,4,7],"offer":9,"offload":5,"offset":5,"ok":[7,9],"old":[1,5],"old_data":[1,3],"older":7,"omit":2,"onc":[1,7],"one":[1,3,4,6,8],"ones":[2,3],"onli":[0,1,2,3,4,5,6,7,9,11],"onto":7,"openssl_pkcs12":7,"oper":[0,1,2,3,4,6,11],"oppos":0,"option":[0,1,2,3,4,5,7,8,9],"order":[0,3,5,11,13,14,15,16,17,18],"ordereddict":3,"origin":5,"ospf":[0,2,3,5,11],"other":[0,2,4,5,8,11],"out":[3,5,6,7],"output":[2,3,4,5,6,7,9],"outsid":[0,1,2,3,4,6,11],"over":[5,6],"overrid":[13,14,15,16,17,18],"override_al":7,"ovpn":[2,3,5],"own":[0,1,2,3,4,7],"p12":7,"packag":[2,3,5],"packet":5,"paramet":[5,7,13,15,16,18],"paramiko":9,"pars":7,"part":[0,1,2,3,4,6,11,13,14,15,16,17,18],"pass":[3,6,8],"passphras":7,"password":[0,1,2,3,4,7,9],"path":[0,1,2,4,5,7,12],"peer":[0,2,3,5,11],"pem":[0,1,2,3,4,7],"per":5,"perform":4,"pimsm":[2,3,5],"ping":[2,3,5],"pkc":7,"pkcs12":7,"plai":[7,9],"platform":[0,1,2,3,4,6,9,11,12],"playbook":[0,1,2,3,4,5,6,7,9,11,13,14,15,16,17,18],"pleas":[0,1,2,3,4,5,7,9],"plugin":[6,8,9,10,13,14,15,16,17,18],"poe":[2,3,5],"point":7,"polici":[2,3,5,6],"pool":[2,3,5],"port":[0,1,2,3,4],"possibl":[0,2,3,11],"possibli":[0,1,2,3,4,6,11],"potenti":5,"power":5,"ppp":[2,3,5],"pppoe":[2,3,5],"pptp":[2,3],"preboot":5,"predefin":7,"predict":[0,1,2,3,4,6,11],"pref":5,"prefix":[2,3,5],"prepar":5,"prepend":[0,1,2,3,11],"preprocess":5,"prereleas":5,"present":[3,5],"prevent":5,"primari":5,"print":[2,4,6,7,9],"print_path":7,"prioriti":[5,13,14,15,16,17,18],"privat":7,"privatekey_path":7,"problem":[2,3,7,9],"produc":9,"product":[5,7],"profil":[2,3,5],"program":5,"properti":[5,6],"propos":[2,3,5],"protect":7,"protocol":[0,1,2,3,4,5],"provid":[1,2,3,5,6,8,17],"provis":[2,3,5],"proxi":[2,3,5],"psd":5,"public":5,"pull":5,"pylibssh":9,"python":[0,1,2,3,4,5,7,9],"queri":[0,1,2,3,4,5,6,11],"querier":5,"queryout":4,"question":12,"queue":[2,3,5],"quit":7,"quot":[4,5,6,12,13],"quote_argu":[5,8,12],"quote_argument_valu":[4,5,8,12],"radiu":[2,3,5],"random":[5,7],"random_password":7,"random_str":7,"randomis":5,"rang":[2,3,5],"rate":5,"raw":[2,3,5],"rb750gl":9,"reachabl":7,"read":[2,3,5,6],"readabl":5,"realm":5,"reboot":9,"recap":[7,9],"receiv":17,"recommend":7,"record":5,"referenc":[0,11],"regex":[2,3],"regexp":5,"regist":[0,2,4,7,9,11],"regular":[2,3,5],"reject":5,"rel":5,"relai":[2,3,5],"releas":12,"relev":[0,1,2,3,4,6,11],"reli":5,"remot":[1,2,3,4,5,12],"remov":[3,4,7],"remove_as_much_as_poss":3,"renam":[1,5],"render":5,"replac":[4,9],"report":[0,1,2,3,4,6,11,12,13,14,15,16,17,18],"repositori":[0,1,2,3,4,5,6,11,12,13,14,15,16,17,18],"represent":14,"request":[0,1,2,3,4,6,11,12,13,14,15,16,17,18],"requir":[5,6,8,13,14,15,16,18],"require_assign":[8,14],"require_matches_max":1,"require_matches_min":1,"rescu":[7,9],"resourc":[2,3,5,6,9],"resp":2,"respond":5,"respons":6,"restor":[2,3],"restrict":[0,2,3,4,5,11],"result":[2,3,5,6,7,9,13,14,15,16,18],"retri":6,"retriev":[0,1,3,4,5,7,12],"return":[5,7],"reus":5,"rip":[2,3],"ripng":[2,3],"ro":5,"role":5,"romon":[2,3],"room":12,"root":5,"ros6":5,"ros7":5,"rout":[0,2,3,5,11],"router":[0,1,2,3,4,5,9],"routerboard":[2,3,5,6],"routero":8,"routeros_":5,"row":[0,1,2,3,4,6,11],"rp":[2,3,5],"rule":[2,3,5],"run":[1,2,3,4,5,7,9,12,13,14,15,16,18],"safe":5,"same":[0,1,2,3,4,5,6,11],"sampl":[1,2,3,4,6],"satisfi":6,"schedul":[2,3,5],"script":[2,3,4,5],"search":[1,3],"second":[0,1,2,3,4,5,6,11],"secret":[2,3,5],"sect":9,"secur":[2,3,5],"see":[5,7,9],"seen":5,"select":[2,3,4,5],"semant":5,"send":[6,17],"sens":[3,11],"sequenc":5,"serial":[0,11],"server":[2,3,5],"servic":[2,3,7],"set":[0,1,2,3,4,5,6,8,10,11,14],"set_fact":[7,13,14,15,16,18],"setup":[3,7],"should":[0,1,2,3,5,6,7,9,11,13,15,16,18],"show":[5,7,9],"sign":[0,1,2,3,4,7],"signatur":5,"signific":5,"similar":[0,9],"simpl":[2,3,5],"simpli":[0,1,2,3,4,6],"sinc":[3,5,7,9],"singl":3,"situat":5,"size":5,"skip":[0,1,2,3,4,7,8,9,14],"skip_empty_valu":[8,14],"slash":[5,9],"sm":[2,3],"small":[5,7],"smb":[2,3],"sniffer":[2,3],"snmp":[2,3,5],"snooper":[2,3],"so":[4,14],"sock":[2,3],"softwar":5,"some":[2,3,5,8],"someth":9,"sourc":[0,1,2,3,4,6,11,12,13,14,15,16,17,18],"space":[0,4,5,8,9,11],"spdx":5,"special":7,"specif":[0,1,4,5,6,7,11],"specifi":[0,1,2,3,4,6,7,9,11,13,14,15,16,17,18],"split":[5,6,8,12,14],"src":[5,7],"srcnat":3,"ssh":[2,3,5,6,7,11,12],"ssh_type":9,"ssl":[0,1,2,3,4,5,7],"sstp":[2,3],"stabl":9,"start":9,"state":[0,2,5,11],"static":[2,3,5],"statu":[0,1,2,3,4,5,6,11],"stdout":[5,6],"stdout_lin":[6,7,9],"steer":[2,3],"step":1,"still":[2,3,5],"store":9,"strict":[3,5],"string":[0,1,2,3,4,5,6,8,9,11,13,14,15,16,18],"strip":11,"sub":5,"subdomain":5,"subject":7,"submit":[0,1,2,3,4,6,11,12,13,14,15,16,17,18],"subpath":5,"subset":[0,3,11],"success":[1,13,14,15,16,18],"successfulli":7,"suffix":5,"suggest":5,"suppli":[0,11],"support":[0,1,2,3,4,5,6,9,11,12],"suppress":5,"sure":[1,2,3,7,9],"suscept":[0,1,2,3,4,7],"switch":[2,3],"symbol":[5,9],"system":[0,1,2,3,4,5,6,9,11],"system_resource_print":9,"tabl":[0,2,3,5,11],"talk":7,"target":[0,1,2,3,4,5,6,11],"task":[1,5,6,7,8,9],"tcp":5,"tell":[0,1,2,3,4,9],"templat":[2,3,5],"termin":5,"test":[7,9],"test1234":[7,9],"text":[5,7,8],"tftp":[2,3],"than":[1,4,5,9],"thei":[0,2,3,11],"them":[0,3,4,8,11],"thi":[0,1,2,3,4,5,6,7,8,9,11,13,14,15,16,17,18],"thing":[0,1,2,3,4],"think":[2,3],"those":5,"three":[3,7],"through":[4,7],"thu":5,"time":[5,6,9],"timeout":[0,1,2,3,4,5],"timestamp":11,"tl":[0,1,2,3,4,5,7],"togeth":[1,3,9],"too":9,"tool":[2,3,5],"total":[0,9,11],"touch":3,"track":[2,3],"tracker":[0,1,2,3,4,6,11,12,13,14,15,16,17,18],"traffic":[2,3,5],"trap":5,"tree":[2,3,5],"tri":6,"troubl":[5,9],"true":[0,1,2,3,4,5,6,7,8,14],"trust":7,"truststor":7,"try":6,"ttl":5,"tunnel":5,"twice":[0,1,2,3,4,6,11],"two":[3,8,9],"tx":5,"txt":5,"type":[2,3,5,13,14,15,16,17,18],"under":5,"underscor":5,"unexpect":5,"unfilt":2,"uniqu":[1,2,3,4,5,6],"unnecessari":5,"unquot":[4,5,6,12],"unreach":[5,7,9],"unset":[1,2,3],"unsupport":9,"until":[5,6],"unwrap":5,"up":[2,3,5,13,14,15,16,17,18],"updat":[0,2,3,4,5,11],"upgrad":[2,3,5],"upnp":[2,3,5],"upper":1,"uptim":[0,9,11],"us":[2,3,4,5,6,8,9,10,11,12,13,14,15,16,18],"usag":12,"user":[0,1,2,3,4,5,9,12],"usernam":[0,1,2,3,4,5,7,9],"usual":7,"utf":[0,1,2,3,4],"util":5,"v":5,"v7":9,"valid":[0,1,2,3,4,5,6,7],"validate_cert":[0,1,2,3,4,5,7],"validate_cert_hostnam":[0,1,2,3,4,5,7],"valu":[0,5,7,8,11,12],"value1":14,"value2":14,"var":[2,7,9],"variabl":[13,14,15,16,17,18],"variant":[2,3],"variou":5,"verbos":5,"verif":7,"verifi":3,"version":[0,1,2,3,4,5,6,7,9,11,12,13,14,15,16,17,18],"via":[5,9],"virtual":5,"vlan":[2,3,5],"voltag":5,"vpnv4":[0,11],"vrf":[2,3,5],"vrrp":[2,3,5],"wa":[1,3,5,11],"wai":[0,1,2,3,4,6,7,11],"wait":6,"wait_for":[5,6],"wan":3,"want":[1,2,3],"watchdog":[2,3],"we":[1,3,4,5,7],"web":[2,3],"well":[2,5,7],"were":1,"what":[0,1,2,3,4,5,6,11],"when":[0,1,2,3,4,5,6,7,8,9,11,14],"where":[4,5],"whether":[0,1,2,3,4,5,6,11,13,14,15,16,17,18],"which":[4,5,7,8,9],"while":8,"whitespac":5,"whose":[2,3,8,14],"wifi":[2,3,5],"wifiwave2":[2,3,5],"winbox":[2,3],"wipe":7,"wireguard":[2,3,5],"wireless":[2,3,5],"within":6,"without":[0,1,2,3,4,5,6,7,8,11,14],"word":4,"work":[0,1,2,3,4,5,7],"workaround":5,"wrap":9,"write":[3,5,9],"wrong":5,"www":7,"x":5,"x86":6,"y":5,"yaml":1,"ye":5,"you":[0,1,2,3,4,5,6,7,8,9],"your":[0,1,2,3,4,5,7,9],"zaitsev":[0,6,11,12,17],"zero":1},"titles":["community.routeros.api_facts module \u2013 Collect facts from remote devices running MikroTik RouterOS using the API","community.routeros.api_find_and_modify module \u2013 Find and modify information using the API","community.routeros.api_info module \u2013 Retrieve information from API","community.routeros.api_modify module \u2013 Modify data at paths with API","community.routeros.api module \u2013 Ansible module for RouterOS API","Community.Routeros Release Notes","community.routeros.command module \u2013 Run commands on remote devices running MikroTik RouterOS","How to connect to RouterOS devices with the RouterOS API","How to quote and unquote commands and arguments","How to connect to RouterOS devices with SSH","Index of all Collection Environment Variables","community.routeros.facts module \u2013 Collect facts from remote devices running MikroTik RouterOS","Community.Routeros","community.routeros.join filter \u2013 Join a list of arguments to a command","community.routeros.list_to_dict filter \u2013 Convert a list of arguments to a dictionary","community.routeros.quote_argument filter \u2013 Quote an argument","community.routeros.quote_argument_value filter \u2013 Quote an argument value","community.routeros.routeros cliconf \u2013 Use routeros cliconf to run command on MikroTik RouterOS platform","community.routeros.split filter \u2013 Split a command into arguments"],"titleterms":{"0":5,"1":5,"10":5,"11":5,"12":5,"13":5,"14":5,"15":5,"16":5,"17":5,"18":5,"19":5,"2":5,"20":5,"3":5,"4":5,"5":5,"6":5,"7":5,"8":5,"9":5,"all":10,"also":[0,1,2,3,4,6,11],"an":[9,15,16],"ansibl":4,"api":[0,1,2,3,4,7],"api_fact":0,"api_find_and_modifi":1,"api_info":2,"api_modifi":3,"argument":[8,13,14,15,16,18],"attribut":[0,1,2,3,4,6,11],"author":[0,1,2,3,4,6,11,13,14,15,16,17,18],"break":5,"bugfix":5,"certif":7,"chang":5,"changelog":12,"cliconf":[12,17],"collect":[0,1,2,3,4,6,10,11,13,14,15,16,17,18],"command":[6,8,13,17,18],"commun":[0,1,2,3,4,5,6,7,11,12,13,14,15,16,17,18],"connect":[7,9],"convert":14,"data":3,"default":7,"deprec":5,"descript":12,"devic":[0,6,7,9,11],"dictionari":14,"encrypt":7,"environ":10,"exampl":[0,1,2,3,4,6,11,13,14,15,16,18],"fact":[0,11],"featur":5,"filter":[5,12,13,14,15,16,18],"find":1,"from":[0,2,11],"group":7,"guid":[5,12],"how":[7,8,9],"import":9,"index":[10,12],"inform":[1,2],"input":[13,14,15,16,18],"instal":7,"inventori":9,"issu":5,"join":13,"keyword":14,"known":5,"link":[0,1,2,3,4,6,11,13,14,15,16,17,18],"list":[13,14],"list_to_dict":14,"mikrotik":[0,6,7,11,17],"minor":5,"modifi":[1,3],"modul":[0,1,2,3,4,5,6,7,11,12],"new":5,"note":[1,3,4,5,9],"paramet":[0,1,2,3,4,6,11,14],"path":3,"pki":7,"platform":17,"plugin":[5,12],"port":5,"previous":5,"quot":[8,15,16],"quote_argu":15,"quote_argument_valu":16,"releas":5,"remot":[0,6,11],"remov":5,"requir":[0,1,2,3,4],"retriev":2,"return":[0,1,2,3,4,6,11,13,14,15,16,18],"router":7,"routero":[0,1,2,3,4,5,6,7,9,11,12,13,14,15,16,17,18],"run":[0,6,11,17],"see":[0,1,2,3,4,6,11],"set":[7,9],"split":18,"ssh":9,"summari":5,"synopsi":[0,1,2,3,4,6,11,13,14,15,16,17,18],"topic":5,"unquot":8,"up":[7,9],"us":[0,1,7,17],"v0":5,"v1":5,"v2":5,"v3":5,"valu":[1,2,3,4,6,13,14,15,16,18],"variabl":10}}) \ No newline at end of file diff --git a/tag/3.5.0/split_filter.html b/tag/3.5.0/split_filter.html new file mode 100644 index 0000000..4c273b2 --- /dev/null +++ b/tag/3.5.0/split_filter.html @@ -0,0 +1,268 @@ + + + + + + + + + + community.routeros.split filter – Split a command into arguments — Community.Routeros Collection documentation + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
Community.Routeros Collection Docs
+
+
+ + +
+ +
+
+
+
    +
  • + +
  • + + Edit on GitHub +
  • +
+
+
+
+ + +
+ +
+

community.routeros.split filter – Split a command into arguments

+
+

Note

+

This filter plugin is part of the community.routeros collection (version 3.5.0).

+

It is not included in ansible-core. +To check whether it is installed, run ansible-galaxy collection list.

+

To install it, use: ansible-galaxy collection install community.routeros.

+

To use it in a playbook, specify: community.routeros.split.

+
+

New in community.routeros 2.0.0

+ +
+

Synopsis

+
    +
  • Split a command into arguments.

  • +
+
+
+

Input

+

This describes the input of the filter, the value before | community.routeros.split.

+ + + + + + + + + + + +

Parameter

Comments

+

Input

+

string / required

+

A command.

+
+
+
+

Examples

+
- name: Split command into list of arguments
+  ansible.builtin.set_fact:
+    argument_list: "{{ 'foo=bar comment="foo is bar" baz' | community.routeros.split }}"
+    # Should result in ['foo=bar', 'comment=foo is bar', 'baz']
+
+
+
+
+

Return Value

+ + + + + + + + + + + +

Key

Description

+

Return value

+

list / elements=string

+

The list of arguments.

+

Returned: success

+
+
+

Authors

+
    +
  • Felix Fontein (@felixfontein)

  • +
+
+

Hint

+

Configuration entries for each entry type have a low to high priority order. For example, a variable that is lower in the list will override a variable that is higher up.

+
+
+ +
+
+ + +
+
+ + +
+ +
+ +
+

© Copyright Community.Routeros Contributors.

+
+ + + + +
+
+
+
+
+ + + + \ No newline at end of file