Add network commissioning script
* 00-maas-05-simplify-network-interfaces that makes transformation of
NIC names 10G=> tenXX ; 1G=> oneXX
* The patch only migrates logic from docs [0] to be optional.
* Misc: don't call processing of fabrics\dev\netw\etc modules, if they
are not defined.
EME-70
[0] `https://docs.mirantis.com/mcp/master/mcp-deployment-guide/deploy-mcp-drivetrain/install-base-infra/deploy-physical-nodes/deploy-automatically/commission-nodes-automatically.html`
Change-Id: Ie1d384bc887a9ddcc8f8f5b268de12d1ccb9c83e
diff --git a/README.rst b/README.rst
index d09b6fd..2fd06cb 100644
--- a/README.rst
+++ b/README.rst
@@ -128,7 +128,7 @@
subnet: cidr:192.168.10.0/24
mac: '66:55:44:33:22:11'
commissioning_scripts:
- 00-maas-06-create-raid.sh: /srv/salt/reclass/scripts/commisioning_script.sh
+ 00-maas-05-simplify-network-interfaces: /etc/maas/files/commisioning_scripts/00-maas-05-simplify-network-interfaces
maas_config:
domain: mydomain.local
http_proxy: http://192.168.0.10:3142
diff --git a/maas/files/commisioning_scripts/00-maas-05-simplify-network-interfaces b/maas/files/commisioning_scripts/00-maas-05-simplify-network-interfaces
new file mode 100755
index 0000000..b4cc872
--- /dev/null
+++ b/maas/files/commisioning_scripts/00-maas-05-simplify-network-interfaces
@@ -0,0 +1,47 @@
+#!/bin/bash
+
+# Those script exchange default maas commissioning logic:
+# and report interface names in different way.
+# Initial logic stored in:
+# /usr/lib/python3/dist-packages/provisioningserver/refresh/node_info_scripts.py
+# IPADDR_SCRIPT variable.
+
+function process_ipaddr(){
+i=1
+j=1
+
+ethernets=$(ip -o l | grep -E '^[0-9]+:\ .*link/ether.*' | awk -F":" '/,/{gsub(/ /, "", $0); print $2}' | grep -Ev "br|bond")
+
+declare -A interfaces
+for iface in ${ethernets[@]}; do
+ speed=`ethtool $iface | grep '40000'`
+ if [[ "$?" == 0 ]]; then
+ interfaces[$iface]="fourty$i"
+ ((i++))
+ else
+ speed=`ethtool $iface | grep '10000' `
+ if [[ "$?" == 0 ]]; then
+ interfaces[$iface]="ten$i"
+ ((i++))
+ else
+ interfaces[$iface]="one$j"
+ ((j++))
+ fi
+ fi
+done
+
+for i in ${!interfaces[@]}; do
+ sedline+="-e s/${i}/${interfaces[$i]}/ "
+done
+
+ip addr | sed ${sedline}
+}
+
+if [[ "$(basename $0)" != "99-maas-03-network-interfaces" ]]; then
+ SCRIPTPATH="$( cd "$(dirname "$0")" ; pwd -P )"
+ echo "Apply 00-maas-05-simplify-network-interfaces modificathion:"
+ cp -v $0 ${SCRIPTPATH}/99-maas-03-network-interfaces
+ chmod 0755 ${SCRIPTPATH}/99-maas-03-network-interfaces
+else
+ process_ipaddr
+fi
diff --git a/maas/region.sls b/maas/region.sls
index 3b88307..90d6657 100644
--- a/maas/region.sls
+++ b/maas/region.sls
@@ -119,49 +119,81 @@
- require:
- cmd: maas_login_admin
+{%- if region.get('commissioning_scripts', False) %}
+/etc/maas/files/commisioning_scripts/:
+ file.directory:
+ - user: root
+ - group: root
+ - mode: 755
+ - makedirs: true
+ - require:
+ - pkg: maas_region_packages
+
+/etc/maas/files/commisioning_scripts/00-maas-05-simplify-network-interfaces:
+ file.managed:
+ - source: salt://maas/files/commisioning_scripts/00-maas-05-simplify-network-interfaces
+ - mode: 755
+ - user: root
+ - group: root
+ - require:
+ - file: /etc/maas/files/commisioning_scripts/
+
maas_commissioning_scripts:
module.run:
- name: maas.process_commissioning_scripts
- require:
- module: maas_config
+{%- endif %}
+{%- if region.get('fabrics', False) %}
maas_fabrics:
module.run:
- name: maas.process_fabrics
- require:
- module: maas_config
+{%- endif %}
+{%- if region.get('subnets', False) %}
maas_subnets:
module.run:
- name: maas.process_subnets
- require:
- module: maas_config
- module: maas_fabrics
+{%- endif %}
+{%- if region.get('devices', False) %}
maas_devices:
module.run:
- name: maas.process_devices
- require:
- module: maas_config
- module: maas_subnets
+{%- endif %}
+{%- if region.get('dhcp_snippets', False) %}
maas_dhcp_snippets:
module.run:
- name: maas.process_dhcp_snippets
- require:
- module: maas_config
+{%- endif %}
+{%- if region.get('package_repositories', False) %}
maas_package_repositories:
module.run:
- name: maas.process_package_repositories
- require:
- module: maas_config
+{%- endif %}
+{%- if region.get('boot_resources', False) %}
maas_boot_resources:
module.run:
- name: maas.process_boot_resources
- require:
- module: maas_config
+{%- endif %}
maas_domain:
module.run:
@@ -169,10 +201,12 @@
- require:
- module: maas_config
+{%- if region.get('sshprefs', False) %}
maas_sshprefs:
module.run:
- name: maas.process_sshprefs
- require:
- module: maas_config
+{%- endif %}
{%- endif %}