65 Commits

Author SHA1 Message Date
Zuul
993934e959 Merge "Use a python shim for running for auth_ed25519 helper" 2020-04-18 04:48:15 +00:00
Damien Ciabrini
1479a0ea32 Use a python shim for running for auth_ed25519 helper
When mysql ed25519 authentication is enabled, puppet-tripleo
uses a python helper to generate password hashes. Python
helpers have their +x permission stripped on install time,
so run the helper via the right python interpreter instead.

Change-Id: I13b02af166d7767799be99a0fb52066b00637a01
Related-Bug: #1866093
2020-04-14 15:48:08 +02:00
Takashi Kajinami
474d20438a Remove OpenDaylight support
... because OpenDaylight tempmates and environemtns were alredy removed
in tripleo-heat-teampltes[1].

[1] 9c3638b8a13ea08a1bab95c9cd6ab335b729b6b3

Change-Id: I0204b6985de71441e0f63f21cfda24d55fd340e5
2020-04-14 22:42:44 +09:00
Damien Ciabrini
00a06edc5c Support for mariadb's ed25519 authentication
Add the ability to configure all mysql users to require authenticating
to the server via mariadb's ed25519 auth plugin [1], rather than the
default native authentication [2].

[1] https://mariadb.com/kb/en/authentication-plugin-ed25519/
[2] https://mariadb.com/kb/en/authentication-plugin-mysql_native_password/

Change-Id: I430ea8e1fa15fb263d1d4ef8c39615021d907f8a
Partial-Bug: #1866093
2020-03-25 17:45:43 +01:00
Luca Miccini
3991edcae0 Explicitly convert stonith_level fact to int
Apparently the implicit conversion done via '0 + string' is not robust
enough. Adding a "to_i" to make sure we don't break if output is empty.

Change-Id: I1e31761fd2129f57f61707d1920db835df7f7346
2019-11-27 16:51:02 +01:00
Luca Miccini
57ef37990a Check for crm_node presence before collecting fact
This commit adds a check to make sure 'crm_node' is present on the
system (or inside a container, fwiw) before attempting to collect
the stonith level info, so preventing errors like:

~~~
Error: Facter: error while resolving custom fact
\"stonith_levels\": execution of command \"crm_node -n 2> /dev/null\"
failed: command not found."
~~~

Change-Id: I4b4304b54a8aec76fad50b503a007b2bfcc41bd1
2019-11-22 16:47:19 +01:00
Luca Miccini
7c30bd791f Improve stonith leves idempotency.
This commit improves the way stonith levels are set up and their
resiliency against redeployments by introducing a stonith_levels
custom fact that collects the current stonith levels defined for
the specific server, so we can compare against the desired number
of levels defined in hiera.

If these do not match (for example if there are additional levels
that are no longer necessary), the clean up step also introduced
by this commit takes care of deleting the ones no longer necessary.

Change-Id: Ifae73ac2bf4481d0a11e89c0ea0916e85dd2db1d
2019-11-12 13:03:18 +01:00
yogananth subramanian
f5daa76982 Fix upper case checks for SRIOV interface
Allow using upper case names for SRIOV interface names.

Fixes bug 1848483

Change-Id: I2d2cb42d87371f5807a4527eef22425416d4a774
2019-10-17 23:14:44 +05:30
Bogdan Dobrelya
59ecc8820e Add noop service provider and use it for httpd
Add noop service provider that we use when configuring Apache in
containers. Supresses actions performed on the httpd service.

Change-Id: Ibed34a9eeecc9d8ab310816e05652bdd5962f772
Signed-off-by: Bogdan Dobrelya <bdobreli@redhat.com>
2019-08-13 14:56:17 +02:00
waleed mousa
cd31dd2da9 Adding a udev rule to save sriov interface name before configuring switchdev
After moving mlnx interfaces to switchdev mode in sriov, it will
reset that interface and may change its name and also will need ifup
in order to get back the previous configuration.
So adding a udev rule and ifup command the save the interface name
and its configuration

