Kapitel 12: komplett
This commit is contained in:
parent
71dfc752b8
commit
07539d52ce
159
12/Prepare_Workshop/.gitignore
vendored
Normal file
159
12/Prepare_Workshop/.gitignore
vendored
Normal file
|
@ -0,0 +1,159 @@
|
|||
group_vars/all.yml
|
||||
hosts.*
|
||||
|
||||
# ---> Python
|
||||
# Byte-compiled / optimized / DLL files
|
||||
__pycache__/
|
||||
*.py[cod]
|
||||
*$py.class
|
||||
|
||||
# C extensions
|
||||
*.so
|
||||
|
||||
# Distribution / packaging
|
||||
.Python
|
||||
build/
|
||||
develop-eggs/
|
||||
dist/
|
||||
downloads/
|
||||
eggs/
|
||||
.eggs/
|
||||
lib/
|
||||
lib64/
|
||||
parts/
|
||||
sdist/
|
||||
var/
|
||||
wheels/
|
||||
pip-wheel-metadata/
|
||||
share/python-wheels/
|
||||
*.egg-info/
|
||||
.installed.cfg
|
||||
*.egg
|
||||
MANIFEST
|
||||
|
||||
# PyInstaller
|
||||
# Usually these files are written by a python script from a template
|
||||
# before PyInstaller builds the exe, so as to inject date/other infos into it.
|
||||
*.manifest
|
||||
*.spec
|
||||
|
||||
# Installer logs
|
||||
pip-log.txt
|
||||
pip-delete-this-directory.txt
|
||||
|
||||
# Unit test / coverage reports
|
||||
htmlcov/
|
||||
.tox/
|
||||
.nox/
|
||||
.coverage
|
||||
.coverage.*
|
||||
.cache
|
||||
nosetests.xml
|
||||
coverage.xml
|
||||
*.cover
|
||||
*.py,cover
|
||||
.hypothesis/
|
||||
.pytest_cache/
|
||||
|
||||
# Translations
|
||||
*.mo
|
||||
*.pot
|
||||
|
||||
# Django stuff:
|
||||
*.log
|
||||
local_settings.py
|
||||
db.sqlite3
|
||||
db.sqlite3-journal
|
||||
|
||||
# Flask stuff:
|
||||
instance/
|
||||
.webassets-cache
|
||||
|
||||
# Scrapy stuff:
|
||||
.scrapy
|
||||
|
||||
# Sphinx documentation
|
||||
docs/_build/
|
||||
|
||||
# PyBuilder
|
||||
target/
|
||||
|
||||
# Jupyter Notebook
|
||||
.ipynb_checkpoints
|
||||
|
||||
# IPython
|
||||
profile_default/
|
||||
ipython_config.py
|
||||
|
||||
# pyenv
|
||||
.python-version
|
||||
|
||||
# pipenv
|
||||
# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control.
|
||||
# However, in case of collaboration, if having platform-specific dependencies or dependencies
|
||||
# having no cross-platform support, pipenv may install dependencies that don't work, or not
|
||||
# install all needed dependencies.
|
||||
#Pipfile.lock
|
||||
|
||||
# PEP 582; used by e.g. github.com/David-OConnor/pyflow
|
||||
__pypackages__/
|
||||
|
||||
# Celery stuff
|
||||
celerybeat-schedule
|
||||
celerybeat.pid
|
||||
|
||||
# SageMath parsed files
|
||||
*.sage.py
|
||||
|
||||
# Environments
|
||||
.env
|
||||
.venv
|
||||
env/
|
||||
venv/
|
||||
ENV/
|
||||
env.bak/
|
||||
venv.bak/
|
||||
|
||||
# Spyder project settings
|
||||
.spyderproject
|
||||
.spyproject
|
||||
|
||||
# Rope project settings
|
||||
.ropeproject
|
||||
|
||||
# mkdocs documentation
|
||||
/site
|
||||
|
||||
# mypy
|
||||
.mypy_cache/
|
||||
.dmypy.json
|
||||
dmypy.json
|
||||
|
||||
# Pyre type checker
|
||||
.pyre/
|
||||
|
||||
# ---> Ansible
|
||||
*.retry
|
||||
.facts
|
||||
|
||||
# ---> Vim
|
||||
# Swap
|
||||
[._]*.s[a-v][a-z]
|
||||
!*.svg # comment out if you don't need vector files
|
||||
[._]*.sw[a-p]
|
||||
[._]s[a-rt-v][a-z]
|
||||
[._]ss[a-gi-z]
|
||||
[._]sw[a-p]
|
||||
|
||||
# Session
|
||||
Session.vim
|
||||
Sessionx.vim
|
||||
|
||||
# Temporary
|
||||
.netrwhist
|
||||
*~
|
||||
# Auto-generated tag files
|
||||
tags
|
||||
# Persistent undo
|
||||
[._]*.un~
|
||||
|
3
12/Prepare_Workshop/.gitmodules
vendored
Normal file
3
12/Prepare_Workshop/.gitmodules
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
[submodule ".submodules/ansible-lxc-ssh"]
|
||||
path = .submodules/ansible-lxc-ssh
|
||||
url = https://github.com/andreasscherbaum/ansible-lxc-ssh.git
|
613
12/Prepare_Workshop/LICENSE
Normal file
613
12/Prepare_Workshop/LICENSE
Normal file
|
@ -0,0 +1,613 @@
|
|||
GNU AFFERO GENERAL PUBLIC LICENSE
|
||||
|
||||
Version 3, 19 November 2007
|
||||
|
||||
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
|
||||
|
||||
Everyone is permitted to copy and distribute verbatim copies of this license
|
||||
document, but changing it is not allowed.
|
||||
|
||||
Preamble
|
||||
|
||||
The GNU Affero General Public License is a free, copyleft license for software
|
||||
and other kinds of works, specifically designed to ensure cooperation with
|
||||
the community in the case of network server software.
|
||||
|
||||
The licenses for most software and other practical works are designed to take
|
||||
away your freedom to share and change the works. By contrast, our General
|
||||
Public Licenses are intended to guarantee your freedom to share and change
|
||||
all versions of a program--to make sure it remains free software for all its
|
||||
users.
|
||||
|
||||
When we speak of free software, we are referring to freedom, not price. Our
|
||||
General Public Licenses are designed to make sure that you have the freedom
|
||||
to distribute copies of free software (and charge for them if you wish), that
|
||||
you receive source code or can get it if you want it, that you can change
|
||||
the software or use pieces of it in new free programs, and that you know you
|
||||
can do these things.
|
||||
|
||||
Developers that use our General Public Licenses protect your rights with two
|
||||
steps: (1) assert copyright on the software, and (2) offer you this License
|
||||
which gives you legal permission to copy, distribute and/or modify the software.
|
||||
|
||||
A secondary benefit of defending all users' freedom is that improvements made
|
||||
in alternate versions of the program, if they receive widespread use, become
|
||||
available for other developers to incorporate. Many developers of free software
|
||||
are heartened and encouraged by the resulting cooperation. However, in the
|
||||
case of software used on network servers, this result may fail to come about.
|
||||
The GNU General Public License permits making a modified version and letting
|
||||
the public access it on a server without ever releasing its source code to
|
||||
the public.
|
||||
|
||||
The GNU Affero General Public License is designed specifically to ensure that,
|
||||
in such cases, the modified source code becomes available to the community.
|
||||
It requires the operator of a network server to provide the source code of
|
||||
the modified version running there to the users of that server. Therefore,
|
||||
public use of a modified version, on a publicly accessible server, gives the
|
||||
public access to the source code of the modified version.
|
||||
|
||||
An older license, called the Affero General Public License and published by
|
||||
Affero, was designed to accomplish similar goals. This is a different license,
|
||||
not a version of the Affero GPL, but Affero has released a new version of
|
||||
the Affero GPL which permits relicensing under this license.
|
||||
|
||||
The precise terms and conditions for copying, distribution and modification
|
||||
follow.
|
||||
|
||||
TERMS AND CONDITIONS
|
||||
|
||||
0. Definitions.
|
||||
|
||||
"This License" refers to version 3 of the GNU Affero General Public License.
|
||||
|
||||
"Copyright" also means copyright-like laws that apply to other kinds of works,
|
||||
such as semiconductor masks.
|
||||
|
||||
"The Program" refers to any copyrightable work licensed under this License.
|
||||
Each licensee is addressed as "you". "Licensees" and "recipients" may be individuals
|
||||
or organizations.
|
||||
|
||||
To "modify" a work means to copy from or adapt all or part of the work in
|
||||
a fashion requiring copyright permission, other than the making of an exact
|
||||
copy. The resulting work is called a "modified version" of the earlier work
|
||||
or a work "based on" the earlier work.
|
||||
|
||||
A "covered work" means either the unmodified Program or a work based on the
|
||||
Program.
|
||||
|
||||
To "propagate" a work means to do anything with it that, without permission,
|
||||
would make you directly or secondarily liable for infringement under applicable
|
||||
copyright law, except executing it on a computer or modifying a private copy.
|
||||
Propagation includes copying, distribution (with or without modification),
|
||||
making available to the public, and in some countries other activities as
|
||||
well.
|
||||
|
||||
To "convey" a work means any kind of propagation that enables other parties
|
||||
to make or receive copies. Mere interaction with a user through a computer
|
||||
network, with no transfer of a copy, is not conveying.
|
||||
|
||||
An interactive user interface displays "Appropriate Legal Notices" to the
|
||||
extent that it includes a convenient and prominently visible feature that
|
||||
(1) displays an appropriate copyright notice, and (2) tells the user that
|
||||
there is no warranty for the work (except to the extent that warranties are
|
||||
provided), that licensees may convey the work under this License, and how
|
||||
to view a copy of this License. If the interface presents a list of user commands
|
||||
or options, such as a menu, a prominent item in the list meets this criterion.
|
||||
|
||||
1. Source Code.
|
||||
|
||||
The "source code" for a work means the preferred form of the work for making
|
||||
modifications to it. "Object code" means any non-source form of a work.
|
||||
|
||||
A "Standard Interface" means an interface that either is an official standard
|
||||
defined by a recognized standards body, or, in the case of interfaces specified
|
||||
for a particular programming language, one that is widely used among developers
|
||||
working in that language.
|
||||
|
||||
The "System Libraries" of an executable work include anything, other than
|
||||
the work as a whole, that (a) is included in the normal form of packaging
|
||||
a Major Component, but which is not part of that Major Component, and (b)
|
||||
serves only to enable use of the work with that Major Component, or to implement
|
||||
a Standard Interface for which an implementation is available to the public
|
||||
in source code form. A "Major Component", in this context, means a major essential
|
||||
component (kernel, window system, and so on) of the specific operating system
|
||||
(if any) on which the executable work runs, or a compiler used to produce
|
||||
the work, or an object code interpreter used to run it.
|
||||
|
||||
The "Corresponding Source" for a work in object code form means all the source
|
||||
code needed to generate, install, and (for an executable work) run the object
|
||||
code and to modify the work, including scripts to control those activities.
|
||||
However, it does not include the work's System Libraries, or general-purpose
|
||||
tools or generally available free programs which are used unmodified in performing
|
||||
those activities but which are not part of the work. For example, Corresponding
|
||||
Source includes interface definition files associated with source files for
|
||||
the work, and the source code for shared libraries and dynamically linked
|
||||
subprograms that the work is specifically designed to require, such as by
|
||||
intimate data communication or control flow between those
|
||||
|
||||
subprograms and other parts of the work.
|
||||
|
||||
The Corresponding Source need not include anything that users can regenerate
|
||||
automatically from other parts of the Corresponding Source.
|
||||
|
||||
The Corresponding Source for a work in source code form is that same work.
|
||||
|
||||
2. Basic Permissions.
|
||||
|
||||
All rights granted under this License are granted for the term of copyright
|
||||
on the Program, and are irrevocable provided the stated conditions are met.
|
||||
This License explicitly affirms your unlimited permission to run the unmodified
|
||||
Program. The output from running a covered work is covered by this License
|
||||
only if the output, given its content, constitutes a covered work. This License
|
||||
acknowledges your rights of fair use or other equivalent, as provided by copyright
|
||||
law.
|
||||
|
||||
You may make, run and propagate covered works that you do not convey, without
|
||||
conditions so long as your license otherwise remains in force. You may convey
|
||||
covered works to others for the sole purpose of having them make modifications
|
||||
exclusively for you, or provide you with facilities for running those works,
|
||||
provided that you comply with the terms of this License in conveying all material
|
||||
for which you do not control copyright. Those thus making or running the covered
|
||||
works for you must do so exclusively on your behalf, under your direction
|
||||
and control, on terms that prohibit them from making any copies of your copyrighted
|
||||
material outside their relationship with you.
|
||||
|
||||
Conveying under any other circumstances is permitted solely under the conditions
|
||||
stated below. Sublicensing is not allowed; section 10 makes it unnecessary.
|
||||
|
||||
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
|
||||
|
||||
No covered work shall be deemed part of an effective technological measure
|
||||
under any applicable law fulfilling obligations under article 11 of the WIPO
|
||||
copyright treaty adopted on 20 December 1996, or similar laws prohibiting
|
||||
or restricting circumvention of such measures.
|
||||
|
||||
When you convey a covered work, you waive any legal power to forbid circumvention
|
||||
of technological measures to the extent such circumvention is effected by
|
||||
exercising rights under this License with respect to the covered work, and
|
||||
you disclaim any intention to limit operation or modification of the work
|
||||
as a means of enforcing, against the work's users, your or third parties'
|
||||
legal rights to forbid circumvention of technological measures.
|
||||
|
||||
4. Conveying Verbatim Copies.
|
||||
|
||||
You may convey verbatim copies of the Program's source code as you receive
|
||||
it, in any medium, provided that you conspicuously and appropriately publish
|
||||
on each copy an appropriate copyright notice; keep intact all notices stating
|
||||
that this License and any non-permissive terms added in accord with section
|
||||
7 apply to the code; keep intact all notices of the absence of any warranty;
|
||||
and give all recipients a copy of this License along with the Program.
|
||||
|
||||
You may charge any price or no price for each copy that you convey, and you
|
||||
may offer support or warranty protection for a fee.
|
||||
|
||||
5. Conveying Modified Source Versions.
|
||||
|
||||
You may convey a work based on the Program, or the modifications to produce
|
||||
it from the Program, in the form of source code under the terms of section
|
||||
4, provided that you also meet all of these conditions:
|
||||
|
||||
a) The work must carry prominent notices stating that you modified it, and
|
||||
giving a relevant date.
|
||||
|
||||
b) The work must carry prominent notices stating that it is released under
|
||||
this License and any conditions added under section 7. This requirement modifies
|
||||
the requirement in section 4 to "keep intact all notices".
|
||||
|
||||
c) You must license the entire work, as a whole, under this License to anyone
|
||||
who comes into possession of a copy. This License will therefore apply, along
|
||||
with any applicable section 7 additional terms, to the whole of the work,
|
||||
and all its parts, regardless of how they are packaged. This License gives
|
||||
no permission to license the work in any other way, but it does not invalidate
|
||||
such permission if you have separately received it.
|
||||
|
||||
d) If the work has interactive user interfaces, each must display Appropriate
|
||||
Legal Notices; however, if the Program has interactive interfaces that do
|
||||
not display Appropriate Legal Notices, your work need not make them do so.
|
||||
|
||||
A compilation of a covered work with other separate and independent works,
|
||||
which are not by their nature extensions of the covered work, and which are
|
||||
not combined with it such as to form a larger program, in or on a volume of
|
||||
a storage or distribution medium, is called an "aggregate" if the compilation
|
||||
and its resulting copyright are not used to limit the access or legal rights
|
||||
of the compilation's users beyond what the individual works permit. Inclusion
|
||||
of a covered work in an aggregate does not cause this License to apply to
|
||||
the other parts of the aggregate.
|
||||
|
||||
6. Conveying Non-Source Forms.
|
||||
|
||||
You may convey a covered work in object code form under the terms of sections
|
||||
4 and 5, provided that you also convey the machine-readable Corresponding
|
||||
Source under the terms of this License, in one of these ways:
|
||||
|
||||
a) Convey the object code in, or embodied in, a physical product (including
|
||||
a physical distribution medium), accompanied by the Corresponding Source fixed
|
||||
on a durable physical medium customarily used for software interchange.
|
||||
|
||||
b) Convey the object code in, or embodied in, a physical product (including
|
||||
a physical distribution medium), accompanied by a written offer, valid for
|
||||
at least three years and valid for as long as you offer spare parts or customer
|
||||
support for that product model, to give anyone who possesses the object code
|
||||
either (1) a copy of the Corresponding Source for all the software in the
|
||||
product that is covered by this License, on a durable physical medium customarily
|
||||
used for software interchange, for a price no more than your reasonable cost
|
||||
of physically performing this conveying of source, or (2) access to copy the
|
||||
Corresponding Source from a network server at no charge.
|
||||
|
||||
c) Convey individual copies of the object code with a copy of the written
|
||||
offer to provide the Corresponding Source. This alternative is allowed only
|
||||
occasionally and noncommercially, and only if you received the object code
|
||||
with such an offer, in accord with subsection 6b.
|
||||
|
||||
d) Convey the object code by offering access from a designated place (gratis
|
||||
or for a charge), and offer equivalent access to the Corresponding Source
|
||||
in the same way through the same place at no further charge. You need not
|
||||
require recipients to copy the Corresponding Source along with the object
|
||||
code. If the place to copy the object code is a network server, the Corresponding
|
||||
Source may be on a different server (operated by you or a third party) that
|
||||
supports equivalent copying facilities, provided you maintain clear directions
|
||||
next to the object code saying where to find the Corresponding Source. Regardless
|
||||
of what server hosts the Corresponding Source, you remain obligated to ensure
|
||||
that it is available for as long as needed to satisfy these requirements.
|
||||
|
||||
e) Convey the object code using peer-to-peer transmission, provided you inform
|
||||
other peers where the object code and Corresponding Source of the work are
|
||||
being offered to the general public at no charge under subsection 6d.
|
||||
|
||||
A separable portion of the object code, whose source code is excluded from
|
||||
the Corresponding Source as a System Library, need not be included in conveying
|
||||
the object code work.
|
||||
|
||||
A "User Product" is either (1) a "consumer product", which means any tangible
|
||||
personal property which is normally used for personal, family, or household
|
||||
purposes, or (2) anything designed or sold for incorporation into a dwelling.
|
||||
In determining whether a product is a consumer product, doubtful cases shall
|
||||
be resolved in favor of coverage. For a particular product received by a particular
|
||||
user, "normally used" refers to a typical or common use of that class of product,
|
||||
regardless of the status of the particular user or of the way in which the
|
||||
particular user actually uses, or expects or is expected to use, the product.
|
||||
A product is a consumer product regardless of whether the product has substantial
|
||||
commercial, industrial or non-consumer uses, unless such uses represent the
|
||||
only significant mode of use of the product.
|
||||
|
||||
"Installation Information" for a User Product means any methods, procedures,
|
||||
authorization keys, or other information required to install and execute modified
|
||||
versions of a covered work in that User Product from a modified version of
|
||||
its Corresponding Source. The information must suffice to ensure that the
|
||||
continued functioning of the modified object code is in no case prevented
|
||||
or interfered with solely because modification has been made.
|
||||
|
||||
If you convey an object code work under this section in, or with, or specifically
|
||||
for use in, a User Product, and the conveying occurs as part of a transaction
|
||||
in which the right of possession and use of the User Product is transferred
|
||||
to the recipient in perpetuity or for a fixed term (regardless of how the
|
||||
transaction is characterized), the Corresponding Source conveyed under this
|
||||
section must be accompanied by the Installation Information. But this requirement
|
||||
does not apply if neither you nor any third party retains the ability to install
|
||||
modified object code on the User Product (for example, the work has been installed
|
||||
in ROM).
|
||||
|
||||
The requirement to provide Installation Information does not include a requirement
|
||||
to continue to provide support service, warranty, or updates for a work that
|
||||
has been modified or installed by the recipient, or for the User Product in
|
||||
which it has been modified or installed. Access to a network may be denied
|
||||
when the modification itself materially and adversely affects the operation
|
||||
of the network or violates the rules and protocols for communication across
|
||||
the network.
|
||||
|
||||
Corresponding Source conveyed, and Installation Information provided, in accord
|
||||
with this section must be in a format that is publicly documented (and with
|
||||
an implementation available to the public in source code form), and must require
|
||||
no special password or key for unpacking, reading or copying.
|
||||
|
||||
7. Additional Terms.
|
||||
|
||||
"Additional permissions" are terms that supplement the terms of this License
|
||||
by making exceptions from one or more of its conditions. Additional permissions
|
||||
that are applicable to the entire Program shall be treated as though they
|
||||
were included in this License, to the extent that they are valid under applicable
|
||||
law. If additional permissions apply only to part of the Program, that part
|
||||
may be used separately under those permissions, but the entire Program remains
|
||||
governed by this License without regard to the additional permissions.
|
||||
|
||||
When you convey a copy of a covered work, you may at your option remove any
|
||||
additional permissions from that copy, or from any part of it. (Additional
|
||||
permissions may be written to require their own removal in certain cases when
|
||||
you modify the work.) You may place additional permissions on material, added
|
||||
by you to a covered work, for which you have or can give appropriate copyright
|
||||
permission.
|
||||
|
||||
Notwithstanding any other provision of this License, for material you add
|
||||
to a covered work, you may (if authorized by the copyright holders of that
|
||||
material) supplement the terms of this License with terms:
|
||||
|
||||
a) Disclaiming warranty or limiting liability differently from the terms of
|
||||
sections 15 and 16 of this License; or
|
||||
|
||||
b) Requiring preservation of specified reasonable legal notices or author
|
||||
attributions in that material or in the Appropriate Legal Notices displayed
|
||||
by works containing it; or
|
||||
|
||||
c) Prohibiting misrepresentation of the origin of that material, or requiring
|
||||
that modified versions of such material be marked in reasonable ways as different
|
||||
from the original version; or
|
||||
|
||||
d) Limiting the use for publicity purposes of names of licensors or authors
|
||||
of the material; or
|
||||
|
||||
e) Declining to grant rights under trademark law for use of some trade names,
|
||||
trademarks, or service marks; or
|
||||
|
||||
f) Requiring indemnification of licensors and authors of that material by
|
||||
anyone who conveys the material (or modified versions of it) with contractual
|
||||
assumptions of liability to the recipient, for any liability that these contractual
|
||||
assumptions directly impose on those licensors and authors.
|
||||
|
||||
All other non-permissive additional terms are considered "further restrictions"
|
||||
within the meaning of section 10. If the Program as you received it, or any
|
||||
part of it, contains a notice stating that it is governed by this License
|
||||
along with a term that is a further restriction, you may remove that term.
|
||||
If a license document contains a further restriction but permits relicensing
|
||||
or conveying under this License, you may add to a covered work material governed
|
||||
by the terms of that license document, provided that the further restriction
|
||||
does not survive such relicensing or conveying.
|
||||
|
||||
If you add terms to a covered work in accord with this section, you must place,
|
||||
in the relevant source files, a statement of the additional terms that apply
|
||||
to those files, or a notice indicating where to find the applicable terms.
|
||||
|
||||
Additional terms, permissive or non-permissive, may be stated in the form
|
||||
of a separately written license, or stated as exceptions; the above requirements
|
||||
apply either way.
|
||||
|
||||
8. Termination.
|
||||
|
||||
You may not propagate or modify a covered work except as expressly provided
|
||||
under this License. Any attempt otherwise to propagate or modify it is void,
|
||||
and will automatically terminate your rights under this License (including
|
||||
any patent licenses granted under the third paragraph of section 11).
|
||||
|
||||
However, if you cease all violation of this License, then your license from
|
||||
a particular copyright holder is reinstated (a) provisionally, unless and
|
||||
until the copyright holder explicitly and finally terminates your license,
|
||||
and (b) permanently, if the copyright holder fails to notify you of the violation
|
||||
by some reasonable means prior to 60 days after the cessation.
|
||||
|
||||
Moreover, your license from a particular copyright holder is reinstated permanently
|
||||
if the copyright holder notifies you of the violation by some reasonable means,
|
||||
this is the first time you have received notice of violation of this License
|
||||
(for any work) from that copyright holder, and you cure the violation prior
|
||||
to 30 days after your receipt of the notice.
|
||||
|
||||
Termination of your rights under this section does not terminate the licenses
|
||||
of parties who have received copies or rights from you under this License.
|
||||
If your rights have been terminated and not permanently reinstated, you do
|
||||
not qualify to receive new licenses for the same material under section 10.
|
||||
|
||||
9. Acceptance Not Required for Having Copies.
|
||||
|
||||
You are not required to accept this License in order to receive or run a copy
|
||||
of the Program. Ancillary propagation of a covered work occurring solely as
|
||||
a consequence of using peer-to-peer transmission to receive a copy likewise
|
||||
does not require acceptance. However, nothing other than this License grants
|
||||
you permission to propagate or modify any covered work. These actions infringe
|
||||
copyright if you do not accept this License. Therefore, by modifying or propagating
|
||||
a covered work, you indicate your acceptance of this License to do so.
|
||||
|
||||
10. Automatic Licensing of Downstream Recipients.
|
||||
|
||||
Each time you convey a covered work, the recipient automatically receives
|
||||
a license from the original licensors, to run, modify and propagate that work,
|
||||
subject to this License. You are not responsible for enforcing compliance
|
||||
by third parties with this License.
|
||||
|
||||
An "entity transaction" is a transaction transferring control of an organization,
|
||||
or substantially all assets of one, or subdividing an organization, or merging
|
||||
organizations. If propagation of a covered work results from an entity transaction,
|
||||
each party to that transaction who receives a copy of the work also receives
|
||||
whatever licenses to the work the party's predecessor in interest had or could
|
||||
give under the previous paragraph, plus a right to possession of the Corresponding
|
||||
Source of the work from the predecessor in interest, if the predecessor has
|
||||
it or can get it with reasonable efforts.
|
||||
|
||||
You may not impose any further restrictions on the exercise of the rights
|
||||
granted or affirmed under this License. For example, you may not impose a
|
||||
license fee, royalty, or other charge for exercise of rights granted under
|
||||
this License, and you may not initiate litigation (including a cross-claim
|
||||
or counterclaim in a lawsuit) alleging that any patent claim is infringed
|
||||
by making, using, selling, offering for sale, or importing the Program or
|
||||
any portion of it.
|
||||
|
||||
11. Patents.
|
||||
|
||||
A "contributor" is a copyright holder who authorizes use under this License
|
||||
of the Program or a work on which the Program is based. The work thus licensed
|
||||
is called the contributor's "contributor version".
|
||||
|
||||
A contributor's "essential patent claims" are all patent claims owned or controlled
|
||||
by the contributor, whether already acquired or hereafter acquired, that would
|
||||
be infringed by some manner, permitted by this License, of making, using,
|
||||
or selling its contributor version, but do not include claims that would be
|
||||
infringed only as a consequence of further modification of the contributor
|
||||
version. For purposes of this definition, "control" includes the right to
|
||||
grant patent sublicenses in a manner consistent with the requirements of this
|
||||
License.
|
||||
|
||||
Each contributor grants you a non-exclusive, worldwide, royalty-free patent
|
||||
license under the contributor's essential patent claims, to make, use, sell,
|
||||
offer for sale, import and otherwise run, modify and propagate the contents
|
||||
of its contributor version.
|
||||
|
||||
In the following three paragraphs, a "patent license" is any express agreement
|
||||
or commitment, however denominated, not to enforce a patent (such as an express
|
||||
permission to practice a patent or covenant not to s ue for patent infringement).
|
||||
To "grant" such a patent license to a party means to make such an agreement
|
||||
or commitment not to enforce a patent against the party.
|
||||
|
||||
If you convey a covered work, knowingly relying on a patent license, and the
|
||||
Corresponding Source of the work is not available for anyone to copy, free
|
||||
of charge and under the terms of this License, through a publicly available
|
||||
network server or other readily accessible means, then you must either (1)
|
||||
cause the Corresponding Source to be so available, or (2) arrange to deprive
|
||||
yourself of the benefit of the patent license for this particular work, or
|
||||
(3) arrange, in a manner consistent with the requirements of this License,
|
||||
to extend the patent
|
||||
|
||||
license to downstream recipients. "Knowingly relying" means you have actual
|
||||
knowledge that, but for the patent license, your conveying the covered work
|
||||
in a country, or your recipient's use of the covered work in a country, would
|
||||
infringe one or more identifiable patents in that country that you have reason
|
||||
to believe are valid.
|
||||
|
||||
If, pursuant to or in connection with a single transaction or arrangement,
|
||||
you convey, or propagate by procuring conveyance of, a covered work, and grant
|
||||
a patent license to some of the parties receiving the covered work authorizing
|
||||
them to use, propagate, modify or convey a specific copy of the covered work,
|
||||
then the patent license you grant is automatically extended to all recipients
|
||||
of the covered work and works based on it.
|
||||
|
||||
A patent license is "discriminatory" if it does not include within the scope
|
||||
of its coverage, prohibits the exercise of, or is conditioned on the non-exercise
|
||||
of one or more of the rights that are specifically granted under this License.
|
||||
You may not convey a covered work if you are a party to an arrangement with
|
||||
a third party that is in the business of distributing software, under which
|
||||
you make payment to the third party based on the extent of your activity of
|
||||
conveying the work, and under which the third party grants, to any of the
|
||||
parties who would receive the covered work from you, a discriminatory patent
|
||||
license (a) in connection with copies of the covered work conveyed by you
|
||||
(or copies made from those copies), or (b) primarily for and in connection
|
||||
with specific products or compilations that contain the covered work, unless
|
||||
you entered into that arrangement, or that patent license was granted, prior
|
||||
to 28 March 2007.
|
||||
|
||||
Nothing in this License shall be construed as excluding or limiting any implied
|
||||
license or other defenses to infringement that may otherwise be available
|
||||
to you under applicable patent law.
|
||||
|
||||
12. No Surrender of Others' Freedom.
|
||||
|
||||
If conditions are imposed on you (whether by court order, agreement or otherwise)
|
||||
that contradict the conditions of this License, they do not excuse you from
|
||||
the conditions of this License. If you cannot convey a covered work so as
|
||||
to satisfy simultaneously your obligations under this License and any other
|
||||
pertinent obligations, then as a consequence you may
|
||||
|
||||
not convey it at all. For example, if you agree to terms that obligate you
|
||||
to collect a royalty for further conveying from those to whom you convey the
|
||||
Program, the only way you could satisfy both those terms and this License
|
||||
would be to refrain entirely from conveying the Program.
|
||||
|
||||
13. Remote Network Interaction; Use with the GNU General Public License.
|
||||
|
||||
Notwithstanding any other provision of this License, if you modify the Program,
|
||||
your modified version must prominently offer all users interacting with it
|
||||
remotely through a computer network (if your version supports such interaction)
|
||||
an opportunity to receive the Corresponding Source of your version by providing
|
||||
access to the Corresponding Source from a network server at no charge, through
|
||||
some standard or customary means of facilitating copying of software. This
|
||||
Corresponding Source shall include the Corresponding Source for any work covered
|
||||
by version 3 of the GNU General Public License that is incorporated pursuant
|
||||
to the following paragraph.
|
||||
|
||||
Notwithstanding any other provision of this License, you have permission to
|
||||
link or combine any covered work with a work licensed under version 3 of the
|
||||
GNU General Public License into a single combined work, and to convey the
|
||||
resulting work. The terms of this License will continue to apply to the part
|
||||
which is the covered work, but the work with which it is combined will remain
|
||||
governed by version 3 of the GNU General Public License.
|
||||
|
||||
14. Revised Versions of this License.
|
||||
|
||||
The Free Software Foundation may publish revised and/or new versions of the
|
||||
GNU Affero General Public License from time to time. Such new versions will
|
||||
be similar in spirit to the present version, but may differ in detail to address
|
||||
new problems or concerns.
|
||||
|
||||
Each version is given a distinguishing version number. If the Program specifies
|
||||
that a certain numbered version of the GNU Affero General Public License "or
|
||||
any later version" applies to it, you have the option of following the terms
|
||||
and conditions either of that numbered version or of any later version published
|
||||
by the Free Software Foundation. If the Program does not specify a version
|
||||
number of the GNU Affero General Public License, you may choose any version
|
||||
ever published by the Free Software Foundation.
|
||||
|
||||
If the Program specifies that a proxy can decide which future versions of
|
||||
the GNU Affero General Public License can be used, that proxy's public statement
|
||||
of acceptance of a version permanently authorizes you to choose that version
|
||||
for the Program.
|
||||
|
||||
Later license versions may give you additional or different permissions. However,
|
||||
no additional obligations are imposed on any author or copyright holder as
|
||||
a result of your choosing to follow a later version.
|
||||
|
||||
15. Disclaimer of Warranty.
|
||||
|
||||
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE
|
||||
LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
|
||||
OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER
|
||||
EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||
OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM
|
||||
PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR
|
||||
CORRECTION.
|
||||
|
||||
16. Limitation of Liability.
|
||||
|
||||
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL
|
||||
ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS THE PROGRAM
|
||||
AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL,
|
||||
INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO
|
||||
USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED
|
||||
INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE
|
||||
PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER
|
||||
PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
|
||||
|
||||
17. Interpretation of Sections 15 and 16.
|
||||
|
||||
If the disclaimer of warranty and limitation of liability provided above cannot
|
||||
be given local legal effect according to their terms, reviewing courts shall
|
||||
apply local law that most closely approximates an absolute waiver of all civil
|
||||
liability in connection with the Program, unless a warranty or assumption
|
||||
of liability accompanies a copy of the Program in return for a fee. END OF
|
||||
TERMS AND CONDITIONS
|
||||
|
||||
How to Apply These Terms to Your New Programs
|
||||
|
||||
If you develop a new program, and you want it to be of the greatest possible
|
||||
use to the public, the best way to achieve this is to make it free software
|
||||
which everyone can redistribute and change under these terms.
|
||||
|
||||
To do so, attach the following notices to the program. It is safest to attach
|
||||
them to the start of each source file to most effectively state the exclusion
|
||||
of warranty; and each file should have at least the "copyright" line and a
|
||||
pointer to where the full notice is found.
|
||||
|
||||
<one line to give the program's name and a brief idea of what it does.>
|
||||
|
||||
Copyright (C) <year> <name of author>
|
||||
|
||||
This program is free software: you can redistribute it and/or modify it under
|
||||
the terms of the GNU Affero General Public License as published by the Free
|
||||
Software Foundation, either version 3 of the License, or (at your option)
|
||||
any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful, but WITHOUT
|
||||
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
||||
FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
|
||||
details.
|
||||
|
||||
You should have received a copy of the GNU Affero General Public License along
|
||||
with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
Also add information on how to contact you by electronic and paper mail.
|
||||
|
||||
If your software can interact with users remotely through a computer network,
|
||||
you should also make sure that it provides a way for users to get its source.
|
||||
For example, if your program is a web application, its interface could display
|
||||
a "Source" link that leads users to an archive of the code. There are many
|
||||
ways you could offer source, and different solutions will be better for different
|
||||
programs; see section 13 for the specific requirements.
|
||||
|
||||
You should also get your employer (if you work as a programmer) or school,
|
||||
if any, to sign a "copyright disclaimer" for the program, if necessary. For
|
||||
more information on this, and how to apply and follow the GNU AGPL, see <https://www.gnu.org/licenses/>.
|
8
12/Prepare_Workshop/README.md
Normal file
8
12/Prepare_Workshop/README.md
Normal file
|
@ -0,0 +1,8 @@
|
|||
# Prepare_Workshop
|
||||
|
||||
Prepare Ansible workshop
|
||||
|
||||
Set up host machine(s) and create LXContainers defined in inventory
|
||||
|
||||
For local LXContainers `ansible-playbook` must be called as "root". `--become` does NOT work!
|
||||
|
20
12/Prepare_Workshop/ansible.cfg
Normal file
20
12/Prepare_Workshop/ansible.cfg
Normal file
|
@ -0,0 +1,20 @@
|
|||
[defaults]
|
||||
inventory = ./hosts
|
||||
|
||||
connection_plugins = ./connection_plugins/
|
||||
|
||||
interpreter_python = auto
|
||||
|
||||
retry_files_enabled = True
|
||||
retry_files_save_path = ./Retry/
|
||||
|
||||
fact_caching = yaml
|
||||
fact_caching_connection = ./.facts
|
||||
gathering = smart
|
||||
|
||||
host_key_checking = false
|
||||
|
||||
[colors]
|
||||
verbose = bright blue
|
||||
error = bright red
|
||||
|
1
12/Prepare_Workshop/connection_plugins/lxc_ssh.py
Symbolic link
1
12/Prepare_Workshop/connection_plugins/lxc_ssh.py
Symbolic link
|
@ -0,0 +1 @@
|
|||
../.submodules/ansible-lxc-ssh/lxc_ssh.py
|
200
12/Prepare_Workshop/create_inventory_lxc.yml
Normal file
200
12/Prepare_Workshop/create_inventory_lxc.yml
Normal file
|
@ -0,0 +1,200 @@
|
|||
---
|
||||
- hosts: all
|
||||
|
||||
gather_facts: no
|
||||
|
||||
#serial: 1
|
||||
|
||||
vars:
|
||||
# List(!) of SSH keys for authorized_keys. Set here or in group_vars/all.yml
|
||||
#ssh_keys: []
|
||||
#
|
||||
# root password, default: "root"
|
||||
#root_password: root
|
||||
#
|
||||
# Normal user account (with sudo)
|
||||
#service_username: service
|
||||
#service_password: {{ service_username }}
|
||||
#service_ssh_keys: {{ ssh_keys }}
|
||||
|
||||
# "*cmdline_" must be listed AFTER "^cmdline_"!
|
||||
cmdline_python:
|
||||
alpine:
|
||||
- "apk add -U python3"
|
||||
archlinux:
|
||||
- "pacman -Sy"
|
||||
- "pacman -S --noconfirm python"
|
||||
centos: &cmdline_python_centos
|
||||
- "yum clean all"
|
||||
- "yum makecache"
|
||||
- "yum install -y python3 || true"
|
||||
almalinux: *cmdline_python_centos
|
||||
fedora: *cmdline_python_centos
|
||||
oracle: *cmdline_python_centos
|
||||
rockylinux: *cmdline_python_centos
|
||||
debian: &cmdline_python_debian
|
||||
- "apt-get -y update"
|
||||
- "apt-get install -y python3 python3-apt"
|
||||
devuan: *cmdline_python_debian
|
||||
mint: *cmdline_python_debian
|
||||
ubuntu: *cmdline_python_debian
|
||||
opensuse:
|
||||
- "zypper --gpg-auto-import-keys --no-gpg-checks -n refresh"
|
||||
- "zypper --gpg-auto-import-keys --no-gpg-checks -n install python3"
|
||||
voidlinux:
|
||||
- "xbps-install -Suy python3 libgcc"
|
||||
|
||||
cmdline_fixes:
|
||||
oracle:
|
||||
8:
|
||||
- '[ ! -f /usr/bin/python3 ] && ln -s /usr/libexec/platform-python /usr/bin/python3 || true'
|
||||
|
||||
ssh_package_name:
|
||||
alpine: openssh
|
||||
archlinux: openssh
|
||||
opensuse: openssh
|
||||
voidlinux: openssh
|
||||
|
||||
ssh_config_filename:
|
||||
opensuse-tumbleweed: /etc/ssh/sshd_config.d/permitrootlogin.conf
|
||||
|
||||
ssh_service_name:
|
||||
debian: ssh
|
||||
devuan: ssh
|
||||
mint: ssh
|
||||
ubuntu: ssh
|
||||
|
||||
user_shell:
|
||||
alpine: /bin/ash
|
||||
|
||||
|
||||
|
||||
tasks:
|
||||
|
||||
- name: End for non-LXContainer
|
||||
meta: end_host
|
||||
when: inventory_hostname in groups.lxc_hosts
|
||||
|
||||
|
||||
- name: Check for no-validate parameter in download template
|
||||
shell: "/usr/share/lxc/templates/lxc-download --help | grep no-validate || true"
|
||||
changed_when: false
|
||||
register: lxc_download_validate
|
||||
delegate_to: "{{ ansible_host|default('localhost') }}"
|
||||
|
||||
|
||||
- name: Create LXContainer
|
||||
lxc_container:
|
||||
name: "{{ inventory_hostname }}"
|
||||
state: started
|
||||
template: download
|
||||
template_options: "-a amd64 -d {{ os_d }} -r {{ os_r }} {% if 'no-validate' in lxc_download_validate.stdout %}--no-validate{% endif %}"
|
||||
config: "{{ lxc_config_file|default('/etc/lxc/ansible.conf') }}"
|
||||
container_config:
|
||||
- "lxc.group = {{ os_d }}"
|
||||
- "lxc.group = {{ (cmdline_python[os_d][0]).split(' ')[0].split('-')[0] }}"
|
||||
register: lxc_created
|
||||
delegate_to: "{{ ansible_host|default('localhost') }}"
|
||||
|
||||
|
||||
- pause:
|
||||
seconds: 10
|
||||
when: lxc_created is changed
|
||||
|
||||
|
||||
- name: Raw-Install Python
|
||||
raw: "{{ item }}"
|
||||
loop: "{{ cmdline_python[os_d] }}"
|
||||
|
||||
|
||||
- name: OS-dependent fixes
|
||||
raw: "{{ item }}"
|
||||
loop: "{{ cmdline_fixes[os_d][os_r]|default([]) }}"
|
||||
|
||||
|
||||
- setup:
|
||||
|
||||
|
||||
- name: Set root password
|
||||
shell: "echo root:{{ root_password|default('root') }} | chpasswd -c SHA256"
|
||||
|
||||
|
||||
- name: Add SSH keys
|
||||
authorized_key:
|
||||
user: root
|
||||
key: "{{ item }}"
|
||||
loop: "{{ ssh_keys }}"
|
||||
|
||||
|
||||
- name: "[BLOCK] when 'service_username' is set"
|
||||
when: service_username is defined
|
||||
block:
|
||||
|
||||
- name: 'Add normal user "{{ service_username }}"'
|
||||
user:
|
||||
name: "{{ service_username }}"
|
||||
shell: "{{ user_shell[os_d]|default('/bin/bash') }}"
|
||||
|
||||
|
||||
- name: 'Set password for user "{{ service_username }}"'
|
||||
shell: "echo {{ service_username }}:{{ service_password|default(service_username) }} | chpasswd -c SHA256"
|
||||
|
||||
|
||||
- name: Add SSH keys
|
||||
authorized_key:
|
||||
user: "{{ service_username }}"
|
||||
key: "{{ item }}"
|
||||
loop: "{{ ssh_keys_service|default(ssh_keys) }}"
|
||||
|
||||
|
||||
- name: Install sudo
|
||||
package:
|
||||
name: sudo
|
||||
|
||||
|
||||
- name: Add sudo line for service
|
||||
lineinfile:
|
||||
path: /etc/sudoers
|
||||
regexp: "^service"
|
||||
line: "{{ service_username }} ALL=(ALL:ALL) NOPASSWD: ALL"
|
||||
backup: yes
|
||||
|
||||
|
||||
- name: Install SSH
|
||||
package:
|
||||
name: "{{ ssh_package_name[os_d]|default('openssh-server') }}"
|
||||
state: latest
|
||||
|
||||
|
||||
- name: "Set «PermitRootLogin» to «yes»"
|
||||
lineinfile:
|
||||
dest: "{{ ssh_config_filename[os_d + '-' + os_r|string]|default('/etc/ssh/sshd_config') }}"
|
||||
regexp: '^#? *PermitRootLogin'
|
||||
line: "PermitRootLogin yes"
|
||||
create: yes
|
||||
backup: yes
|
||||
notify: "Restart SSH"
|
||||
|
||||
|
||||
- name: Enable SSH
|
||||
service:
|
||||
name: "{{ ssh_service_name[os_d]|default('sshd') }}"
|
||||
enabled: yes
|
||||
|
||||
|
||||
- name: Start SSH
|
||||
service:
|
||||
name: "{{ ssh_service_name[os_d]|default('sshd') }}"
|
||||
state: started
|
||||
ignore_errors: yes
|
||||
|
||||
|
||||
|
||||
handlers:
|
||||
|
||||
- name: Restart SSH
|
||||
service:
|
||||
name: "{{ ssh_service_name[os_d]|default('sshd') }}"
|
||||
state: restarted
|
||||
|
||||
|
17
12/Prepare_Workshop/files/etc/dnsmasq.d/br-lxc
Normal file
17
12/Prepare_Workshop/files/etc/dnsmasq.d/br-lxc
Normal file
|
@ -0,0 +1,17 @@
|
|||
#strict-order
|
||||
local=/br-lxc/
|
||||
domain=br-lxc
|
||||
expand-hosts
|
||||
|
||||
#except-interface=lo
|
||||
|
||||
#bind-interfaces
|
||||
interface=br-lxc
|
||||
|
||||
dhcp-range=br-lxc,192.168.1.100,192.168.1.199,2m
|
||||
|
||||
dhcp-no-override
|
||||
dhcp-authoritative
|
||||
|
||||
dhcp-option=option:dns-server,192.168.1.1
|
||||
|
13
12/Prepare_Workshop/files/etc/lxc/ansible.conf
Normal file
13
12/Prepare_Workshop/files/etc/lxc/ansible.conf
Normal file
|
@ -0,0 +1,13 @@
|
|||
lxc.groups = ansible
|
||||
|
||||
lxc.start.auto = 1
|
||||
|
||||
### 2020-09 wg. NTP in Debian 10
|
||||
lxc.apparmor.profile = unconfined
|
||||
|
||||
lxc.net.0.type = veth
|
||||
lxc.net.0.flags = up
|
||||
lxc.net.0.name = eth0
|
||||
lxc.net.0.link = br-lxc
|
||||
lxc.net.0.hwaddr = fe:fe:fe:xx:xx:xx
|
||||
|
|
@ -0,0 +1,9 @@
|
|||
auto br-lxc
|
||||
iface br-lxc inet static
|
||||
address 192.168.1.1/24
|
||||
|
||||
bridge_ports none
|
||||
|
||||
up /sbin/iptables -t nat -A POSTROUTING -s 192.168.1.0/24 ! -o br-lxc ! -d 192.168.1.0/24 -j MASQUERADE
|
||||
down /sbin/iptables -t nat -D POSTROUTING -s 192.168.1.0/24 ! -o br-lxc ! -d 192.168.1.0/24 -j MASQUERADE
|
||||
|
137
12/Prepare_Workshop/prepare_lxc_hosts.yml
Normal file
137
12/Prepare_Workshop/prepare_lxc_hosts.yml
Normal file
|
@ -0,0 +1,137 @@
|
|||
---
|
||||
- hosts:
|
||||
- lxc_hosts
|
||||
|
||||
tasks:
|
||||
- assert:
|
||||
that:
|
||||
- ansible_pkg_mgr == "apt"
|
||||
fail_msg: "Sorry, Debian-like hosts only!"
|
||||
|
||||
|
||||
- name: Just to be sure python3-apt is installed
|
||||
command: apt install -y python3-apt
|
||||
args:
|
||||
creates: /usr/lib/python3/dist-packages/apt
|
||||
|
||||
|
||||
- name: Install packages
|
||||
package:
|
||||
name: "{{ packages }}"
|
||||
state: latest
|
||||
vars:
|
||||
packages:
|
||||
- bridge-utils
|
||||
- dnsmasq
|
||||
- iptables
|
||||
- lxc
|
||||
- python3-lxc
|
||||
|
||||
|
||||
- name: Copy config files
|
||||
copy:
|
||||
src: "{{ item }}"
|
||||
dest: "/{{ item }}"
|
||||
owner: root
|
||||
group: root
|
||||
mode: 0644
|
||||
loop:
|
||||
- etc/dnsmasq.d/br-lxc
|
||||
- etc/lxc/ansible.conf
|
||||
- etc/network/interfaces.d/br-lxc
|
||||
notify:
|
||||
- Restart dnsmasq
|
||||
|
||||
|
||||
|
||||
- name: Fix evil Debian default /etc/network/interfaces
|
||||
lineinfile:
|
||||
dest: /etc/network/interfaces
|
||||
regexp: 'source.*interfaces.d'
|
||||
line: 'source-directory /etc/network/interfaces.d'
|
||||
backup: yes
|
||||
|
||||
|
||||
- name: dnsmasq should use /etc/resolv.conf
|
||||
lineinfile:
|
||||
path: /etc/default/dnsmasq
|
||||
line: 'IGNORE_RESOLVCONF=yes'
|
||||
regexp: '^\s*#*\s*IGNORE_RESOLVCONF=yes'
|
||||
backup: yes
|
||||
notify:
|
||||
- Restart dnsmasq
|
||||
|
||||
|
||||
- name: IPv4-Forwarding
|
||||
sysctl:
|
||||
name: net.ipv4.ip_forward
|
||||
value: '1'
|
||||
sysctl_file: /etc/sysctl.d/lxc.conf
|
||||
sysctl_set: yes
|
||||
state: present
|
||||
reload: yes
|
||||
|
||||
|
||||
- name: Raise inotify limit
|
||||
sysctl:
|
||||
name: fs.inotify.max_user_instances
|
||||
value: '1024'
|
||||
sysctl_file: 30-lxc-inotify.conf
|
||||
sysctl_set: yes
|
||||
state: present
|
||||
reload: yes
|
||||
|
||||
|
||||
- name: Enable CAP_SYS_TIME in Container
|
||||
lineinfile:
|
||||
dest: /usr/share/lxc/config/common.conf
|
||||
backrefs: yes
|
||||
regexp: '(^\s*[^#].*)sys_time ?(.*)$'
|
||||
line: '\1\2'
|
||||
backup: yes
|
||||
|
||||
|
||||
- name: lxc-net with systemd
|
||||
block:
|
||||
- name: Stop lxc-net service
|
||||
systemd:
|
||||
name: lxc-net
|
||||
state: stopped
|
||||
|
||||
- name: Disable lxc-net service
|
||||
systemd:
|
||||
name: lxc-net
|
||||
enabled: no
|
||||
|
||||
- name: Mask lxc-net service
|
||||
systemd:
|
||||
name: lxc-net
|
||||
masked: yes
|
||||
when: ansible_service_mgr == "systemd"
|
||||
|
||||
|
||||
- name: lxc-net without systemd
|
||||
block:
|
||||
- name: Disable lxc-net
|
||||
service:
|
||||
name: lxc-net
|
||||
enabled: no
|
||||
state: stopped
|
||||
ignore_errors: yes
|
||||
when: ansible_service_mgr != "systemd"
|
||||
|
||||
|
||||
- name: Bring up br-lxc
|
||||
command: ifup br-lxc
|
||||
args:
|
||||
creates: /sys/devices/virtual/net/br-lxc
|
||||
|
||||
|
||||
|
||||
handlers:
|
||||
- name: Restart dnsmasq
|
||||
service:
|
||||
name: dnsmasq
|
||||
state: restarted
|
||||
ignore_errors: yes
|
||||
|
0
12/Win/Unix-Datei.txt
Normal file
0
12/Win/Unix-Datei.txt
Normal file
3
12/Win/ansible.cfg
Normal file
3
12/Win/ansible.cfg
Normal file
|
@ -0,0 +1,3 @@
|
|||
[defaults]
|
||||
inventory = ./hosts
|
||||
|
9
12/Win/hosts
Normal file
9
12/Win/hosts
Normal file
|
@ -0,0 +1,9 @@
|
|||
[windows]
|
||||
win2k12r2 ansible_host=172.22.240.164
|
||||
|
||||
[windows:vars]
|
||||
ansible_user=Administrator
|
||||
ansible_password=XXXXX
|
||||
ansible_connection=winrm
|
||||
ansible_winrm_server_cert_validation=ignore
|
||||
|
141
12/Win/setup.txt
Normal file
141
12/Win/setup.txt
Normal file
|
@ -0,0 +1,141 @@
|
|||
win2k12r2 | SUCCESS => {
|
||||
"ansible_facts": {
|
||||
"ansible_architecture": "64-Bit",
|
||||
"ansible_architecture2": "x86_64",
|
||||
"ansible_bios_date": null,
|
||||
"ansible_bios_version": null,
|
||||
"ansible_date_time": {
|
||||
"date": "2022-03-18",
|
||||
"day": "18",
|
||||
"epoch": "1647607291,11022",
|
||||
"epoch_int": 1647607291,
|
||||
"epoch_local": "1647610891,11022",
|
||||
"hour": "13",
|
||||
"iso8601": "2022-03-18T12:41:31Z",
|
||||
"iso8601_basic": "20220318T134131110217",
|
||||
"iso8601_basic_short": "20220318T134131",
|
||||
"iso8601_micro": "2022-03-18T12:41:31.110217Z",
|
||||
"minute": "41",
|
||||
"month": "03",
|
||||
"second": "31",
|
||||
"time": "13:41:31",
|
||||
"tz": "W. Europe Standard Time",
|
||||
"tz_offset": "+01:00",
|
||||
"weekday": "Friday",
|
||||
"weekday_number": "5",
|
||||
"weeknumber": "11",
|
||||
"year": "2022"
|
||||
},
|
||||
"ansible_distribution": "Microsoft Windows Server 2012 R2 Standard - Testversion",
|
||||
"ansible_distribution_major_version": "6",
|
||||
"ansible_distribution_version": "6.3.9600.0",
|
||||
"ansible_domain": "",
|
||||
"ansible_env": {
|
||||
"ALLUSERSPROFILE": "C:\\ProgramData",
|
||||
"APPDATA": "C:\\Users\\Administrator\\AppData\\Roaming",
|
||||
"COMPUTERNAME": "WIN-A6UVOR2N33N",
|
||||
"ChocolateyInstall": "C:\\ProgramData\\chocolatey",
|
||||
"ChocolateyLastPathUpdate": "132835990150633065",
|
||||
"ChocolateyToolsLocation": "C:\\tools",
|
||||
"ComSpec": "C:\\Windows\\system32\\cmd.exe",
|
||||
"CommonProgramFiles": "C:\\Program Files\\Common Files",
|
||||
"CommonProgramFiles(x86)": "C:\\Program Files (x86)\\Common Files",
|
||||
"CommonProgramW6432": "C:\\Program Files\\Common Files",
|
||||
"FP_NO_HOST_CHECK": "NO",
|
||||
"HOMEDRIVE": "C:",
|
||||
"HOMEPATH": "\\Users\\Administrator",
|
||||
"LOCALAPPDATA": "C:\\Users\\Administrator\\AppData\\Local",
|
||||
"LOGONSERVER": "\\\\WIN-A6UVOR2N33N",
|
||||
"NUMBER_OF_PROCESSORS": "2",
|
||||
"OS": "Windows_NT",
|
||||
"PATHEXT": ".COM;.EXE;.BAT;.CMD;.VBS;.VBE;.JS;.JSE;.WSF;.WSH;.MSC;.CPL",
|
||||
"PROCESSOR_ARCHITECTURE": "AMD64",
|
||||
"PROCESSOR_IDENTIFIER": "Intel64 Family 6 Model 61 Stepping 2, GenuineIntel",
|
||||
"PROCESSOR_LEVEL": "6",
|
||||
"PROCESSOR_REVISION": "3d02",
|
||||
"PROMPT": "$P$G",
|
||||
"PSExecutionPolicyPreference": "Unrestricted",
|
||||
"PSModulePath": "C:\\Users\\Administrator\\Documents\\WindowsPowerShell\\Modules;C:\\Program Files\\WindowsPowerShell\\Modules;C:\\Windows\\system32\\WindowsPowerShell\\v1.0\\Modules",
|
||||
"PUBLIC": "C:\\Users\\Public",
|
||||
"Path": "C:\\Windows\\system32;C:\\Windows;C:\\Windows\\System32\\Wbem;C:\\Windows\\System32\\WindowsPowerShell\\v1.0\\;C:\\ProgramData\\chocolatey\\bin;",
|
||||
"ProgramData": "C:\\ProgramData",
|
||||
"ProgramFiles": "C:\\Program Files",
|
||||
"ProgramFiles(x86)": "C:\\Program Files (x86)",
|
||||
"ProgramW6432": "C:\\Program Files",
|
||||
"SystemDrive": "C:",
|
||||
"SystemRoot": "C:\\Windows",
|
||||
"TEMP": "C:\\Users\\ADMINI~1\\AppData\\Local\\Temp",
|
||||
"TMP": "C:\\Users\\ADMINI~1\\AppData\\Local\\Temp",
|
||||
"USERDOMAIN": "WIN-A6UVOR2N33N",
|
||||
"USERDOMAIN_ROAMINGPROFILE": "WIN-A6UVOR2N33N",
|
||||
"USERNAME": "Administrator",
|
||||
"USERPROFILE": "C:\\Users\\Administrator",
|
||||
"windir": "C:\\Windows"
|
||||
},
|
||||
"ansible_fqdn": "WIN-A6UVOR2N33N",
|
||||
"ansible_hostname": "WIN-A6UVOR2N33N",
|
||||
"ansible_interfaces": [
|
||||
{
|
||||
"connection_name": "Ethernet",
|
||||
"default_gateway": "172.22.240.1",
|
||||
"dns_domain": "br240.void",
|
||||
"interface_index": 21,
|
||||
"interface_name": "Gigabit-Netzwerkverbindung Intel(R) 82574L #2",
|
||||
"macaddress": "52:54:00:80:68:04"
|
||||
}
|
||||
],
|
||||
"ansible_ip_addresses": [
|
||||
"fe80::4d9b:297e:ee2f:4df2%21",
|
||||
"172.22.240.164"
|
||||
],
|
||||
"ansible_kernel": "6.3.9600.0",
|
||||
"ansible_lastboot": "2022-03-18 13:14:08Z",
|
||||
"ansible_machine_id": "S-1-5-21-4249200181-1233407984-53629394",
|
||||
"ansible_memfree_mb": 3435,
|
||||
"ansible_memtotal_mb": 4096,
|
||||
"ansible_netbios_name": "WIN-A6UVOR2N33N",
|
||||
"ansible_nodename": "WIN-A6UVOR2N33N",
|
||||
"ansible_os_family": "Windows",
|
||||
"ansible_os_installation_type": "Server",
|
||||
"ansible_os_name": "Microsoft Windows Server 2012 R2 Standard - Testversion",
|
||||
"ansible_os_product_type": "server",
|
||||
"ansible_owner_contact": "",
|
||||
"ansible_owner_name": "Windows-Benutzer",
|
||||
"ansible_pagefilefree_mb": 1408,
|
||||
"ansible_pagefiletotal_mb": 1408,
|
||||
"ansible_powershell_version": 4,
|
||||
"ansible_processor": [
|
||||
"0",
|
||||
"GenuineIntel",
|
||||
"Intel Core Processor (Broadwell, IBRS)",
|
||||
"1",
|
||||
"GenuineIntel",
|
||||
"Intel Core Processor (Broadwell, IBRS)"
|
||||
],
|
||||
"ansible_processor_count": 0,
|
||||
"ansible_processor_vcpus": 2,
|
||||
"ansible_product_name": null,
|
||||
"ansible_product_serial": null,
|
||||
"ansible_reboot_pending": false,
|
||||
"ansible_swaptotal_mb": 0,
|
||||
"ansible_system": "Win32NT",
|
||||
"ansible_system_description": "",
|
||||
"ansible_system_vendor": null,
|
||||
"ansible_uptime_seconds": 1646,
|
||||
"ansible_user_dir": "C:\\Users\\Administrator",
|
||||
"ansible_user_gecos": "",
|
||||
"ansible_user_id": "Administrator",
|
||||
"ansible_user_sid": "S-1-5-21-4249200181-1233407984-53629394-500",
|
||||
"ansible_virtualization_role": "NA",
|
||||
"ansible_virtualization_type": "NA",
|
||||
"ansible_win_rm_certificate_expires": "2024-10-26 23:04:12",
|
||||
"ansible_windows_domain": "WORKGROUP",
|
||||
"ansible_windows_domain_member": false,
|
||||
"ansible_windows_domain_role": "Stand-alone server",
|
||||
"gather_subset": [
|
||||
"all"
|
||||
],
|
||||
"module_setup": true
|
||||
},
|
||||
"changed": false
|
||||
}
|
12
12/Win/useradd.yml
Normal file
12
12/Win/useradd.yml
Normal file
|
@ -0,0 +1,12 @@
|
|||
---
|
||||
- hosts: windows
|
||||
|
||||
tasks:
|
||||
- name: Ensure user bob is present
|
||||
ansible.windows.win_user:
|
||||
name: bob
|
||||
password: B0bP4ssw0rd
|
||||
state: present
|
||||
groups:
|
||||
- Benutzer
|
||||
|
41
12/ansible.cfg
Normal file
41
12/ansible.cfg
Normal file
|
@ -0,0 +1,41 @@
|
|||
[defaults]
|
||||
|
||||
# Inventory
|
||||
inventory = ./hosts.ini
|
||||
inventory_plugins = ./plugins/inventory
|
||||
|
||||
# Roles paths
|
||||
roles_path = ./roles:./roles.extern:./roles.webcluster:/etc/ansible/roles
|
||||
|
||||
# Interpreter Discovery - Ohne Warnings
|
||||
interpreter_python = auto_silent
|
||||
|
||||
# Zusätzliche Module
|
||||
library = ./plugins/modules
|
||||
|
||||
# SSH
|
||||
remote_user = root
|
||||
#host_key_checking = False
|
||||
|
||||
# Retry files
|
||||
retry_files_enabled = yes
|
||||
retry_files_save_path = ./.cache/Retry/
|
||||
|
||||
# Log files
|
||||
#log_path = ./log/ansible.log
|
||||
|
||||
# Fact caching
|
||||
gathering = smart
|
||||
fact_caching_timeout = 86400
|
||||
fact_caching = yaml
|
||||
fact_caching_connection = ./.cache/facts/
|
||||
|
||||
# Farben ausschalten
|
||||
#nocolor = 1
|
||||
|
||||
[colors]
|
||||
# Für dunklen Hintergrund in der Console
|
||||
verbose = bright blue
|
||||
debug = bright gray
|
||||
error = bright red
|
||||
|
9
12/availenabled.yml
Normal file
9
12/availenabled.yml
Normal file
|
@ -0,0 +1,9 @@
|
|||
---
|
||||
- hosts: localhost
|
||||
gather_facts: no
|
||||
|
||||
tasks:
|
||||
- availenabled:
|
||||
path: /tmp/apache2/mods-
|
||||
name: foo
|
||||
|
5
12/availenabled_module_args.json
Normal file
5
12/availenabled_module_args.json
Normal file
|
@ -0,0 +1,5 @@
|
|||
{"ANSIBLE_MODULE_ARGS": {
|
||||
"path": "/tmp/apache2/mods-",
|
||||
"name": "foo"
|
||||
}
|
||||
}
|
53
12/db+wp.yml
Normal file
53
12/db+wp.yml
Normal file
|
@ -0,0 +1,53 @@
|
|||
---
|
||||
- hosts: localhost
|
||||
|
||||
vars:
|
||||
my_image_mariadb: 'mariadb:10.3'
|
||||
my_image_wordpress: 'wordpress'
|
||||
|
||||
tasks:
|
||||
- name: Download Docker image
|
||||
docker_image:
|
||||
name: '{{ item }}'
|
||||
state: present
|
||||
tag: latest
|
||||
source: pull
|
||||
with_items:
|
||||
- '{{ my_image_mariadb }}'
|
||||
- '{{ my_image_wordpress }}'
|
||||
|
||||
- name: Create persistant volume (Ansible 2.4)
|
||||
docker_volume:
|
||||
name: db_data
|
||||
state: present
|
||||
|
||||
- name: Create DB container (Ansible 2.1)
|
||||
docker_container:
|
||||
name: db
|
||||
image: '{{ my_image_mariadb }}'
|
||||
volumes:
|
||||
- db_data:/var/lib/mysql
|
||||
restart_policy: always
|
||||
env:
|
||||
MYSQL_ROOT_PASSWORD: mysql
|
||||
MYSQL_DATABASE: wordpress
|
||||
MYSQL_USER: wordpress
|
||||
MYSQL_PASSWORD: "{{ lookup('password', './wordpress.pw') }}"
|
||||
|
||||
- name: Create WP container (Ansible 2.1)
|
||||
docker_container:
|
||||
name: wordpress
|
||||
image: '{{ my_image_wordpress }}'
|
||||
restart_policy: always
|
||||
exposed_ports:
|
||||
- 80
|
||||
published_ports:
|
||||
- 8888:80
|
||||
links:
|
||||
- db:db
|
||||
env:
|
||||
WORDPRESS_DB_HOST: db:3306
|
||||
WORDPRESS_DB_USER: wordpress
|
||||
WORDPRESS_DB_PASSWORD: "{{ lookup('password', './wordpress.pw') }}"
|
||||
|
||||
|
12
12/docker_install.yml
Normal file
12
12/docker_install.yml
Normal file
|
@ -0,0 +1,12 @@
|
|||
---
|
||||
- hosts: localhost
|
||||
tasks:
|
||||
- apt:
|
||||
name: "{{ packages }}"
|
||||
vars:
|
||||
packages:
|
||||
- docker.io
|
||||
- docker-compose
|
||||
- python3-docker
|
||||
become: True
|
||||
|
50
12/docker_install_old.yml
Normal file
50
12/docker_install_old.yml
Normal file
|
@ -0,0 +1,50 @@
|
|||
---
|
||||
- hosts: all
|
||||
tasks:
|
||||
- name: Update the apt package index
|
||||
become: yes
|
||||
apt:
|
||||
name: "*"
|
||||
state: latest
|
||||
update_cache: yes
|
||||
force_apt_get: yes
|
||||
- name: Install packages for apt add repository over HTTPS
|
||||
become: yes
|
||||
apt:
|
||||
name: "{{ packagesdep }}"
|
||||
force_apt_get: yes
|
||||
state: latest
|
||||
update_cache: yes
|
||||
vars:
|
||||
packagesdep:
|
||||
- git
|
||||
- apt-transport-https
|
||||
- ca-certificates
|
||||
- wget
|
||||
- software-properties-common
|
||||
- gnupg2
|
||||
- curl
|
||||
- name: Add Apt signing key from official docker repo
|
||||
apt_key:
|
||||
url: https://download.docker.com/linux/debian/gpg
|
||||
state: present
|
||||
- name: add docker official repository for Debian Stretch
|
||||
apt_repository:
|
||||
repo: deb [arch=amd64] https://download.docker.com/linux/debian stretch stable
|
||||
state: present
|
||||
- name: Index new repo into the cache
|
||||
become: yes
|
||||
apt:
|
||||
name: "*"
|
||||
state: latest
|
||||
update_cache: yes
|
||||
force_apt_get: yes
|
||||
- name: actually install docker
|
||||
apt:
|
||||
name: "docker-ce"
|
||||
state: latest
|
||||
- name: Ensure docker-compose is installed and available
|
||||
get_url:
|
||||
url: https://github.com/docker/compose/releases/download/1.22.0/docker-compose-{{ ansible_system }}-{{ ansible_userspace_architecture }}
|
||||
dest: /usr/local/bin/docker-compose
|
||||
mode: 'u+x,g+x'
|
38
12/group_by.yml
Normal file
38
12/group_by.yml
Normal file
|
@ -0,0 +1,38 @@
|
|||
---
|
||||
- hosts:
|
||||
- all
|
||||
- localhost
|
||||
|
||||
tasks:
|
||||
- group_by:
|
||||
key: "sv_pkgsvcmgr_{{ ansible_pkg_mgr }}-{{ ansible_service_mgr }}"
|
||||
parents:
|
||||
- "sv_pkgmgr_{{ ansible_pkg_mgr }}"
|
||||
|
||||
- group_by:
|
||||
key: "sv_svcmgr_{{ ansible_service_mgr }}"
|
||||
|
||||
- group_by:
|
||||
key: "sv_mac_{{ '_'.join(ansible_default_ipv4.macaddress.split(':')[5:6]) }}"
|
||||
|
||||
- group_by:
|
||||
key: "sv_net4_{{ ansible_default_ipv4.network }}"
|
||||
|
||||
- group_by:
|
||||
key: "sv_v6int_{{ ansible_default_ipv6.interface|default('nov6') }}"
|
||||
|
||||
- group_by:
|
||||
key: "sv_distri_{{ ansible_distribution }}"
|
||||
|
||||
- group_by:
|
||||
key: "sv_family_{{ ansible_os_family }}"
|
||||
|
||||
- group_by:
|
||||
key: "sv_{{ ansible_virtualization_role }}_{{ ansible_virtualization_type }}"
|
||||
|
||||
- hosts: localhost
|
||||
gather_facts: no
|
||||
tasks:
|
||||
- debug:
|
||||
msg: "{{ groups | dict2items | selectattr('key', 'contains', 'sv_') | list | items2dict }}"
|
||||
|
7
12/ping.yml
Normal file
7
12/ping.yml
Normal file
|
@ -0,0 +1,7 @@
|
|||
---
|
||||
- hosts:
|
||||
- all
|
||||
- localhost
|
||||
tasks:
|
||||
- ping:
|
||||
|
5
12/setup.yml
Normal file
5
12/setup.yml
Normal file
|
@ -0,0 +1,5 @@
|
|||
---
|
||||
- hosts: all
|
||||
|
||||
tasks: []
|
||||
|
1
12/timesync.yml
Symbolic link
1
12/timesync.yml
Symbolic link
|
@ -0,0 +1 @@
|
|||
../roles.extern/roles_timesync/timesync.yml
|
|
@ -1 +1 @@
|
|||
11/ansible.cfg
|
||||
12/ansible.cfg
|
6
helper/12_gitmodules_Prepare-Workshop.sh
Executable file
6
helper/12_gitmodules_Prepare-Workshop.sh
Executable file
|
@ -0,0 +1,6 @@
|
|||
#!/bin/bash -ex
|
||||
|
||||
mkdir -p roles.extern
|
||||
|
||||
git submodule add https://git.velt.biz/Ansible/Prepare_Workshop.git 12/Prepare_Workshop
|
||||
|
6
helper/12_gitmodules_timesync.sh
Executable file
6
helper/12_gitmodules_timesync.sh
Executable file
|
@ -0,0 +1,6 @@
|
|||
#!/bin/bash -ex
|
||||
|
||||
mkdir -p roles.extern
|
||||
|
||||
git submodule add https://git.velt.biz/Ansible/roles_timesync.git roles.extern/roles_timesync
|
||||
|
6
helper/12_packages.sh
Executable file
6
helper/12_packages.sh
Executable file
|
@ -0,0 +1,6 @@
|
|||
#!/bin/bash
|
||||
|
||||
sudo apt install --no-install-recommends --yes \
|
||||
jq \
|
||||
nmap\
|
||||
|
15
helper/create_hosts_from_file.sh
Executable file
15
helper/create_hosts_from_file.sh
Executable file
|
@ -0,0 +1,15 @@
|
|||
#!/bin/bash
|
||||
|
||||
if [ -z "$1" -o ! -f "$1" ]; then
|
||||
echo Need filename
|
||||
exit 1
|
||||
fi
|
||||
|
||||
for GROUP in alpine archlinux centos debian devuan fedora oracle opensuse ubuntu voidlinux
|
||||
do
|
||||
grep "${GROUP}" "$1" | while read NAME IP REST
|
||||
do
|
||||
echo -e "${IP}\t${NAME}.heinlein.akademie\t\t${NAME}"
|
||||
done
|
||||
done
|
||||
|
10
helper/create_hosts_from_lxc.sh
Executable file
10
helper/create_hosts_from_lxc.sh
Executable file
|
@ -0,0 +1,10 @@
|
|||
#!/bin/bash
|
||||
|
||||
for GROUP in alpine archlinux centos debian devuan fedora oracle opensuse ubuntu voidlinux
|
||||
do
|
||||
sudo lxc-ls -f -F name,ipv4 -g ${GROUP} | grep -v NAME | while read NAME IP
|
||||
do
|
||||
echo -e "${IP}\t${NAME}.heinlein.akademie\t\t${NAME}"
|
||||
done
|
||||
done
|
||||
|
90
helper/create_inventory_from_file.sh
Executable file
90
helper/create_inventory_from_file.sh
Executable file
|
@ -0,0 +1,90 @@
|
|||
#!/bin/bash
|
||||
|
||||
if [ -z "$1" -o ! -f "$1" ]; then
|
||||
echo Need filename
|
||||
exit 1
|
||||
fi
|
||||
|
||||
for GROUP in almalinux alpine archlinux centos debian devuan fedora oracle rockylinux opensuse ubuntu voidlinux
|
||||
do
|
||||
echo "[${GROUP}]"
|
||||
grep "${GROUP}" "$1" | while read NAME IP REST
|
||||
do
|
||||
case "${GROUP}" in
|
||||
almalinux|rockylinux)
|
||||
echo -e "${NAME}\t\tansible_host=${IP}"
|
||||
;;
|
||||
*)
|
||||
echo "${NAME}"
|
||||
;;
|
||||
esac
|
||||
done
|
||||
echo ""
|
||||
done
|
||||
|
||||
|
||||
cat <<EOF
|
||||
############################################################
|
||||
|
||||
[apk:children]
|
||||
alpine
|
||||
|
||||
[apt]
|
||||
EOF
|
||||
|
||||
grep "mint" "$1" | while read NAME IP REST
|
||||
do
|
||||
echo "${NAME}"
|
||||
done
|
||||
|
||||
cat <<EOF
|
||||
|
||||
[apt:children]
|
||||
debian
|
||||
devuan
|
||||
ubuntu
|
||||
|
||||
[pacman:children]
|
||||
archlinux
|
||||
|
||||
[yum:children]
|
||||
almalinux
|
||||
centos
|
||||
fedora
|
||||
oracle
|
||||
rockylinux
|
||||
|
||||
[xbps:children]
|
||||
voidlinux
|
||||
|
||||
[zypper:children]
|
||||
opensuse
|
||||
|
||||
############################################################
|
||||
|
||||
[lb]
|
||||
tn00-alpine3j
|
||||
tn00-alpine3k
|
||||
|
||||
[lb:vars]
|
||||
ansible_ssh_transfer_method=piped
|
||||
|
||||
[worker]
|
||||
tn00-ubu2004a
|
||||
tn00-ubu2004b
|
||||
tn00-ubu2004c
|
||||
tn00-ubu2004d
|
||||
|
||||
tn00-debian11
|
||||
|
||||
[db]
|
||||
tn00-ubu2004a
|
||||
tn00-ubu2004b
|
||||
|
||||
[webcluster:children]
|
||||
lb
|
||||
worker
|
||||
db
|
||||
|
||||
EOF
|
||||
|
85
helper/create_inventory_from_lxc.sh
Executable file
85
helper/create_inventory_from_lxc.sh
Executable file
|
@ -0,0 +1,85 @@
|
|||
#!/bin/bash
|
||||
|
||||
for GROUP in almalinux alpine archlinux centos debian devuan fedora oracle rockylinux opensuse ubuntu voidlinux
|
||||
do
|
||||
echo "[${GROUP}]"
|
||||
sudo lxc-ls -f -F name,ipv4 -g ${GROUP} | grep -v NAME | while read NAME IP
|
||||
do
|
||||
case "${GROUP}" in
|
||||
almalinux|rockylinux)
|
||||
echo -e "${NAME}\t\tansible_host=${IP}"
|
||||
;;
|
||||
*)
|
||||
echo "${NAME}"
|
||||
;;
|
||||
esac
|
||||
done
|
||||
echo ""
|
||||
done
|
||||
|
||||
|
||||
cat <<EOF
|
||||
############################################################
|
||||
|
||||
[apk:children]
|
||||
alpine
|
||||
|
||||
[apt]
|
||||
EOF
|
||||
|
||||
sudo lxc-ls -f -F name,ipv4 -g mint | grep -v NAME | while read NAME IP
|
||||
do
|
||||
echo "${NAME}"
|
||||
done
|
||||
|
||||
cat <<EOF
|
||||
|
||||
[apt:children]
|
||||
debian
|
||||
devuan
|
||||
ubuntu
|
||||
|
||||
[pacman:children]
|
||||
archlinux
|
||||
|
||||
[yum:children]
|
||||
almalinux
|
||||
centos
|
||||
fedora
|
||||
oracle
|
||||
rockylinux
|
||||
|
||||
[xbps:children]
|
||||
voidlinux
|
||||
|
||||
[zypper:children]
|
||||
opensuse
|
||||
|
||||
############################################################
|
||||
|
||||
[lb]
|
||||
tn00-alpine3j
|
||||
tn00-alpine3k
|
||||
|
||||
[lb:vars]
|
||||
ansible_ssh_transfer_method=piped
|
||||
|
||||
[worker]
|
||||
tn00-ubu2004a
|
||||
tn00-ubu2004b
|
||||
tn00-ubu2004c
|
||||
tn00-ubu2004d
|
||||
|
||||
tn00-debian11
|
||||
|
||||
[db]
|
||||
tn00-ubu2004a
|
||||
tn00-ubu2004b
|
||||
|
||||
[webcluster:children]
|
||||
lb
|
||||
worker
|
||||
db
|
||||
|
||||
EOF
|
||||
|
6
inventory-scripts/hosts.json.sh
Executable file
6
inventory-scripts/hosts.json.sh
Executable file
|
@ -0,0 +1,6 @@
|
|||
#!/bin/sh
|
||||
|
||||
cat <<EOF
|
||||
{ "gruppe1": { "hosts": ["host1", "host2"] }, "gruppe2": { "hosts": ["host3", "host4"] }, "_meta": {} }
|
||||
EOF
|
||||
|
36
inventory-scripts/inventory_lxc.py
Executable file
36
inventory-scripts/inventory_lxc.py
Executable file
|
@ -0,0 +1,36 @@
|
|||
#!/usr/bin/python3
|
||||
|
||||
import json
|
||||
import sys
|
||||
|
||||
try:
|
||||
import lxc
|
||||
except ImportError:
|
||||
print("Could not import lxc module!")
|
||||
sys.exit(1)
|
||||
|
||||
########################################
|
||||
inventory ={ '_meta':{'hostvars':{} } }
|
||||
########################################
|
||||
|
||||
ctnames = lxc.list_containers()
|
||||
|
||||
for ctname in ctnames:
|
||||
ct = lxc.Container(ctname)
|
||||
|
||||
if ct.running:
|
||||
groups = ct.get_running_config_item('lxc.group')
|
||||
if not groups:
|
||||
groups = 'ungrouped'
|
||||
for group in groups.rstrip().split('\n'):
|
||||
if not group in inventory:
|
||||
inventory[group] = {
|
||||
'hosts': [],
|
||||
'vars': {
|
||||
'ansible_connection': 'lxc',
|
||||
}
|
||||
}
|
||||
inventory[group]['hosts'].append(ctname)
|
||||
|
||||
print(json.dumps(inventory))
|
||||
|
33
inventory-scripts/inventory_lxc.py.OLD
Executable file
33
inventory-scripts/inventory_lxc.py.OLD
Executable file
|
@ -0,0 +1,33 @@
|
|||
#!/usr/bin/python3
|
||||
|
||||
import json
|
||||
import sys
|
||||
|
||||
try:
|
||||
import lxc
|
||||
except ImportError:
|
||||
print("Could not import lxc module!")
|
||||
sys.exit(1)
|
||||
|
||||
########################################
|
||||
inventory ={ '_meta':{'hostvars':{} } }
|
||||
########################################
|
||||
|
||||
ctnames = lxc.list_containers()
|
||||
|
||||
for ctname in ctnames:
|
||||
ct = lxc.Container(ctname)
|
||||
|
||||
if ct.running:
|
||||
for group in ct.get_running_config_item('lxc.group').rstrip().split('\n'):
|
||||
if not group in inventory:
|
||||
inventory[group] = {
|
||||
'hosts': [],
|
||||
'vars': {
|
||||
'ansible_connection': 'lxc',
|
||||
}
|
||||
}
|
||||
inventory[group]['hosts'].append(ctname)
|
||||
|
||||
print(json.dumps(inventory))
|
||||
|
40
inventory-scripts/inventory_lxc_ip.py
Executable file
40
inventory-scripts/inventory_lxc_ip.py
Executable file
|
@ -0,0 +1,40 @@
|
|||
#!/usr/bin/python3
|
||||
|
||||
import json
|
||||
import sys
|
||||
|
||||
try:
|
||||
import lxc
|
||||
except ImportError:
|
||||
print("Could not import lxc module!")
|
||||
sys.exit(1)
|
||||
|
||||
########################################
|
||||
inventory ={ '_meta':{'hostvars':{} } }
|
||||
########################################
|
||||
|
||||
ctnames = lxc.list_containers()
|
||||
|
||||
for ctname in ctnames:
|
||||
ct = lxc.Container(ctname)
|
||||
|
||||
if ct.running:
|
||||
groups = ct.get_running_config_item('lxc.group')
|
||||
if not groups:
|
||||
groups = 'ungrouped'
|
||||
for group in groups.rstrip().split('\n'):
|
||||
if not group in inventory:
|
||||
inventory[group] = {
|
||||
'hosts': [],
|
||||
'vars': {
|
||||
'ansible_user': 'root',
|
||||
},
|
||||
}
|
||||
inventory[group]['hosts'].append(ctname)
|
||||
inventory['_meta']['hostvars'][ctname] = {
|
||||
'ansible_host': ct.get_ips()[0],
|
||||
}
|
||||
|
||||
|
||||
print(json.dumps(inventory))
|
||||
|
22
inventory/hosts.nmap.cache.yml
Normal file
22
inventory/hosts.nmap.cache.yml
Normal file
|
@ -0,0 +1,22 @@
|
|||
---
|
||||
plugin: community.general.nmap
|
||||
#strict: False
|
||||
#ports: False
|
||||
#ipv4: True
|
||||
#ipv6: False
|
||||
#address: 192.168.0.0/24
|
||||
#address: 192.168.50.0/24
|
||||
address: 10.128.17.0/24
|
||||
#address: 80.241.57.126/32
|
||||
|
||||
cache: true
|
||||
cache_connection: ./.cache/inventory
|
||||
cache_plugin: yaml
|
||||
cache_prefix: inventory_yaml_
|
||||
cache_timeout: 30
|
||||
|
||||
groups:
|
||||
nmap_without_hostname: "name|ansible.utils.ipv4"
|
||||
nmap_debian: "'debian' in name"
|
||||
nmap_centos: "'centos' in name"
|
||||
|
16
inventory/hosts.nmap.yml
Normal file
16
inventory/hosts.nmap.yml
Normal file
|
@ -0,0 +1,16 @@
|
|||
---
|
||||
plugin: community.general.nmap
|
||||
#strict: False
|
||||
#ports: False
|
||||
#ipv4: True
|
||||
#ipv6: False
|
||||
#address: 192.168.0.0/24
|
||||
#address: 192.168.50.0/24
|
||||
address: 10.128.17.0/24
|
||||
#address: 80.241.57.126/32
|
||||
|
||||
groups:
|
||||
nmap_without_hostname: "name|ansible.utils.ipv4"
|
||||
nmap_debian: "'debian' in name"
|
||||
nmap_centos: "'centos' in name"
|
||||
|
4
inventory/libvirt_lxc.yml
Normal file
4
inventory/libvirt_lxc.yml
Normal file
|
@ -0,0 +1,4 @@
|
|||
---
|
||||
plugin: community.libvirt.libvirt
|
||||
uri: lxc:/
|
||||
|
3
inventory/lxc.yml
Normal file
3
inventory/lxc.yml
Normal file
|
@ -0,0 +1,3 @@
|
|||
---
|
||||
plugin: lxc
|
||||
|
75
plugins/inventory/lxc.py
Normal file
75
plugins/inventory/lxc.py
Normal file
|
@ -0,0 +1,75 @@
|
|||
from __future__ import (absolute_import, division, print_function)
|
||||
__metaclass__ = type
|
||||
|
||||
DOCUMENTATION = r'''
|
||||
'''
|
||||
|
||||
EXAMPLES = r'''
|
||||
'''
|
||||
|
||||
from ansible.plugins.inventory import BaseInventoryPlugin, Constructable
|
||||
from ansible.errors import AnsibleError
|
||||
|
||||
try:
|
||||
import lxc
|
||||
except ImportError:
|
||||
raise AnsibleError('the lxc inventory plugin requires lxc-python.')
|
||||
|
||||
class InventoryModule(BaseInventoryPlugin, Constructable):
|
||||
NAME = 'lxc'
|
||||
|
||||
def parse(self, inventory, loader, path, cache=True):
|
||||
super(InventoryModule, self).parse(
|
||||
inventory,
|
||||
loader,
|
||||
path,
|
||||
cache=cache
|
||||
)
|
||||
|
||||
config_data = self._read_config_data(path)
|
||||
self._consume_options(config_data)
|
||||
|
||||
ctnames = lxc.list_containers()
|
||||
for ctname in ctnames:
|
||||
ct = lxc.Container(ctname)
|
||||
|
||||
if ct.running:
|
||||
self.inventory.add_host(ctname)
|
||||
for group in ct.get_running_config_item('lxc.group').rstrip().split('\n'):
|
||||
self.inventory.add_group(group)
|
||||
self.inventory.add_child(group, ctname)
|
||||
self.inventory.set_variable(ctname, 'ansible_connection', 'lxc')
|
||||
|
||||
# Get variables for compose
|
||||
# variables = self.inventory.hosts[ctname].get_vars()
|
||||
# print(variables)
|
||||
# print(ctname)
|
||||
# print( self.get_option('compose') )
|
||||
# print( self.get_option('strict') )
|
||||
|
||||
# # Set composed variables
|
||||
# self._set_composite_vars(
|
||||
# self.get_option('compose'),
|
||||
# variables,
|
||||
# ctname,
|
||||
# self.get_option('strict'),
|
||||
# )
|
||||
# print('XXX')
|
||||
#
|
||||
# # Add host to composed groups
|
||||
# self._add_host_to_composed_groups(
|
||||
# self.get_option('groups'),
|
||||
# variables,
|
||||
# inventory_hostname,
|
||||
# self.get_option('strict'),
|
||||
# )
|
||||
#
|
||||
# # Add host to keyed groups
|
||||
# self._add_host_to_keyed_groups(
|
||||
# self.get_option('keyed_groups'),
|
||||
# variables,
|
||||
# inventory_hostname,
|
||||
# self.get_option('strict'),
|
||||
# )
|
||||
|
||||
|
81
plugins/modules/availenabled.py
Normal file
81
plugins/modules/availenabled.py
Normal file
|
@ -0,0 +1,81 @@
|
|||
#!/usr/bin/python
|
||||
|
||||
import os
|
||||
from operator import xor
|
||||
|
||||
def main():
|
||||
module = AnsibleModule(
|
||||
argument_spec = dict(
|
||||
path = dict(required=True),
|
||||
base = dict(default=""),
|
||||
p_enabled = dict(default='enabled'),
|
||||
p_available = dict(default='available'),
|
||||
name = dict(required=True),
|
||||
suffix= dict(default='.conf'),
|
||||
state = dict(default='present', choices=['present', 'absent']),
|
||||
)
|
||||
)
|
||||
|
||||
# path: /etc/apache2 or /etc/apache2/conf-
|
||||
# base: conf- or ""
|
||||
# name: FILENAME or FILENAME.conf
|
||||
path = module.params.get('path')
|
||||
base = module.params.get('base')
|
||||
p_enabled = module.params.get('p_enabled')
|
||||
p_available = module.params.get('p_available')
|
||||
name = module.params.get('name')
|
||||
suffix = module.params.get('suffix')
|
||||
state = module.params.get('state') == 'present'
|
||||
|
||||
# pre-checks
|
||||
if os.path.isdir(path):
|
||||
p_available = os.path.join(path, base + p_available)
|
||||
p_enabled = os.path.join(path, base + p_enabled)
|
||||
else:
|
||||
p_available = path + p_available
|
||||
p_enabled = path + p_enabled
|
||||
|
||||
for p in [p_available, p_enabled]:
|
||||
if not os.path.isdir(p):
|
||||
module.fail_json(msg="Directory %s not found" % p)
|
||||
|
||||
# define internal variables
|
||||
src = os.path.join(p_available, name + suffix)
|
||||
dest = os.path.join(p_enabled, name + suffix)
|
||||
|
||||
if not (os.path.isfile(src) or os.path.islink(src)):
|
||||
module.fail_json(msg="Source not found")
|
||||
|
||||
dest_exists=True
|
||||
if not (os.path.isfile(dest) or os.path.islink(dest)):
|
||||
dest_exists=False
|
||||
|
||||
# if there's no difference, no change, exit "ok"
|
||||
if not xor(state, dest_exists):
|
||||
module.exit_json()
|
||||
|
||||
if state:
|
||||
# try to create symlink
|
||||
try:
|
||||
os.symlink(os.path.relpath(src, p_enabled), dest)
|
||||
except:
|
||||
module.fail_json(msg="Could not create symlink")
|
||||
else:
|
||||
# test, if symlink
|
||||
if not os.path.islink(dest):
|
||||
module.fail_json(msg="Destination is not a symlink")
|
||||
|
||||
# try to remove symlink
|
||||
try:
|
||||
os.unlink(dest)
|
||||
except:
|
||||
module.fail_json(msg="Could not remove symlink")
|
||||
|
||||
module.exit_json(changed=True)
|
||||
|
||||
|
||||
|
||||
from ansible.module_utils.basic import *
|
||||
if __name__ == '__main__':
|
||||
main()
|
||||
|
177
plugins/modules/lxc_container_info.py
Normal file
177
plugins/modules/lxc_container_info.py
Normal file
|
@ -0,0 +1,177 @@
|
|||
#!/usr/bin/python
|
||||
|
||||
# Copyright: (c) 2020-, Sven Velt <sven-ansiblerole@velt.biz>
|
||||
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
||||
from __future__ import (absolute_import, division, print_function)
|
||||
__metaclass__ = type
|
||||
|
||||
DOCUMENTATION = r'''
|
||||
---
|
||||
module: lxc_container_info
|
||||
short_description: Gather info about LXC Containers
|
||||
version_added: "0.1.0"
|
||||
description: Gather some information about (all) LXC Containers
|
||||
options:
|
||||
name:
|
||||
description: Name of Container to gather informations
|
||||
required: false
|
||||
type: str
|
||||
requirements:
|
||||
- 'lxc-python3'
|
||||
author:
|
||||
- Sven Velt
|
||||
'''
|
||||
|
||||
EXAMPLES = r'''
|
||||
# Gather information of all containers:
|
||||
- name: Gather LXC informations
|
||||
lxc_container_info:
|
||||
|
||||
# Gather information of one container:
|
||||
- name: Gather LXC informations
|
||||
lxc_container_info:
|
||||
name: containername
|
||||
'''
|
||||
|
||||
|
||||
RETURN = r'''
|
||||
# These are examples of possible return values, and in general should use other names for return values.
|
||||
containers:
|
||||
description: dict of container information
|
||||
returned: always
|
||||
type: complex
|
||||
contains:
|
||||
containername:
|
||||
description: name of container
|
||||
type: complex
|
||||
contains:
|
||||
all_interfaces:
|
||||
description: List of all interfaces
|
||||
type: str
|
||||
returned: always
|
||||
sample: '["lo", "eth0"]'
|
||||
defined:
|
||||
description: if container is defined
|
||||
type: bool
|
||||
returned: always
|
||||
sample: true
|
||||
exists:
|
||||
description: if container is defined
|
||||
type: bool
|
||||
returned: always
|
||||
sample: true
|
||||
init_pid:
|
||||
description: PID of init of container (if running)
|
||||
type: init
|
||||
sample: 1234
|
||||
original_message:
|
||||
description: The original name param that was passed in.
|
||||
type: str
|
||||
returned: always
|
||||
sample: 'hello world'
|
||||
message:
|
||||
description: The output message that the test module generates.
|
||||
type: str
|
||||
returned: always
|
||||
sample: 'goodbye'
|
||||
my_useful_info:
|
||||
description: The dictionary containing information about your system.
|
||||
type: dict
|
||||
returned: always
|
||||
sample: {
|
||||
'foo': 'bar',
|
||||
'answer': 42,
|
||||
}
|
||||
'''
|
||||
|
||||
import ipaddress
|
||||
|
||||
try:
|
||||
import lxc
|
||||
except ImportError:
|
||||
HAS_LXC = False
|
||||
else:
|
||||
HAS_LXC = True
|
||||
|
||||
from ansible.module_utils.basic import AnsibleModule
|
||||
|
||||
|
||||
def run_module():
|
||||
module_args = dict(
|
||||
name=dict(type='str', default=''),
|
||||
)
|
||||
|
||||
result = dict(
|
||||
changed=False,
|
||||
containers={},
|
||||
)
|
||||
|
||||
module = AnsibleModule(
|
||||
argument_spec=module_args,
|
||||
supports_check_mode=True
|
||||
)
|
||||
|
||||
if not HAS_LXC:
|
||||
module.fail_json(
|
||||
msg='The `lxc` module is not importable. Check the requirements.'
|
||||
)
|
||||
|
||||
if module.params['name']:
|
||||
ctnames = [ module.params['name'], ]
|
||||
else:
|
||||
ctnames = lxc.list_containers()
|
||||
|
||||
for ctname in ctnames:
|
||||
ct = lxc.Container(ctname)
|
||||
|
||||
res_ct = {}
|
||||
res_ct['defined'] = ct.defined
|
||||
res_ct['exists'] = ct.defined
|
||||
res_ct['state'] = ct.state
|
||||
res_ct['running'] = ct.running
|
||||
res_ct['init_pid'] = ct.init_pid
|
||||
res_ct['all_interfaces'] = ct.get_interfaces()
|
||||
|
||||
res_ifaces = {}
|
||||
for iface in ct.get_interfaces():
|
||||
res_if = {}
|
||||
res_if['ipv4_addresses'] = []
|
||||
res_if['ipv6_addresses'] = []
|
||||
for addr in ct.get_ips(iface):
|
||||
try:
|
||||
res_if['ipv4_addresses'].append(str(ipaddress.IPv4Address(addr)))
|
||||
except ipaddress.AddressValueError:
|
||||
try:
|
||||
res_if['ipv6_addresses'].append(str(ipaddress.IPv6Address(addr)))
|
||||
except:
|
||||
pass
|
||||
res_ifaces[iface] = res_if
|
||||
res_ct['interfaces'] = res_ifaces
|
||||
|
||||
res_stat = {}
|
||||
if ct.running:
|
||||
res_stat['mem'] = {
|
||||
'usage': int(ct.get_cgroup_item("memory.usage_in_bytes")),
|
||||
'max_usage': int(ct.get_cgroup_item("memory.max_usage_in_bytes")),
|
||||
'usage_mb': int(ct.get_cgroup_item("memory.usage_in_bytes")) // 1048576,
|
||||
'max_usage_mb': int(ct.get_cgroup_item("memory.max_usage_in_bytes")) // 1048576,
|
||||
}
|
||||
res_stat['kmem'] = {
|
||||
'usage': int(ct.get_cgroup_item("memory.kmem.usage_in_bytes")),
|
||||
'max_usage': int(ct.get_cgroup_item("memory.kmem.max_usage_in_bytes")),
|
||||
'usage_mb': int(ct.get_cgroup_item("memory.kmem.usage_in_bytes")) // 1048576,
|
||||
'max_usage_mb': int(ct.get_cgroup_item("memory.kmem.max_usage_in_bytes")) // 1048576,
|
||||
}
|
||||
res_ct['stats'] = res_stat
|
||||
|
||||
result['containers'][ctname] = res_ct
|
||||
|
||||
module.exit_json(**result)
|
||||
|
||||
|
||||
def main():
|
||||
run_module()
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
main()
|
Loading…
Reference in a new issue