Sync from SUSE:SLFO:Main ansible-sap-infrastructure revision e5ef425deb3226ad452936e8ad682997
This commit is contained in:
commit
079d2b9b26
23
.gitattributes
vendored
Normal file
23
.gitattributes
vendored
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
## Default LFS
|
||||||
|
*.7z filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bsp filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.gem filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.gz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.jar filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.lz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.lzma filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.obscpio filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.oxt filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.pdf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.png filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.rpm filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tbz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tbz2 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tgz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.ttf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.txz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.whl filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.xz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zip filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zst filter=lfs diff=lfs merge=lfs -text
|
3
_service
Normal file
3
_service
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
<services>
|
||||||
|
<service name="download_files" mode="manual"/>
|
||||||
|
</services>
|
BIN
ansible-sap-infrastructure-1.1.1.tar.gz
(Stored with Git LFS)
Normal file
BIN
ansible-sap-infrastructure-1.1.1.tar.gz
(Stored with Git LFS)
Normal file
Binary file not shown.
5
ansible-sap-infrastructure.changes
Normal file
5
ansible-sap-infrastructure.changes
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Fri Jan 20 09:00:00 UTC 2025 - Marcel Mamula <marcel.mamula@suse.com>
|
||||||
|
|
||||||
|
- 1.1.1
|
||||||
|
- Initial release
|
133
ansible-sap-infrastructure.spec
Normal file
133
ansible-sap-infrastructure.spec
Normal file
@ -0,0 +1,133 @@
|
|||||||
|
#
|
||||||
|
# spec file for package ansible-sap-infrastructure
|
||||||
|
#
|
||||||
|
# Copyright (c) 2025 SUSE LLC
|
||||||
|
#
|
||||||
|
# All modifications and additions to the file contributed by third parties
|
||||||
|
# remain the property of their copyright owners, unless otherwise agreed
|
||||||
|
# upon. The license for this file, and modifications and additions to the
|
||||||
|
# file, is the same license as for the pristine package itself (unless the
|
||||||
|
# license for the pristine package is not an Open Source License, in which
|
||||||
|
# case the license is the MIT License). An "Open Source License" is a
|
||||||
|
# license that conforms to the Open Source Definition (Version 1.9)
|
||||||
|
# published by the Open Source Initiative.
|
||||||
|
|
||||||
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
||||||
|
#
|
||||||
|
|
||||||
|
%define ansible_collection_name sap_infrastructure
|
||||||
|
%define ansible_roles_to_remove "sap_hypervisor_node_preconfigure sap_vm_preconfigure sap_vm_verify"
|
||||||
|
%define ansible_collection_path %{_datadir}/ansible/collections/ansible_collections/suse/%{ansible_collection_name}
|
||||||
|
|
||||||
|
|
||||||
|
Name: ansible-sap-infrastructure
|
||||||
|
Summary: Ansible collection suse.sap_infrastructure for SAP Automation
|
||||||
|
License: Apache-2.0
|
||||||
|
Version: 1.1.1
|
||||||
|
Release: 0
|
||||||
|
URL: https://github.com/SUSE/community.sap_infrastructure/
|
||||||
|
Source: %{url}archive/refs/tags/%{version}-suse.tar.gz#/%{name}-%{version}.tar.gz
|
||||||
|
|
||||||
|
BuildArch: noarch
|
||||||
|
|
||||||
|
|
||||||
|
# Python macros are required for python detection
|
||||||
|
BuildRequires: python-rpm-macros
|
||||||
|
|
||||||
|
# Minimum python version
|
||||||
|
%{?sle15_python_module_pythons}
|
||||||
|
BuildRequires: %{python_module base >= 3.11}
|
||||||
|
Requires: %{python_module base >= 3.11}
|
||||||
|
|
||||||
|
|
||||||
|
# Select correct supported Ansible
|
||||||
|
%if 0%{?suse_version} >= 1600
|
||||||
|
Requires: ansible-core
|
||||||
|
Requires: ansible
|
||||||
|
BuildRequires: ansible-core
|
||||||
|
BuildRequires: ansible
|
||||||
|
%else
|
||||||
|
# Only Ansible 9 is supported on SLES 15
|
||||||
|
Requires: ansible-core-2.16
|
||||||
|
Requires: ansible-9
|
||||||
|
BuildRequires: ansible-core-2.16
|
||||||
|
BuildRequires: ansible-9
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# Do not check any files in collections for requires
|
||||||
|
%global __requires_exclude_from ^%{python311_sitelib}/.*$
|
||||||
|
|
||||||
|
|
||||||
|
%description
|
||||||
|
This package provides a Ansible collection suse.sap_infrastructure.
|
||||||
|
|
||||||
|
It automates the provisioning of SAP infrastructure across various platforms:
|
||||||
|
- AWS EC2 Virtual Server instances
|
||||||
|
- Google Cloud Compute Engine Virtual Machines
|
||||||
|
- IBM Cloud, Intel Virtual Servers
|
||||||
|
- IBM Cloud, Power Virtual Servers
|
||||||
|
- Microsoft Azure Virtual Machines
|
||||||
|
- IBM PowerVM Virtual Machines
|
||||||
|
|
||||||
|
Ensure that you install all required packages, python modules and collections.
|
||||||
|
https://github.com/SUSE/community.sap_infrastructure/tree/main/roles/sap_vm_provision#requirements
|
||||||
|
|
||||||
|
Package and collection dependencies are not installed along with this package!
|
||||||
|
|
||||||
|
|
||||||
|
%prep
|
||||||
|
# Extract tarball
|
||||||
|
cd %{_builddir}
|
||||||
|
tar -xzf %{_sourcedir}/%{name}-%{version}.tar.gz --strip-components=1
|
||||||
|
|
||||||
|
|
||||||
|
%build
|
||||||
|
cd %{_builddir}
|
||||||
|
# Remove unsupported roles before building collection
|
||||||
|
for role in $(echo %{ansible_roles_to_remove}); do
|
||||||
|
rm -rf %{_builddir}/roles/$role
|
||||||
|
done
|
||||||
|
ansible-galaxy collection build --output-path %{_builddir}
|
||||||
|
|
||||||
|
|
||||||
|
%install
|
||||||
|
rm -rf %{buildroot}
|
||||||
|
mkdir -p %{buildroot}%{_datadir}/ansible/collections
|
||||||
|
mkdir -p %{buildroot}%{_datadir}/ansible/roles/
|
||||||
|
|
||||||
|
# ansible-galaxy always appends ansible_collections folder into collections path
|
||||||
|
ansible-galaxy collection install --force %{_builddir}/suse-%{ansible_collection_name}-%{version}.tar.gz \
|
||||||
|
--collections-path %{buildroot}%{_datadir}/ansible/collections
|
||||||
|
|
||||||
|
|
||||||
|
%post
|
||||||
|
# Loop through roles in collection and create symlinks under %{_datadir}/ansible/roles/
|
||||||
|
# Installed community collection will take precedence over role symlinks.
|
||||||
|
for role in %{ansible_collection_path}/roles/*; do
|
||||||
|
role_name=$(basename "$role")
|
||||||
|
if [ ! -e %{_datadir}/ansible/roles/community.%{ansible_collection_name}.${role_name} ]; then
|
||||||
|
ln -sf %{ansible_collection_path}/roles/${role_name} \
|
||||||
|
%{_datadir}/ansible/roles/community.%{ansible_collection_name}.${role_name}
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
|
||||||
|
%postun
|
||||||
|
# Loop through roles in %{_datadir}/ansible/roles/ and remove those that link to collection
|
||||||
|
if [ "$1" -eq 0 ]; then
|
||||||
|
for role in %{_datadir}/ansible/roles/community.%{ansible_collection_name}.*; do
|
||||||
|
if [ -L "$role" ]; then
|
||||||
|
target=$(readlink "$role")
|
||||||
|
if ( [ -e "$target" ] && [ "$target" = "%{ansible_collection_path}/roles/$(basename "$role")" ] ) || [ ! -e "$target" ]; then
|
||||||
|
rm -f "$role"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
%files
|
||||||
|
%{_datadir}/ansible/collections/
|
||||||
|
%{_datadir}/ansible/roles/
|
||||||
|
|
||||||
|
%changelog
|
Loading…
x
Reference in New Issue
Block a user