Change-Id: Ib4f384da344344f9e2ec666b0d8dbae441f24568
Closes-Bug: 1816710
2019-02-20 03:27:25 -05:00
Alex Schultz
5fff984cec Fix interface_for_ip for newer facter versions
In facter 3.x, the networking facts are in a complex hash. Previously
the interface facts where flat so we would lookup the vars. This change
first tries the facter 2.x lookup before falling back to the facter 3.x
syntax.

Change-Id: I260b18ae3479da4f5176027d4b26b3e1c6b22063
Closes-Bug: #1812938
2019-01-24 08:57:19 -07:00
waleed mousa
bcf06e0b4b Configure switchedv while there is no vfs bounded
When configuring vf-lag, it will not work properly when configuring switchdev
capability while there are some vfs bounded.
So removing all the binding codes as it's not needed anymore.

Closes-Bug: 1809733
Change-Id: I135cef33bece6fd31363e093e53617caac413ce0
2019-01-08 07:08:09 +00:00
Alex Schultz
4a576293c1 Update parser functions to 4.x api
This change updates additional parser functions we have to use teh
puppet 4.x function api.  This includes some basic unit tests to ensure
they continue to function as expected.

Change-Id: Iebeb82b2890216bed139219441718fffc4004391
Related-Bug: #1799786
2018-10-29 14:26:54 +00:00
Alex Schultz
8d889af7d4 Update functions to fix unit tests
With the release of 5.5.7, some of the legacy function definitions no
longer pass in unit tests. This change updates the functions that are
failing in the tests to the modern style (4.x) for function
declarations.  Additionally we're removing teh lookup_hiera_hash
function which is failing but not actually consumed by our code base.

There will be a followup patch to migrate the rest of the parser
functions to the new format, but this patch should unblock the gates.

NOTE: git thinks some of these files have been added/deleted rather than
git move due to the large amount of changes between the two versions of
the file.

Change-Id: Ie7316fd422bd4a5eb91f94016977e5d8d76c27bc
Closes-Bug: #1799786
2018-10-29 12:16:38 +01:00
Zuul
e8a8732b30 Merge "Implements: liquidio-containerization" 2018-10-15 21:06:32 +00:00
Zuul
c5713786f6 Merge "Add support for ODL-OVS IPv6 deployment" 2018-10-12 15:56:17 +00:00
hanish gogada
c0cc54face Implements: liquidio-containerization
Modified Liquidio puppet module for containerization support.
These changes would support both baremetal and container based
deployments.

Change-Id: Ice2baafae2fb1011e16d83c83b5c85f721f6d679
2018-09-28 12:10:47 +05:30
Alex Schultz
6fb8797f79 Fix nic_alias fact error
If os-net-config is not installed, this fact causes a warning to be
generated. Let's check for os-net-config prior to trying to run it to
cleanup this error.

Change-Id: Ie55b96bbd7b60dae2342b89c24936d4d071cec10
Closes-Bug: #1794837
2018-09-27 11:04:33 -06:00
Janki Chhatbar
66292a5886 Add support for ODL-OVS IPv6 deployment
Make necessary changes for proper deployment
of ODL on IPv6 network.

Change-Id: Id7a0986f886a81b2041987b0d5a95edf2160e05e
Depends-On: Idd257cf4666b853eb4c52861f9f400b6dbdeeadb
Partial-Bug: #1783196
2018-08-24 09:30:37 +05:30
waleed mousa
cd7232bb8c Adding support for VF LAG in SR-IOV for Mellanox interfaces
It is possible to configure bond over two virtual functions
for the vms in case of using mellanox interfaces.

Change-Id: Iaeee31a9edaefec25498a734cac6eda389c38ec5
2018-08-19 05:50:05 +00:00
Tim Rozet
463d3f3a63 Remove table 17 from OVS OF pipeline sync
OpenFlow flows for table 17 now only appear after a port is created and
there is no longer a default flow during the deploy stage. Therefore
remove the check for table 17 existing during deployment.

Closes-Bug: 1781616

Change-Id: Ie988ba6a2d444a614e97c0edf5fce24b23970310
Signed-off-by: Tim Rozet <trozet@redhat.com>
2018-07-13 11:03:12 -04:00
Steve Baker
90df6c5965 Discover the gid of the docker group for mistral
The gid of the docker group is discovered by stating the gid of the
file /var/run/docker.sock. The gid of the docker group is not fixed,
so it must match the gid assigned when docker is installed on the
host. If no docker.sock exists, the custom fact will return nil.

