Describe 'UI Network Selection' in the docs
This patch adds a description of a 'network' dynamic ui field into the 'Dynamic UI definition specification' section of murano docs. It also reflects the recent increment of Murano Dynamic UI platform version to 2.1. It also adds a new article to 'Use Cases' section. It is called 'Configuring Network Access for VMs' and describes how the application developers may utilize the new feature in their application packages. Targets blueprint ui-network-selection Change-Id: Id8dad235084e022737c79dfe8612ba440be031e1
This commit is contained in:
parent
3d4048dd50
commit
baef6a19e0
@ -39,7 +39,7 @@ For example, Murano Dynamic UI platform of version 2.2 is able to process UI
|
|||||||
definitions of versions 2.0, 2.1 and 2.2, but is unable to process 2.3, 3.0 or
|
definitions of versions 2.0, 2.1 and 2.2, but is unable to process 2.3, 3.0 or
|
||||||
1.9.
|
1.9.
|
||||||
|
|
||||||
Currently the latest version of Dynamic UI platform is 2.0. It is incompatible
|
Currently the latest version of Dynamic UI platform is 2.1. It is incompatible
|
||||||
with UI definitions of Version 1, which were used in Murano releases before
|
with UI definitions of Version 1, which were used in Murano releases before
|
||||||
Juno.
|
Juno.
|
||||||
|
|
||||||
@ -69,7 +69,7 @@ used. Two yaql functions are used for object model generation:
|
|||||||
* **generateHostname** is used for machine hostname generation; it accepts 2 arguments: name pattern (string) and index (integer). If '#' symbol is present in name pattern, it will be replaced with the index provided. If pattern is not given, a random name will be generated.
|
* **generateHostname** is used for machine hostname generation; it accepts 2 arguments: name pattern (string) and index (integer). If '#' symbol is present in name pattern, it will be replaced with the index provided. If pattern is not given, a random name will be generated.
|
||||||
* **repeat** is used to produce a list of data snippets, given the template snippet (first argument) and number of times it should be reproduced (second argument). Inside that template snippet current step can be referenced as *$index*.
|
* **repeat** is used to produce a list of data snippets, given the template snippet (first argument) and number of times it should be reproduced (second argument). Inside that template snippet current step can be referenced as *$index*.
|
||||||
|
|
||||||
.. note:
|
.. note::
|
||||||
Note, that while evaluating YAQL expressions referenced from
|
Note, that while evaluating YAQL expressions referenced from
|
||||||
**Application** section (as well as almost all attributes inside
|
**Application** section (as well as almost all attributes inside
|
||||||
**Forms** section, see later) *$* root object is set to the list of
|
**Forms** section, see later) *$* root object is set to the list of
|
||||||
@ -144,6 +144,8 @@ Currently supported options for **type** attribute are:
|
|||||||
* flavor - specific field, used for selection instance flavor from a list
|
* flavor - specific field, used for selection instance flavor from a list
|
||||||
* keypair - specific field, used for selecting a keypair from a list
|
* keypair - specific field, used for selecting a keypair from a list
|
||||||
* azone - specific field, used for selecting instance availability zone from a list
|
* azone - specific field, used for selecting instance availability zone from a list
|
||||||
|
* network - specific field, used to select a network and subnet from a list of
|
||||||
|
the ones available to the current user
|
||||||
* any other value is considered to be a fully qualified name for some Application package and is rendered as a pair of controls: one for selecting already existing Applications of that type in an Environment, second - for creating a new Application of that type and selecting it
|
* any other value is considered to be a fully qualified name for some Application package and is rendered as a pair of controls: one for selecting already existing Applications of that type in an Environment, second - for creating a new Application of that type and selecting it
|
||||||
|
|
||||||
Other arguments (and whether they are required or not) depends on a
|
Other arguments (and whether they are required or not) depends on a
|
||||||
@ -177,6 +179,41 @@ attributes are the following:
|
|||||||
min_vcpus: 2
|
min_vcpus: 2
|
||||||
min_memory_mb: 2048
|
min_memory_mb: 2048
|
||||||
|
|
||||||
|
* **include_subnets** is used only with network field. `True` by default.
|
||||||
|
If `True`, the field list includes all the possible combinations of network
|
||||||
|
and subnet. E.g. if there are two available networks X and Y, and X has two
|
||||||
|
subnets A and B, while Y has a single subnet C, then the list will include 3
|
||||||
|
items: (X, A), (X, B), (Y, C). If set to `False` only network names will be
|
||||||
|
listed, without their subnets.
|
||||||
|
|
||||||
|
* **filter** is used only with network field. `None` by default. If set to a
|
||||||
|
regexp string, will be used to display only the networks with names matching
|
||||||
|
the given regexp.
|
||||||
|
|
||||||
|
* **murano_networks** is used only with network field. `None` by default. May
|
||||||
|
have values `None`, `exclude` or `translate`. Defines the handling of
|
||||||
|
networks which are created by murano.
|
||||||
|
Such networks usually have very long randomly generated names, and thus look
|
||||||
|
ugly when displayed in the list. If this value is set to `exclude` then these
|
||||||
|
networks are not shown in the list at all. If set to `translate` the
|
||||||
|
names of such networks are replaced by a string `Network of %env_name%`.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
This functionality is based on the simple string matching of the
|
||||||
|
network name prefix and the names of all the accessible murano
|
||||||
|
environments. If the environment is renamed after the initial deployment
|
||||||
|
this feature will not be able to properly translate or exclude its network
|
||||||
|
name.
|
||||||
|
|
||||||
|
* **allow_auto** is used only with network field. `True` by default. Defines if
|
||||||
|
the default value of the dropdown (labeled "Auto") should be present in the
|
||||||
|
list. The default value is a tuple consisting of two `None` values. The logic
|
||||||
|
on how to treat this value is up to application developer. It is suggested to
|
||||||
|
use this field to indicate that the instance should join default environment
|
||||||
|
network. For use-cases where such behavior is not desired, this parameter
|
||||||
|
should be set to `False`.
|
||||||
|
|
||||||
|
|
||||||
Besides field-level validators, form-level validators also exist. They
|
Besides field-level validators, form-level validators also exist. They
|
||||||
use **standard context** for YAQL evaluation and are required when
|
use **standard context** for YAQL evaluation and are required when
|
||||||
there is a need to validate some form's constraint across several
|
there is a need to validate some form's constraint across several
|
||||||
|
@ -155,4 +155,85 @@ So, you need to specify the maximum instance number in the UI form related to th
|
|||||||
After the deployment, the LB virtual IP, by which an application is accessible,
|
After the deployment, the LB virtual IP, by which an application is accessible,
|
||||||
is displayed.
|
is displayed.
|
||||||
|
|
||||||
|
Configuring Network Access for VMs
|
||||||
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
By default, each VM instance deployed by ``io.murano.resources.Instance`` class
|
||||||
|
or its descendants joins an environment's default network. This network gets
|
||||||
|
created when the Environment is deployed for the first time, a subnet is
|
||||||
|
created in it and is uplinked to a router which is detected automatically based
|
||||||
|
on its name.
|
||||||
|
|
||||||
|
This behavior may be overridden in two different ways.
|
||||||
|
|
||||||
|
Using existing network as environment's default
|
||||||
|
-----------------------------------------------
|
||||||
|
|
||||||
|
This option is available for users when they create a new environment in the
|
||||||
|
Dashboard. A dropdown control is displayed next to the input field prompting
|
||||||
|
for the name of environment. By default this control provides to create a new
|
||||||
|
network, but the user may opt to choose some already existing network to be the
|
||||||
|
default for the environment being created. If the network has more than one
|
||||||
|
subnet, the list will include all the available options with their CIDRs
|
||||||
|
shown. The selected network will be used as environment's default, so no new
|
||||||
|
network will be created.
|
||||||
|
|
||||||
|
.. note::
|
||||||
|
|
||||||
|
Murano does not check the configuration or topology of the network selected
|
||||||
|
this way. It is up to the user to ensure that the network is uplinked to some
|
||||||
|
external network via a router - otherwise the murano engine will not be able
|
||||||
|
to communicate with the agents on the deployed VMs. If the Applications being
|
||||||
|
deployed require internet connectivity it is up to the user to ensure that
|
||||||
|
this net provides it, than DNS nameservers are set and accessible etc.
|
||||||
|
|
||||||
|
|
||||||
|
Modifying the App UI to prompt user for network
|
||||||
|
-----------------------------------------------
|
||||||
|
|
||||||
|
The application package may be designed to ask user about the network they want
|
||||||
|
to use for the VMs deployed by this particular application. This allows to
|
||||||
|
override the default environment's network setting regardless of its value.
|
||||||
|
|
||||||
|
To do this, application developer has to include a ``network`` field into the
|
||||||
|
Dynamic UI definition of the app. The value returned by this field is a tuple
|
||||||
|
of network_id and a subnet_id. This values may be passed as the
|
||||||
|
input properties for ``io.murano.resources.ExistingNeutronNetwork`` object
|
||||||
|
which may be in its turn passed to an instance of
|
||||||
|
``io.murano.resources.Instance`` as its network configuration.
|
||||||
|
|
||||||
|
The UI definition may look like this:
|
||||||
|
|
||||||
|
.. code-block:: yaml
|
||||||
|
|
||||||
|
Templates:
|
||||||
|
customJoinNet:
|
||||||
|
- ?:
|
||||||
|
type: io.murano.resources.ExistingNeutronNetwork
|
||||||
|
internalNetworkName: $.instanceConfiguration.network[0]
|
||||||
|
internalSubnetworkName: $.instanceConfiguration.network[1]
|
||||||
|
Application:
|
||||||
|
?:
|
||||||
|
type: com.example.someApplicationName
|
||||||
|
instance:
|
||||||
|
?:
|
||||||
|
type: io.murano.resources.LinuxMuranoInstance
|
||||||
|
networks:
|
||||||
|
useEnvironmentNetwork: $.instanceConfiguration.network[0]=null
|
||||||
|
useFlatNetwork: false
|
||||||
|
customNetworks: switch($.instanceConfiguration.network[0], $=null=>list(), $!=null=>$customJoinNet)
|
||||||
|
Forms:
|
||||||
|
- instanceConfiguration:
|
||||||
|
fields:
|
||||||
|
- name: network
|
||||||
|
type: network
|
||||||
|
label: Network
|
||||||
|
description: Select a network to join. 'Auto' corresponds to a default environment's network.
|
||||||
|
required: false
|
||||||
|
murano_networks: translate
|
||||||
|
|
||||||
|
For more details on the Dynamic UI its controls and templates please refer to
|
||||||
|
its :ref:`specification <DynamicUISpec>`.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user