guides:reference:templates:relations
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
guides:reference:templates:relations [2019/12/23 14:27] – external edit 127.0.0.1 | guides:reference:templates:relations [2024/07/03 12:31] (current) – external edit 127.0.0.1 | ||
---|---|---|---|
Line 1: | Line 1: | ||
+ | {{indexmenu_n> | ||
+ | |||
+ | ====== Relations and Contexts ====== | ||
+ | ===== Contexts ===== | ||
+ | ==== Default Context ==== | ||
+ | When generating the configuration for a networking device, a large number of parameters are retrieved from the NetYCE database that are related to that node. These parameters are used in the Templates that make up the configuration and are substituted during generation. For each node type, the set of available parameters may vary. This set of parameters and their values we call the **Context** of the node. | ||
+ | |||
+ | The **Default Context** is the standard context of the node for which the configuration is generated. | ||
+ | ==== Named Context ==== | ||
+ | Additional parameter sets reflecting specific relations in the network design can be defined by the user with // | ||
+ | |||
+ | A //Named Context// is the name by which the SQL query is being stored and is also the name of the context. A named context is then being accessed as a temporary table that, in combination with a parameter name results in one or multiple values. | ||
+ | |||
+ | The various named contexts become an extension of the default context from which the parameter values can be accessed via the name of the context. A named context is defined only once as a ‘// | ||
+ | |||
+ | A configured named context or ‘relation’ is available for all templates, sub templates and automations. There are no restrictions with regards to the number of named contexts that can be configured or that are used in a template. | ||
+ | |||
+ | ==== Current Context ==== | ||
+ | The //Current Context// is always the Default Context of the node, but can be changed (temporary) under the influence of the Template-directives to a //Named Context//. | ||
+ | |||
+ | Parameters in the current context are expressed in the following form: ''< | ||
+ | |||
+ | In case that all values of ''< | ||
+ | |||
+ | The default context is in fact also a named context with the name of the node. For this reason the creation of a named context with the name of the node is not recommended. The results will be confusing. | ||
+ | |||
+ | |||
+ | ==== Context Directives ==== | ||
+ | Context directives (or pointers) are used in the template text and can influence the context behavior while generating a configuration. | ||
+ | |||
+ | === Load or reload a context === | ||
+ | ''# | ||
+ | This forces the loading of a //Named Context//. Normally a named context is retrieved from the database at the moment of its first reference. The ''# | ||
+ | |||
+ | //The context information is loaded in addition// | ||
+ | |||
+ | ''# | ||
+ | The ''# | ||
+ | |||
+ | //The context information is clean (previous information is cleared)// | ||
+ | |||
+ | The ''# | ||
+ | |||
+ | === Use a named context === | ||
+ | ''# | ||
+ | ''# | ||
+ | The ''# | ||
+ | |||
+ | The use of these will be very sporadic since sub-templates with variable contexts are normally invoked via the '' | ||
+ | |||
+ | Without argument, the ''# | ||
+ | |||
+ | === Wait directive === | ||
+ | ''# | ||
+ | A wait directive also exists to allow for additional waiting between commands. This is explained in more detail at [[menu: | ||
+ | ==== Remarks ==== | ||
+ | Context names, parameters and directives are not case sensitive.\\ | ||
+ | |||
+ | De directives like ''# | ||
+ | |||
+ | ==== Named Context definition ==== | ||
+ | A named context is being stored under the ‘Relations’ form of the YCE client front-end as an SQL query. This form is accessible via the Relations form: | ||
+ | |||
+ | {{: | ||
+ | |||
+ | Named contexts will most always contain a '' | ||
+ | |||
+ | ==== Transformed Context ==== | ||
+ | When creating a named context (relation) the SQL definition of the relation can be modified to automatically create additional columns based on the values found in the SQL results. | ||
+ | |||
+ | This extension of columns is the result of transforming a field value from a selected column to a column name. The value(s) in that column then points to another selected value from the record. In that way, a result table in which every line describes a parameter, can be changed to a table in which this parameter-name becomes a field-name. That field name then receives one of the field values that belong to that parameter. | ||
+ | |||
+ | To extend the existing context to a Transformed context, a ‘Transform’ line is being added, preceding the context SQL query. This Transform line has the syntax: | ||
+ | |||
+ | '' | ||
+ | |||
+ | This transform-line is directly followed by the '' | ||
+ | |||
+ | A transformed context makes it easier to use parameter names directly in a template. | ||
+ | Example: The reference to ''< | ||
+ | will return the parameter (colum name) '' | ||
+ | |||
+ | Should a Transform be applied (using '' | ||
+ | ''< | ||
+ | |||
+ | The transformed '' | ||
+ | |||
+ | As the context is only extended with a number of new columns, both reference forms remain available (and can also be combined) | ||
+ | |||
+ | It is not possible to transform more than one parameter. | ||
+ | |||
+ | ==== Relation Test ==== | ||
+ | As of version 5.0, it is possible to develop a relation more interactive. The web-tool ‘Relation Test’ allows the developer to evaluate the outcome of a query for a specific node. The transform syntax is here being supported. It can be found in the Build -> Relations menu section. | ||
+ | |||
+ | The Relation Test starts with selecting a node to examine the context results for a relation. By selecting various nodes the results for a relation for each of these nodes can quickly be examined. | ||
+ | |||
+ | {{: | ||
+ | |||
+ | The relations can be retrieved with the drop down ‘Relations’. After activation with the ‘View Context’ button is the SQL query being shown. Also is the query being processed for the selected node and shown as a table. | ||
+ | |||
+ | {{: | ||
+ | |||
+ | Changes to the query can be added by editing the ‘Context Query’ field. By applying the ‘Evaluation’ button, this is being executed. In this way a context-query (or relation) can be changed iterative. | ||
+ | |||
+ | It’s not possible to save a changed query directly. To do this, the final query needs to be pasted back in the Relations form of the YCE client. | ||
+ | ===== Parameters ===== | ||
+ | ==== Current Context ==== | ||
+ | Parameter substitution for the Current Context has two different forms | ||
+ | |||
+ | ''< | ||
+ | This substitutes the value ''< | ||
+ | |||
+ | ''< | ||
+ | This generates a configuration line for all values (also non-unique) for the parameter from the Current Context. See also description of ''< | ||
+ | |||
+ | A reference to ''< | ||
+ | |||
+ | |||
+ | ==== Named Context ==== | ||
+ | The substitution of named contexts is different than for normal parameters.\\ | ||
+ | |||
+ | A query of a named context often results in multiple records. Mostly, the relation between nodes consists of multiple elements such as switches or routers on different locations, ports of a switch, SLA measurements QoS parameters etc. In these cases a configuration line is preferred for all possible values of the parameter in this context. | ||
+ | |||
+ | |||
+ | '' | ||
+ | This substitutes the value of ' | ||
+ | A template line where multiple parameters from the same context are used, results in configuration lines applying one record every time of the named context so the underlying relation is maintained. | ||
+ | |||
+ | |||
+ | Example: | ||
+ | |||
+ | Named Context: routers | ||
+ | < | ||
+ | Hostname Lan_address Lan_mask | ||
+ | switch1 100.216.80.23 255.255.254.0 | ||
+ | switch2 100.21.100.134 255.255.254.0 | ||
+ | switch3 100.21.120.3 255.255.254.0 | ||
+ | </ | ||
+ | The template line: | ||
+ | < | ||
+ | Remark < | ||
+ | </ | ||
+ | Results in: | ||
+ | < | ||
+ | Remark switch1 on adres 100.216.80.23 | ||
+ | Remark switch2 on adres 100.21.100.134 | ||
+ | Remark switch3 on adres 100.21.120.3 | ||
+ | </ | ||
+ | |||
+ | If multiple named contexts are used in one template line, then configuration lines are generated for //**all permutations**// | ||
+ | |||
+ | |||
+ | **''< | ||
+ | The named context parameter with a ‘key-value’ uses a given value (the ' | ||
+ | |||
+ | **''< | ||
+ | **''< | ||
+ | The wildcard characters '' | ||
+ | |||
+ | Combining a key-value parameter and a normal parameter from the same context will result in the same behaviour as if the contexts were different: different configuration lines are generated for all permutations in both named contexts. | ||
+ | |||
+ | **''< | ||
+ | **''< | ||
+ | This format allows you to specify which of the parameters in the relation must match the key-value. Instead of trying to find the key-value in any of its columns, only the named one is tried. | ||
+ | As with the other context based substitutions, | ||
+ | |||
+ | < | ||
+ | # safe to use without permutations: | ||
+ | |||
+ | vlan-name: < | ||
+ | |||
+ | vlan-name: < | ||
+ | |||
+ | vlan-name: < | ||
+ | |||
+ | </ | ||
+ | |||
+ | |||
+ | ==== Indirect ==== | ||
+ | Parameters can also be substituted indirectly. This option is useful in case a reference in the form of a node name or template name is needed. | ||
+ | |||
+ | For normal substitution, | ||
+ | |||
+ | Indirect substitution is also supported for context parameters. Meaning that the referenced parameter points to a named context (''< | ||
+ | |||
+ | The implementation however is not fully recursive. Only the first and second references can name a context, any subsequent indirect references must name regular parameters. | ||
+ | |||
+ | |||
+ | ==== Template line ==== | ||
+ | In all above mentioned paragraphs mentioned template line it is also possible to use next to direct commando’s the following: | ||
+ | < | ||
+ | {sub-template} | ||
+ | {template_ref, | ||
+ | {template_ref, | ||
+ | {template_ref, | ||
+ | </ | ||
+ | |||
+ | Multiple conditionals can be added, which will make a logical ' | ||
+ | |||
+ | Commands with substitution of: | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | < | ||
+ | [Eval(..)] | ||
+ | [IpAdd(..)] | ||
+ | [InvMask(..)] | ||
+ | </ | ||
+ | |||
+ | In case of context references (parameters with a '' | ||
+ | |||
+ | ==== Line concatenation ==== | ||
+ | For situations where a context results in multiple lines, it is sometimes possible that this is executed as a block instead of line by line. The can easily be realized using the concatenation sign '' | ||
+ | |||
+ | An example of a list of vlan interfaces with some details: | ||
+ | < | ||
+ | |< | ||
+ | | ||
+ | | ||
+ | ! | ||
+ | </ | ||
+ | |||
+ | This results in a useless configuration. Also the condition is limited to the first line so it should be repeated for every line. | ||
+ | |||
+ | < | ||
+ | interface vlan 100 | ||
+ | interface vlan 150 | ||
+ | interface vlan 200 | ||
+ | description Inrol vlan | ||
+ | description OSPF_Vlan vlan | ||
+ | description Servers_bk vlan | ||
+ | description Native vlan | ||
+ | network address 10.106.63.204 | ||
+ | network address 10.106.63.140 | ||
+ | network address 10.106.47.32 | ||
+ | network address | ||
+ | ! | ||
+ | </ | ||
+ | |||
+ | By using concatenation, | ||
+ | |||
+ | < | ||
+ | |< | ||
+ | description < | ||
+ | network address < | ||
+ | ! | ||
+ | </ | ||
+ | |||
+ | Results in the desired list: | ||
+ | |||
+ | < | ||
+ | interface vlan 100 | ||
+ | description Inrol vlan | ||
+ | network address | ||
+ | ! | ||
+ | interface vlan 150 | ||
+ | description OSPF_Vlan vlan | ||
+ | network address | ||
+ | ! | ||
+ | interface vlan 200 | ||
+ | description Servers_bk vlan | ||
+ | network address | ||
+ | ! | ||
+ | </ | ||
+ | |||
+ | |||
+ | ===== Sub-Templates ===== | ||
+ | Sub-templates can be invoked from within the main template. This can be done iterative by nesting sub-templates. Also conditional use is possible. | ||
+ | |||
+ | ==== Template substitution ==== | ||
+ | < | ||
+ | {sub-template} | ||
+ | |< | ||
+ | {< | ||
+ | </ | ||
+ | |||
+ | Sub-templates are invoked and substituted by its name. The texts of the sub-template is being evaluated line by line, like the main-template and included in the configuration. A sub-template always uses the Current context. | ||
+ | |||
+ | Also a template can be invoked indirectly by using a parameter name in which the name of the sub-template is mentioned. Template names are not case sensitive. The template names or its reference may involve all template sorts: main, sub, automation, port. | ||
+ | |||
+ | ==== Context-templates ==== | ||
+ | In situations where sub-templates must be used several times, and by which each time a different set of values must be used, Context-template forms can be used. | ||
+ | |||
+ | < | ||
+ | |||
+ | {template, context} | ||
+ | {< | ||
+ | |||
+ | </ | ||
+ | |||
+ | Here the template '' | ||
+ | |||
+ | As an example it is easy to generate all Vlan interfaces with its own ip-addresses with e.g. '' | ||
+ | |||
+ | The ''< | ||
+ | |||
+ | This is useful if the template name is mentioned in its context. | ||
+ | Example: | ||
+ | |||
+ | < | ||
+ | |||
+ | {< | ||
+ | |||
+ | </ | ||
+ | |||
+ | This results in the execution of all defined Sla_monitors whereby the Sla_template parameter contains the template name of the context. | ||
+ | |||
+ | < | ||
+ | |||
+ | {< | ||
+ | |||
+ | </ | ||
+ | |||
+ | This is the most complex use of sub-templates being supported. Here a condition is used for the context for which (indirectly) a template is being called upon. This is useful to generate the configuration of a specific port or set of ports. | ||
+ | |||
+ | < | ||
+ | |||
+ | {< | ||
+ | |||
+ | </ | ||
+ | |||
+ | This conditional use of context templates allow for conditions of the type '' | ||
+ | |||
+ | < | ||
+ | |||
+ | # include all GigabitEthernet interface variants (GB, 10G, 40G, 100G) | ||
+ | |||
+ | { < | ||
+ | |||
+ | # do loopbacks only | ||
+ | |||
+ | { < | ||
+ | |||
+ | # exclude ten-gigabit interfaces | ||
+ | |||
+ | { < | ||
+ | |||
+ | # Filter on dhcp_type and Net_address | ||
+ | |||
+ | {DHCP_pool, ipv4_customs_node, | ||
+ | </ | ||
+ | |||
+ | |||
+ | |||
+ | ===== Configuration Generator ===== | ||
+ | |||
+ | ==== Version 2.0 ==== | ||
+ | The templates are being transformed into a specific vendor configuration or commands by the configuration generator. The generator is a Perl script that accepts the syntaxes as described in this document. | ||
+ | Syntax from version 1.0 that are no longer supported, will be automatically converted to version 2.0 before send to the generator, but the templates itself are unchanged. Certain specials were not possible to convert and need to be changed in the template. | ||
+ | |||
+ | ==== Command line ==== | ||
+ | De generator can be found on the YCE servers in the directory ''/ | ||
+ | |||
+ | YCE configuration generator version 5. | ||
+ | Creates template-based full node configurations or command sets. | ||
+ | |||
+ | Usage: c2.pl | ||
+ | < | ||
+ | -n, --node nodename | ||
+ | Mandatory argument. | ||
+ | Nodename must exist in YCE database | ||
+ | Any orphaned argument is taken as nodename | ||
+ | -t, --template template[, | ||
+ | Defaults to node main template | ||
+ | Multiple templates are appended in sequence | ||
+ | Template ' | ||
+ | -j, --jobid jobID | ||
+ | Optional job directory in / | ||
+ | When provided, the log is created here, | ||
+ | otherwise logs to / | ||
+ | -v, --verbose [level 0..3] | ||
+ | -h, --help | ||
+ | |||
+ | Output files: | ||
+ | with jobID - in directory / | ||
+ | | ||
+ | with template - filename is < | ||
+ | | ||
+ | |||
+ | Examples: | ||
+ | Full node configuration in / | ||
+ | | ||
+ | |||
+ | | ||
+ | | ||
+ | |||
+ | | ||
+ | -j 0719_005 -n M1005011 -t cn_dialer_del, | ||
+ | |||
+ | | ||
+ | echo ' | ||
+ | </ | ||