This change also makes sure the user and group ensure_resource calls are
tagged so that docker-puppet.py can include those tags explicitly.

Blueprint: container-prepare-workflow

Change-Id: I94fa558480e408f76e69d292b1d84849ddf9a2a2
2018-06-28 13:50:58 +12:00
Tim Rozet
199ddad31b Adds check and resyncs ODL/OVS OF pipeline
Some flows may be missing in OVS (on a per table basis) when deploying
with OpenDaylight. There is no OpenDaylight fix yet for this issue, so
this patch implements a workaround. The workaround is to check if all
the tables exist on each OVS node. If they are missing, then reset the
OpenFlow connection to the ODL controller, which will result in ODL
pushing the flows again and inserting the missing flows.

Closes-Bug: 1775436

Change-Id: I28d13a26198268cfd1f3e9e64236605f24319a04
Signed-off-by: Tim Rozet <trozet@redhat.com>
2018-06-06 14:06:48 -04:00
Zuul
eacbda328a Merge "Add fact to get array of nic alias name" 2018-03-28 21:19:55 +00:00
Zenghui Shi
6dcb55fa88 Add fact to get array of nic alias name
This is useful for getting the alias name of
a real network interface name which in turn
will allow users to configure alias name in tht.

Change-Id: I28fae19f8c1c8dacad38d10513330b15bd6cdbe6
2018-03-23 21:22:15 +08:00
Zuul
7d315ab2e8 Merge "Ensure interface names are downcased" 2018-03-16 23:40:47 +00:00
Michele Baldessari
4c7ca4cbc3 Fail more gracefully when passed an empty ip
Introduce a new function called is_ip_addresses which will verify
if a string or an array of strings are composed of correct ip addresses.

We do this in order to fail a bit more clearly if we are passed an empty
or broken ip address. Without this the failure will be in pacemaker
failing to start a VIP called 'ip-'.

Also convert the only use of legacy is_ip_address stdlib function in
mysql::client to this new function (for consistency reasons).

Suggested-by: Rhys Oxenham <roxenham@redhat.com>

Change-Id: Ie15c585a9a902b577f35a75de191bfa91c132668
2018-03-13 17:08:34 +01:00
Alan Bishop
8bff507abc Avoid hard-coded settings in Cinder HA containers
Add parameters for controlling the docker container settings used to
create the cinder-volume and cinder-backup pacemaker bundles. The
parameters eliminate the need to hard-code the list of docker volumes
and environment variables, making it possible to control the values
using hiera data.

For backward compatibility, the previous hard-coded values are used
when no parameter inputs are supplied.

Partial-Bug: #1748290
Change-Id: I4ba0d78ad17183b97290b853a6c103e55bc8977c
2018-02-13 11:53:24 -05:00
waleed mousa
10237e999d hw ovs offload - On some machines representor ports not created after reboot
On some machines it's failing to run the devlink and ethtool commands
without the full path of these commands

Closes-Bug: #1745821
Change-Id: If2f7c7a46fb1b52cce9ffbfa31a3161fc07f1334
2018-01-29 11:32:24 +00:00
Dan Radez
c62bb66667 Ensure interface names are downcased
https://tickets.puppetlabs.com/browse/FACT-777
Puppet downcases fact names so they names don't become Types
Interfaces can have Uppercase letters in them.

Closes-Bug: #1745448

Change-Id: I03fd5c103f4b4d4c90770f4d8aa26ae8eeeecdcd
2018-01-25 18:11:38 +00:00
Sulaiman Radwan
279e9b75c5 Configure inline mode transport for Connectx4/LX
We need inline mode transport to be able to hw offload in the above cards.

Change-Id: I23e9db07529999450ecc56ce2687276fca57306b
2018-01-07 06:49:37 -05:00
waleed mousa
e5c563290c Add support for switchdev mode in SR-IOV
In Kernel 4.10 supports changing SR-IOV to switchdev mode.
This mode allows to create VFs represontors which can manage
the SR-IOV VFs from the hypervsior.

