summaryrefslogtreecommitdiff
path: root/docs/contributing
diff options
context:
space:
mode:
authorJohn Estabrook <jestabro@vyos.io>2024-12-11 14:33:20 -0600
committerJohn Estabrook <jestabro@vyos.io>2024-12-11 15:30:53 -0600
commitd69a7c651c937d195c1d091551a42f701b3b97c2 (patch)
tree5876696c9b23ea06b854db79512c69ff9a4730ca /docs/contributing
parent8128e0cd57dcbcadf3963d30e9bbefc8ae507e5a (diff)
downloadvyos-documentation-d69a7c651c937d195c1d091551a42f701b3b97c2.tar.gz
vyos-documentation-d69a7c651c937d195c1d091551a42f701b3b97c2.zip
Fix typos and add constraints on conf-mode scripts under configd
Diffstat (limited to 'docs/contributing')
-rw-r--r--docs/contributing/development.rst21
1 files changed, 19 insertions, 2 deletions
diff --git a/docs/contributing/development.rst b/docs/contributing/development.rst
index e39af3a5..c5df8b12 100644
--- a/docs/contributing/development.rst
+++ b/docs/contributing/development.rst
@@ -290,7 +290,7 @@ device if you happen to be a crazy scientist.
from vyos.config import Config
from vyos import ConfigError
- def get_config():
+ def get_config(config=None):
if config:
conf = config
else:
@@ -306,7 +306,6 @@ device if you happen to be a crazy scientist.
# Verify that configuration is valid
if invalid:
raise ConfigError("Descriptive message")
- return True
def generate(config):
# Generate daemon configs
@@ -385,6 +384,24 @@ For easy orientation we suggest you take a look on the ``ntp.py`` or
``interfaces-bonding.py`` (for tag nodes) implementation. Both files can be
found in the vyos-1x_ repository.
+Other considerations: vyos-configd
+----------------------------------
+
+All scripts now run under the config daemon and must conform to the
+following:
+
+1. The signature and initial four lines of ``get_config(...)`` `must` be as
+ above.
+
+2. Each of ``get_config``, ``verify``, ``apply``, ``generate`` `must`
+ appear, with signatures as above, even if they are a no-op.
+
+3. Instantiations of ``Config`` other than that in ``get_config`` `must not`
+ appear.
+
+4. The legacy function ``my_set`` `must not` appear: modifications of the
+ active config `should not` appear in new code (if absolutely necessary,
+ alternative mechanisms may be used).
XML (used for CLI definitions)
==============================