This patch extends the tripleo::host::sriov::number_of_vf to
<physical_network>:<number_of_vfs>:<sriov_mode>,
where sriov_mode accepts legacy or switchdev.
if sriov_mode is not specified we default to legacy.

Change-Id: I578f956f2a8c6ee29a9d1ff38ee51765bcab05c1
2017-12-12 14:58:43 +00:00
Jenkins
152d224c73 Merge "Contrail: Fix controlplane/dataplane network asignments & enable optional dpdk" 2017-07-14 23:44:24 +00:00
Michael Henkel
8b9e2b3c6c Contrail: Fix controlplane/dataplane network asignments & enable optional dpdk
This patch will move the Contrail roles communication towards
OpenStack APIs from the public/external network to the
internal_api network. I will also add the option to enable
dpdk for Contrail.

Change-Id: Ia835df656031cdf28de20f41ec6ab1c028dced23
Closes-Bug: 1698422
2017-07-05 22:52:58 +02:00
Brent Eagles
d71697a419 Do not fail if PCI device is missing
Fixes a problem where SR-IOV VF count configuration will fail if a
physical function is in use by a guest when 'puppet apply' is executed.
This change substitutes warnings for failures and skips complaints if a
PCI device is unavailable.

Note: this patch has the side-effect of allowing the same configuration
data on hosts that may *not* or *ever* have PCI SR-IOV devices on the
hardware. Time will tell how evil this is in practice.

Closes-Bug: #1701284
Change-Id: I71edc135432ab2193741c37ce977dd11172401e6
2017-06-29 11:55:14 -02:30
Dan Prince
be2a1d3c81 Drop un-needed 'else' in noop_resource
Change-Id: Id45ac93d482ff23c4c834e2d345a926fc408573f
2017-06-02 09:41:35 -04:00
Alex Schultz
2be36167fd Throw warnings for norpm actions
If the norpm provider attempts to do any install/update/remove actions,
we should throw a warning in the logs so people are aware that the
action did not actually take place.

Change-Id: Ieee5cac3412c709ba6b39316e455d7708cc9d22e
Closes-Bug: #1669666
2017-03-03 09:21:59 -07:00
Alex Schultz
bb9dba1819 Add virtual_packages support to norpm provider
The norpm provider is supposed to noop package installs/updates but if a
package name in puppet does not match the installed package, it is being
reported as not installed.  The provider then 'installs' it every time
which can trigger unwanted service restarts.

Change-Id: Icdfa6567168f9ecc555489ed67405f98544bd910
Closes-Bug: #1665405
2017-02-17 00:49:21 +00:00
Jenkins
d89ba57f59 Merge "Make sure we bind the rabbit inter-cluster to a specific interface" 2017-01-25 02:29:17 +00:00
Dan Prince
a3de7c0942 Add a noop_resource function
A function to create noop providers (set as the default) for the named
resource. This works alongside of 'puppet apply --tags' to disable
some custom resource types that still attempt to run commands during
prefetch, etc.

Change-Id: Icabdb30369c8ca15e77d169dc441bee8cfd3631f
2017-01-20 20:14:32 -05:00
Michele Baldessari
2f038b30e8 Make sure we bind the rabbit inter-cluster to a specific interface
Currently the inter-cluster communication port listens to all ip
addresses:
tcp 0 0 0.0.0.0:25672 0.0.0.0:* LISTEN 25631/beam.smp

In order to limit it to listen only to the network assigned to rabbitmq
we need to add the following:
{kernel, [
    ...
    {inet_dist_use_interface, {172,17,0,16}},
    ...
  ]}

In order to do the conversion from an ip address to the Erlang
representation we add a function that takes a string and returns a
converted output. The (~400 randomly generated) IPv6/4 addresses at [1]
have been parsed both via erl's built-in inet:parse_address() function
and our ruby implementation. All converted ip addresses resulted in the
same output [2], [3]. The only difference is that Erlang's parse_address()
considers network ip addresses (e.g. 10.0.0.0) invalid whereas the ruby
function does not. This should not be a problem as the use case here is
to bind a service to a specific ip address on an interface and if
anything we likely prefer the less strict behaviour, given that at least
in theory it is perfectly valid for an interface to have a network
address assigned to it.

[1] http://acksyn.org/files/tripleo/ip-addresses.txt
[2] http://acksyn.org/files/tripleo/ip-addresses-ruby.txt
[3] http://acksyn.org/files/tripleo/ip-addresses-erl.txt
Change-Id: I211c75b9bab25c545bcc7f90f34edebc92bba788
Partial-Bug: #1645898
2017-01-20 08:41:22 +01:00
Carlos Camacho
bed1c230f2 Implement NTP profile
This puppet manifest will install and configure by default
the NTP service. It will also make sure chrony is purged, because it's
present on the EL7 images.

Change-Id: If3cf7d9690001b051465ea25cf8a8c3bc6f7c33a
2017-01-19 07:21:12 -05:00
Dan Prince
545cfa2d19 Avoid Yum/RPM prefetch in norpm provider
When package installation is disabled we still prefetch packages.
This disables the package prefetch by returning an empty array
which should be fine in the normal case and fixes issues when
running puppet in some docker containers.

Change-Id: Ia483c5f8500b804ba37a80e9ca1ec9c038f0a867
2017-01-02 16:46:48 -05:00
Juan Antonio Osorio Robles
68497915bc Fix value of ctlplane fqdn fact
This fact was being retrieving the value of the hostname for the management
network. We should instead be using a value set explicitly in t-h-t.

Depends-On: Idb3ca22ac136691b0bff6f94524d133a4fa10617
Change-Id: I6fcf7c7853071a9f3377aec475308bc8d10d5b33
Related-Bug: #1621742
2016-09-12 14:04:32 +03:00
Jenkins
364542757e Merge "Convert ringbuilder to build devices array" 2016-09-06 14:54:38 +00:00
Juan Antonio Osorio Robles
784a2aa0c8 Map ctlplane network to management fqdn
We don't really expose a management network, but a ctlplane one. So
when someone requests the ctlplane fqdn, we'll give the management
one. Since that's what we actually fill in the hosts.

Change-Id: Iede5a06d73206f98f283729f1879484f09d4012a
2016-09-05 14:45:47 +03:00
Juan Antonio Osorio Robles
fdfd8ab4f7 Make fqdn fact names match service net map
This will make it easier to use and consume from t-h-t, making their
use more dynamic. This is still safe to do, since these are not used
by anything yet.

Change-Id: I4d603938c568320d4ae1cc7a396070ad4ac62132
2016-09-05 14:33:45 +03:00
Steven Hardy
4b006b7c32 Convert ringbuilder to build devices array
Currently we have some hard-coded mangling in t-h-t but we
instead need to build the array based on the nodes running swift
storage, combined with the SwiftRawDisks parameter.

This will enable running SwiftStorage on nodes other than Controller
and SwiftStorage roles, and is required for custom-roles due to
the hard-coded stuff in the role templates and overcloud.yaml

Change-Id: I11deed1df712ecccf85d36a75b3bd2e9d226af36
Partially-Implements: blueprint custom-roles
2016-09-02 17:22:48 +02:00
karthik s
eec3bba44b Configure the numvfs for SRIOV interfaces
This patch shall create VFs via the PCI SYS interface.
Default value : $::os_service_default
Sample Format : ['eth0:4','eth2:128']
For values as in sample format, the sriov_numvfs config files
for eth0 and eth2 will have the values 4 and 128 respectively
The SR-IOV numvfs configuration shall be persisted in /sbin/ifup-local
so that, during the bootup of the compute nodes, the numvfs
configuration will be restored.

Change-Id: I7450b904475bdf46498d9af633416b3eba12f761
Implements: blueprint tripleo-sriov
Signed-off-by: karthik s <ksundara@redhat.com>
2016-08-29 19:41:35 +05:30
Sofer Athlan-Guyot
edde5b9a28 Fix retrieval of hostname fact based on network.
When Facter.value(:domain) is nil the facts fqdn_<network> are failing
with :

Could not retrieve fact='fqdn_external', resolution='<anonymous>': undefined method `empty?' for nil:NilClass

Change-Id: I3e7fa983d4cf91c6ab25f9aa4c353b364f44826e
Closes-bug: 1595125
2016-07-11 09:25:37 +00:00